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

0 0
原创粉丝点击