[TOC]
# jsp脚本和注释
servlet脚本会变翻译到和webapps平级的work文件夹下
在webapps文件下,有个conf文件夹,这个文件下有web.xml
jsp本质就是servlet
jsp脚本:
~~~
1)<%java代码%> ----- 内部的java代码翻译到service方法的内部
2)<%=java变量或表达式 %> ----- 会被翻译成service方法内部out.print(),就是页面显示
3)<%!java代码%> ---- 会被翻译成servlet的成员的内容,就是类成员变量
~~~
jsp注释: 不同的注释可见范围是不同
~~~
1)Html注释:<!--注释内容--> ---可见范围 jsp源码、翻译后的servlet、页面显示html源码
2)java注释://单行注释 /*多行注释*/ --可见范围 jsp源码 翻译后的servlet
3)jsp注释:<%--注释内容--%> ----- 可见范围 jsp源码可见
~~~
# jsp运行原理-----jsp本质就是servlet
jsp在第一次被访问时会被Web容器翻译成servlet,在执行
过程:
第一次访问---->helloServlet.jsp---->helloServlet_jsp.java---->编译运行
PS:被翻译后的servlet在Tomcat的work目录中可以找到
# jsp指令(3个)
jsp的指令是指导jsp翻译和运行的命令,jsp包括三大指令:
1)page指令 --- 属性最多的指令(实际开发中page指令默认)
属性最多的一个指令,根据不同的属性,指导整个页面特性
格式:<%@ page 属性名1= "属性值1" 属性名2= "属性值2" ...%>
常用属性如下:
language:jsp脚本中可以嵌入的语言种类
pageEncoding:当前jsp文件的本身编码---内部可以包含contentType
contentType:response.setContentType(text/html;charset=UTF-8)
session:是否jsp在翻译时自动创建session,默认session是true
import:导入java的包
errorPage:当当前页面出错后跳转到哪个页面
isErrorPage:当前页面是一个处理错误的页面
buffer : 缓冲区out的大小,buffer="8kb"
~~~
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8" session="true" import="java.util.*" errorPage="/error.jsp"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
int i =3;
System.out.println(i);
List list = new ArrayList();
//或者
java.util.List list1 = new java.util.ArrayList();
%>
<%=i %>
<%! String str = "你好"; %>
<%=str %>
</body>
</html>
~~~
错误全局的话要在web.xml那配置
~~~
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>w1</display-name>
<!-- 设置web应用的全局错误页面 -->
<error-page>
<error-code>404</error-code>
<location>/error.jsp</location>
</error-page>
<error-page>
<error-code>500</error-code>
<location>/error2.jsp</location>
</error-page>
</web-app>
~~~
2)include指令
页面包含(静态包含)指令,可以将一个jsp页面包含到另一个jsp页面中
格式:<%@ include file="被包含的文件地址"%>
3)taglib指令
在jsp页面中引入标签库(jstl标签库、struts2标签库)
格式:<%@ taglib uri="标签库地址" prefix="前缀"%>
# jsp内置/隐式对象(9个)
jsp被翻译成servlet之后,service方法中有9个对象定义并初始化完毕,我们在jsp 脚本中可以直接使用这9个对象
在翻译后的servlet页面有这个
![](https://box.kancloud.cn/9d656e4530e07880bf13289bbe8b8a48_1174x550.png)
![](https://box.kancloud.cn/318cc183c79177bd3df6137eafe3d757_1212x470.jpg)
![](https://box.kancloud.cn/584e139d4afe7087ad4b74dd926692d7_1358x808.jpg)
exception是获取上个页面错误信息
~~~
<% exception.getMessage(); %>
~~~
(1)out对象
out的类型:JspWriter
out作用就是想客户端输出内容----out.write()
out缓冲区默认8kb 可以设置成0 代表关闭out缓冲区 内容直接写到response缓冲器
8k大小,是在page指令那buffer设置
tomcat默认会对response缓存区获取内容,最终都要写到response缓冲区
![](https://box.kancloud.cn/3df8bcdd9715799e3eb56947dfcacb3d_1173x538.png)
(2)pageContext对象
jsp页面的上下文对象,作用如下:
page对象与pageContext对象不是一回事
1)pageContext是一个域对象
~~~
setAttribute(String name,Object obj)
getAttribute(String name)
removeAttrbute(String name)
~~~
pageContext可以向指定的其他域中存取数据
~~~
setAttribute(String name,Object obj,int scope) //第三参数用 PageContext.XX 来获取
getAttribute(String name,int scope)
removeAttrbute(String name,int scope)
findAttribute(String name)
~~~
~~~
<body>
111 <!-- 然后是这个 -->
<% pageContext.setAttribute("1",2); %>
<% Object i = pageContext.getAttribute("1");
out.write(i.toString()); //第三是这个
response.getWriter().write("aaa");//先输出这个
%>
<%="ddddd" %><!-- 最后是这个 -->
</body>
~~~
**---依次从pageContext域,request域,session域,application域中获 取属性,在某个域中获取后将不在向后寻找**
**四大作用域的总结:
page域:当前jsp页面范围
request域:一次请求
session域:一次会话
application域:整个web应用**
2)**可以获得其他8大隐式对象**
~~~
例如: pageContext.getRequest()
pageContext.getSession()
~~~
# jsp标签(动作)
1)页面包含(动态包含):<jsp:include page="被包含的页面"/>
这是动态包含,静态包含还是不同文件,编译时运行,把他包含进去
静态包含是一个文件
2)请求转发:<jsp:forward page="要转发的资源" />
- 基础
- 编译和安装
- scanner类(键盘录入)
- Random类(随机数)
- 数组
- 方法
- 类
- ArrayList集合
- char与int
- eclipse
- IDEA
- 变量与常量
- 常用API
- String,StringBuffer,StringBuilder
- 正则,Date,DateFormat,Calendar
- 包装类,System,Math,Arrays,BigInteger,BigDecimal
- 集合,迭代器,增强for,泛型
- List,set,判断集合唯一
- map,Entry,HashMap,Collections
- 异常
- IO
- File
- 递归
- 字节流
- 字符流
- IO流分类
- 转换流
- 缓冲流
- 流的操作规律
- properties
- 序列化流与反序列化流
- 打印流
- commons-IO
- IO流总结
- 多线程
- 线程池
- 线程安全
- 线程同步
- 死锁
- lock接口
- ThreadLoad
- 等待唤醒机制
- 线程状态
- jdbc
- DBUtils
- 连接池DBCP
- c3p0连接池
- 网络编程
- 多线程socket上传图片
- 反射
- xml
- 设计模式
- 装饰器模式
- web service
- tomcat
- Servlet
- response
- request
- session和cookie
- JSP
- EL
- JSTL
- 事务
- 监听器Listener
- 过滤器Filter
- json
- linux安装软件
- 反射详解
- 类加载器和注解
- 动态代理
- jedis
- Hibernate
- 简介
- 创建映射文件
- Hibernate核心配置文件
- 事务和增删改查
- HibernateUtils
- 持久化对象的三种状态
- 检索方式
- query
- Criteria
- SQLQuery
- 持久化类
- 主键生成策略
- 缓存
- 事务管理
- 关系映射
- 注解
- 优化
- struts2
- 搭建
- 配置详解
- Action
- 结果跳转方式
- 访问ServletAPI方式
- 如何获得参数
- OGNL表达式
- valueStack 值栈
- Interceptor拦截器
- spring
- 导包
- IOC和DI
- Bean获取与实例化
- Bean属性注入
- spring注解
- 注解分层
- junit整合
- aop
- 动态代理实现
- cglib代理实现
- aop名词
- spring的aop
- aop-xml详解
- aop-注解详解
- 代理方式选择
- jdbcTemplate
- spring事务管理
- 回滚注意
- 事务传播属性
- MyBatis
- MyBatis简介
- 入门程序
- 与jdbc hibernate不同
- 原始Dao开发
- Mapper动态代理方式
- SqlMapConfig.xml配置文件
- 输入参数pojo包装类
- resultMap
- 动态sql
- 一对一关联
- 一对多
- 整合spring
- 逆向工程
- maven
- maven简介
- 仓库
- maven目录结构
- maven常用命令
- 生命周期
- eclipse中maven插件
- 入门程序
- 整合struct
- 依赖范围
- 添加插件
- idea配置
- jar包冲突
- 分模块开发
- 构建可执行的jar包(包含依赖jar包)
- springMVC
- 处理流程
- java面试
- java版本升级
- java1-8版本变更
- java9新特性
- 锁
- java资料
- idea
- jdk版本切换
- log4j
- 入门实例
- 基本使用方法
- Web中使用Log4j
- spring中使用log4j
- java代码优化