java程序员第十一课 javaweb之request&response
来源:互联网 发布:html5 淘汰桌面软件 编辑:程序博客网 时间:2024/05/17 08:05
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
- java程序员第十一课 javaweb之request&response
- java程序员第十课 javaweb之request&response
- JavaWeb之Request && Response篇
- javaweb之response、request对象
- Javaweb基础之response&request
- day08-JavaWeb之http协议request-response
- JavaWeb-request和response
- JavaWeb之Request对象和Response对象详解
- (javaweb读书笔记系列之三)request和response
- JavaWeb系列之七(response域与request)
- 重新学javaweb---Response&Request
- JavaWeb:Request和Response总结
- Java Web之四 Response Request
- java程序员第九课 javaweb之servlet
- javaweb之response细节
- javaWeb之response
- Javaweb核心之response
- JavaWeb-08 (JavaWeb-Servlet基础&java web之request/respone)
- 分享功能
- Unity3D自定义脚本模板
- Mysql初始化root密码和允许远程访问
- 【Leet Code】74. Search a 2D Matrix---Medium
- 【Android】从零开始
- java程序员第十一课 javaweb之request&response
- apache虚拟主机设置
- Javascript编程风格
- SSH端口转发(隧道)
- ios 剪裁图片
- 再谈单例模式
- (四)洞悉linux下的Netfilter&iptables:包过滤子系统iptable_filter
- 基于对话框MFC按Enter键或者Ese退出的解决方法
- android 显示隐藏密码