java程序员第十一课 javaweb之request&response
1、上节内容回顾
1、Response的简介
http响应里面
** 响应行
- setStatus()
** 响应头
- setHeader()
- addHeader()
- 针对特殊类型设置头
** 响应体
- 页面显示的内容
- 字节流
- 字符流
2、案例一:使用Response实现登录重定向
3、案例二:使用Response实现页面定时刷新
4、案例三:使用Response实现禁用浏览器缓存
5、Response向页面输出中文乱码解决(字节流和字符流)
(1) 使用字节流输出中文乱码问题
- 设置浏览器编码
- 设置字节数组的编码
(2) 使用字符流输出中文乱码问题
- 设置缓冲区的编码
- 设置浏览器编码
- 简写方式 setContentType("text/html;charset=utf-8")
(3) 几点注意的问题
* 字节流和字符流互斥
* 不能直接向页面输出数字
7、案例四(**):使用Response实现文件的下载(两种方式)
- 使用头:Content-Disposition: 无论什么格式的文件,浏览器都是以下载方式打开
8、案例五(**):使用Response实现验证码的开发
(1)Response验证码的编写
(2)Response实现中文验证码
9、Request获得客户机信息和请求头信息
- getHeader方法获取请求头信息
10、Request获取提交的数据
* getParameter("输入项里面name的值")
* getParameterValues();类似复选框
* getParameterMap():获取所有输入项name名称和输入的值
* getParameterNames()
11、Request获取提交的中文数据乱码解决
(1) post请求中文乱码解决
- 设置request缓冲区的编码
(2) get请求中文乱码解决
- 三种方式
new String("".getBytes("iso8859-1"),"utf-8");
12、重定向和转发的区别
(1) request域
- 域:在一定的范围内,存取数据
* servletContext域:web域
* request域:一次请求
(2) 重定向和转发
13、案例六:使用转发重写登录案例
- ${msg}
1、jsp入门
* sun公司提供了两种开发动态网站的技术 servlet jsp
* 使用servlet向页面输出内容(html) getWriter().println()
* jsp就是servlet,最终也会被编译成servlet
* java server pages:java服务器端页面
** html+java代码+标签(el表达式)
* jsp的执行过程:执行jsp时候会编译成servlet
* 在jsp里面如何嵌入java代码
- 三种方式
** <%! %>
- 定义的变量是成员变量
** <%= %>
- 可以向页面输出内容,代码生成在service方法里面
- 生成这样的一段代码 out.print("hello" );
- <%="hello" %>
** <% %>
- 也会生成到service方法里面
- *** 不能定义方法
- 写java代码
- <%
for(int i=0;i<5;i++) {
}
%>
* 实际开发中,把html代码和java代码混合使用
- 在jsp页面里面输出一个 5行 5列的表格
- <table border="1">
<!-- 循环行 tr-->
<%
for(int i=1;i<=5;i++) {
%>
<tr>
<!-- 循环列 td -->
<%
for(int j=1;j<=5;j++) {
%>
<td>hello</td>
<%
}
%>
</tr>
<%
}
%>
</table>
2、el的入门
* 表达式:获取域对象里面的值
** servletContext
** request
* 语法:${域对象里面名称}
* <!-- 向request域里面设置值 -->
<%
request.setAttribute("msg", "itcast1");
getServletContext().setAttribute("msg", "itcast2");
%>
<!-- 使用传统方式获取 -->
<%=request.getAttribute("msg1") %>
<%-- <%=getServletContext().getAttribute("msg") %> --%>
<!--
通过传统方式获取域对象里面的值,如果名称不存在,得到值 null
会出现空指针异常
-->
<hr/>
<!-- 使用el表达式获取 -->
<!-- 如何域值名称相同,通过el表达式获取是域范围小的那个里面的值 -->
<!-- ${requestScope.msg}
${applicationScope.msg}-->
${msg1}
<!--
通过el表达式的方式获取域对象里面的值,如果名称不存在,得到值 "" 空字符串
不会出现空指针异常
-->
3、会话管理
* 什么是会话管理:打开浏览器,进行网页的浏览,到关闭浏览器的过程。
* 会话管理做什么事情?
** 画图分析:
* servletContext域是否可以存储购物信息?
- 不能存储购物信息
- 谁先结算,把servletContext里面的所有商品都结算
* request域是否可以存储购物信息?
- 不能存储购物信息
- request域是一次请求有效,没有任何的购物信息
* 会话管理有两个技术 cookie和session
*** 画图分析使用cookie和session如何存储购物信息?
** cookie:客户端的技术
- 发送一个请求,服务器会把购买的东西返回到浏览器的内容中(cookie)
- 发送第二次请求,会带着第一次返回到浏览器的购物信息,把新购买的商品和之前的商品一起返回到浏览器的内存中
** session:服务器端的技术
- 发送一个请求,服务器会分配一个空间,把购物信息放到空间里面,同时返回一个可以打开这个空间的唯一key(钥匙)
- 发送第二次请求,带着这个key发送请求,使用这个钥匙打开服务器空间,把新的购物信息放入到空间里面,返回可以打开这个空间的唯一key(钥匙)。
4、案例一:使用cookie记录用户上次访问时间
** 画图分析实现步骤
** 方法:
1、获取cookie: request里面:Cookie[] getCookies()
2、回写cookie: response里面:addCookie(Cookie cookie)
3、创建cookie对象: 构造方法,Cookie(java.lang.String name, java.lang.String value)
** 步骤:
* 1、得到cookie
* 2、判断是否是第一次访问 lastVisit
* ** 如果是第一次访问,直接页面输出欢迎信息
* - 同时获取当前时间,把时间回写到浏览器
* ** 如果不是第一次,显示上次访问时间
* - 同时获取当前时间,把时间回写到浏览器
*/
5、cookie的API的查看
**方法:
- 构造方法:Cookie(java.lang.String name, java.lang.String value)
- 获取cookie的名称:getName()
- 获取cookie的值:getValue()
*** 更常用的方法
- setMaxAge(int expiry):设置cookie的有效时长 int expiry: 秒 60*60
** 适用于持久化的cookie
- setPath(java.lang.String uri) :设置cookie的有效路径
- setDomain(java.lang.String pattern):设置有效域名
** cookie的分类
分为两类:
1、会话级别的cookie
* 关闭浏览器之后,cookie销毁了。默认情况下,是会话级别
2、持久化的cookie
* 设置一个有效时长 使用 setMaxAge(秒)
* 可以手动销毁cookie 销毁之前路径必须要一致
*** 创建一个和要销毁的cookie相同名称的cookie
Cookie cookieTime = new Cookie("lastVisit","");
setMaxAge(0);
setPath("/");
response.addCookie(cookieTime);
* 设置有效路径 setPath("/")
** 有效路径(持久化的cookie)
* 设置 setPath("/day11"):访问路径带/day11,会携带cookie信息
比如1:
http://127.0.0.1/day11/aa
http://127.0.0.1/day12/bb
比如2:
setPath("/day11/cc")
http://127.0.0.1/day11/cc
http://127.0.0.1/day11/dd
* 技巧:setPath("/")
** 设置有效域名
比如:
http://www.sina.com
http://sport.sina.com
http://music.sina.com
setDomain(".sina.com"); 只有地址栏请求地址包含这个信息,都会携带cookie信息
**cookie开发的细节
1、一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。
2、一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
******
3、浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
4、如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),
用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。
5、删除持久cookie,可以将cookie最大时效设为0,注意,删除cookie时,path必须一致,否则不会删除
6、案例二:使用cookie记录用户浏览的商品
* /*
* 1、得到商品的id
* 2、判断是否第一次浏览 his
* * 如果是第一次浏览,直接把信息放入到cookie里面
* * 如果不是第一次,
* - 首先判断,cookie是否存在前一次访问商品名称 his : 1
* - 如果没有存在,his : 1,2 在前一次cookie之后做一个追加操作
*/
** 清空浏览器记录操作(清空cookie)
1、创建一个和要删除的cookie名称相同的cookie
2、设置一个相同path
3、设置有效时间是0
4、回写到浏览器
5、回到商品页面
7、session简介
** session是服务器端技术,生成一个key(唯一的打开的空间)返回浏览器的内存中(使用cookie技术实现返回到浏览器的内存中)
- 回写的key称为:jsessionid=key的值
** session如何创建
request.getSession() 方法可以创建session
- 第一次访问request.getSession()创建session
** 创建一个servlet,执行 request.getSession(),查看一下id值
8、案例三:使用session实现购物车功能
* 实现步骤:
· /**
* 1、获取到id
* 2、得到商品名称 创建一个数组
*
* 3、判断是否是第一次购物 (得到session,是否为空)
- Map