目录
- 基本概念
- JSP九大内置对象(重点)
- 九大内置对象中四种范围对象(小到大)
基本概念
- 在eclipse中创建的web项目:
- 浏览器可以直接访问WebContent中的文件
- 但是WEB-INF中的文件无法通过客户端(浏览器)直接访问,只能通过请求转发来访问
注意:并不是任何内部的跳转都都能访问WEB-INF,跳转有请求转发和重定向两种方式
- 配置Tomcat运行时环境
jsp<->servlet
- 将Tomcat/lib中的servlet-api.jar加入项目的构建路径
- 右键项目->build path ->add library ->server runtime
- 部署Tomcat
- 在servers面板,新建一个Tomcat实例,再在该实例中部署
- 注意:一般建议将eclipse中的tomcat与本地Tomcat中的信息保持一致;第一次创建完设置托管模式;否则以后就变灰了,不能改
- 统一字符集编码
设置jsp文件的编码(jsp中的pageEncoding属性):jsp->java设置浏览器读取jsp文件的编码(jsp文件中content属性)
一般讲上述设置成统一码,推荐使用国际码utf-8
文本编码:
- 将整个eclipse中的以后文件统一设置
- 设置一个项目
- 设置单独文件
- jsp的页面元素:HTML,Java代码(脚本scriptlet),指令
- 脚本scriptlet
//1<%
局部变量、Java语句
%>
//2
<%!
全局变量、定义方法
%>
//3
<%= 输出表达式 %>
一般而言,修改web.xml需要重启tomcat,修改jsp不需要注意:out.println()不会回车,需要添加HTML的换行符,out.println()中可以识别html代码
- 指令
- page指令
<%@page .....%>
- page指令的属性:
- language:jsp页面使用的脚本语言
- import:导入类
- pageEncoding:jsp文件自身编码 jsp->java
- contentType:浏览器解析jsp的编码
<%@ page language="java" contentType="text/html; charset=utf-8"pageEncoding="utf-8"%>
- 注释
- html注释 网页源代码里边可以显示
- java注释// /.../
- jsp注释<%-- jsp注释 --%>
JSP九大内置对象(重点)
- jsp九大内置对象(重点)(自带的,不需要new也能使用的对象)
- out:输出对象,向客户端输出内容
- request:(封装请求信息)请求对象;存储"客户端向服务端发送的请求信息"(数据只在同一次请求有效)
- 常见方法:
- String getParameter(String name):根据请求的字段名key,返回字段值value;
- String[] getParameterValues(String name):根据请求的字段名key,返回多个字段值value(checkbox);
- void setCharacterEncoding("编码格式utf-8"):具体设置post请求编码(tomcat默认编码iso-8859-1);
- getRequestDispatcher("b.jsp").forward(request,response): 请求转发的方式跳转页面 A->B
- ServletContext getServerContext():获取项目的ServletContext对象
- 示例:
- 注册
- 注册页register.jsp 展示页show.jsp
- 访问url含义
- localhost:8080/MyJspProject/show.jsp?uname=aa&upwd=wer&uage=12
- 连接/文件?参数名1=参数值1&参数名2=参数值2&参数名3=参数值3
- 统一请求的编码request
- get方式 如果出现乱码解决方式:
- 统一每一个变量的编码(不推荐)
- 变量名=new String(变量名.getBytes("iso-8859-1"),"utf-8");
- 每个变量改一次
- 修改server.xml一劳永逸
- 建议使用Tomcat时,首先在server.xml中统一编码方式 URIEncoding="UTF-8"
- post方式
- request.setCharacterEncoding("utf-8");
- get提交方式:method="get"和地址栏、超链接请求方式默认都属于get提交方式
- get与post请求方式的区别:
- get方式在地址栏显示请求信息(但是地址栏容纳信息有限,4-5kb,如果请求数据存在大文件,图片,存储不下会报错),post不会显示
- 文件上传操作,必须是post
- 推荐使用:post
- response:(响应信息)响应对象
- 提供的方法:
- void addCookie(Cookie cookie):服务端向客户端增加cookie对象
- void sendRedirect(String location)throws IOException:页面跳转的一种方式
- void setContentType(String type):设置服务端响应的编码(设置服务端的contentType类型)
- 示例:登录
- login.jsp登录->check.jsp判断->success.jsp
- 请求转发和重定向的区别:
- 地址栏改变:不变,变
- 是否保留第一次请求时的数据:保留,不保留(跳到success.jsp拿不到数据) --4种范围对象
- 请求的次数:1次(请求转发的跳转是在服务器内部跳转),2次
- 跳转发生的位置:服务器端,客户端
- 转发、重定向:
- 转发: 张三(客户端)->【服务窗口A->服务窗口B】
- 重定向: 张三(客户端)->【服务窗口A】->张三(客户端)->【服务窗口B】
- session(存在于服务端)
- Cookie
- Cookie(存在于客户端,不是内置对象,得new):
- Cookie是有服务端生成的,再发送给客户端保存;
- Cookie相当于本地缓存的作用:客户端->服务端
- 作用:提高访问服务端的效率,但是安全性较差
- Cookie:name-value
- javax.servlet.http.Cookie类产生的 public Cookie(String name,String value)
- String getName():获取name
- String getValue():获取value
- void setMaxAge(int expiry):设置最大有效期(秒)
- 服务端准备Cookie:
- response.addCookie(Cookie cookie)
- 页面跳转(转发,重定向)
- 客户端获取Cookie:
- request.getCookies(); //获取Cookie必须每次都是获取全部
- 注意:
- 服务端增加cookie:response对象
客户端获取对象:request对象
- 不能直接获取单独对象,只能一次性将全部cookie得到
除了自己设置的Cookie对象外,还有一个name叫JSESSIONIDDE的cookie
- 使用Cookie实现自动记住用户名 //建议cookie只保存英文数字,否则要编解码
- session:会话
- 浏览网站:开始-关闭
- 购物:浏览-付款-退出
- 电子邮件:浏览-写邮件-退出 一次开始到关闭
- session机制
- 客户端第一次请求服务端
- 客户端第一次请求服务端时,(jsessionid-sessionid)服务端会产生一个session对象(用于保存该客户的信息),并且每个session对象都会有唯一的sessionId(用于区分其他session);
- 服务端会产生一个cookie,并且该cookie的name=JSESSIONID,value=服务端sessionId的值;
- 然后,服务端会在响应客户端的同时,将该cookie发送给客户端,至此 客户端就有一个cookie(JSESSIONID)
- 因此,客户端的cookie就可以和服务端的session一一对应(JSESSIONID-SESSIONID)
- 客户端第二次/n次访问服务端
- 客户端第二次/n次访问服务端时:服务端会先用客户端cooki中的JSESSIONID去服务端session中匹配sessionId,若匹配到,则说明不是第一次访问
- 例子:
- 客户端:顾客
- 服务端:存包处
顾客第一次存包:商场判断此人是不是之前已经存过包(是否有钥匙),如果新顾客(没钥匙),分配一个钥匙;
第二次/n次,如果手里有钥匙,直接一一对应,不分配
- session:
- session存储在服务端
- session是在同一个用户请求时共享
- session实现机制:第一次客户请求时产生一个sessionid并复制给jsessionid然后发给客户端.最终实现sessionid与jsessionid一一对应
- session方法
- String getId():获取sessionId
- boolean isNew():判断是否是新用户(第一次访问)
- void invalidate():使session失效(退出登录、注销)
- void setAttribute():
- Object getAttribute():
- void setMaxInactiveInterval(秒):设置最大有效非活动时间
- int getMaxInactiveInterval(秒):获取最大有效非活动时间
- 示例:
- 登录
- JSESSIONID5B3D4AA49AB91B1311F514BCF727DD29
- sessionId5B3D4AA49AB91B1311F514BCF727DD29
- 客户端在第一次请求服务端时,如果服务端发现此请求没有JSESSIONID,则会创建一个name=JSESSIONID的cookie并返回给客户端
- Cookie
- 不是内置对象,要使用必须new
- 但是,服务端会自动new一个Jsessionid的cookie
- cookie和session的区别:
- 位置分为:客户端和服务端
- 安全为:不安全和较安全
- 保存的内容:Object和字符串String
- application:全局对象
- String getContextPath():虚拟路径
- String getRealPath(String name):绝对路径(虚拟路径,相对的的绝对路径)
- pageContext:JSP页面容器
- config:配置对象
- page:当前JSP页面对象(相当于JAVA中的this)
- exception:异常对象
九大内置对象中四种范围对象(小到大)
- pageContext(也可称为page对象):当前页面有效,页面跳转后无效
- request:同一次请求有效,其他请求无效(请求转发后有效,重定向后无效)
- session:同一次会话有效(无论怎么跳转都有效,只要不关/切换浏览器)
- application:全局有效(整个项目有效):整个项目运行期间都有效,切换浏览器也有效,关闭服务或者切换项目无效
- 以上四种对象的共有的方法:
- Object getAttribute(String name):根据属性名,获取属性值
- void setAttribute(String name,Object obj):设置属性值(新增,修改)
- setAttribute("a","b");//如果a对象之前不存在,则新建一个a对象; 如果a之前已经存在,则将a的值改为b
- void removeAttribute(String name):根据属性名,删除对象 //set赋值,get取值,尽量使用小范围,性能损耗小