美文网首页
请求响应与会话相关内容

请求响应与会话相关内容

作者: IT_lz | 来源:发表于2019-06-06 15:08 被阅读0次

    一、HttpServletResponse对象

    1、发送状态码相关的方法

    • setStatus() 设置响应状态码, 默认为200
    • sendError() 设置响应错误码

    2、发送响应消息头的相关方法

    下面为设置响应头信息的一些方法

    • addHeader()
    • setHeader()
    • setIntHeader()
    • addIntHeader()

    下面是设置字符编码的一些方法,主要用于防止乱码现象发生。

    • setContentType()
    • setLocale()
    • setCharactorEncoding()

    上述三个编码方法,setCharactorEncoding()优先级最高。如果没有设置Content-Type头字段,则setCharactorEncoding设置的字符编码不会出现在Content-Type字段中。

    在解决中文乱码时,可以使用两种方法:

    • Response.setCharactorEncoding("utf-8");

    Response.setHeader("Content-Type", "text/html;charset=utf-8");

    • Response.setContentType("text/html;charset=utf-8");

    二、RequestDispatcher接口

    如果服务器通知另外一个资源去处理请求,可以使用sendRedirect()之外,还可以使用

    RequestDispatcher接口来处理。RequestDispatcher接口包含两个方法,forward()请求转发、include()请求包含。

    1、请求转发forward()

    当前servlet可通过forward()方法将请求转发给其他servlet,其他servlet处理完请求后,直接将响应结果传递给客户端。

    2、请求包含include()

    将servlet请求转发给其他web资源,与请求转发不同的是,在请求包含的响应信息中,既包含了当前servlet的响应信息,还包含其他web资源返回的响应信息。

    三、Cookie

    1、Cookie

    存储在客户端本地,用于后台区分用户。

    Set-Cookie: user=liu; Path=/;

    user代表Cookie名称

    Path表示Cookie属性

    2、Cookie Api

    • setMaxAge() 和 getMaxAge()

      设置和返回Cookie在浏览器保存的时间,默认设置为-1

      保存时间分为:

      正数(即Cookie保存在本地,在没有超过时间之前都是有效的。)

      负数(即Cookie保存在浏览器内存中,浏览器关闭则删除。)

      0(即通知浏览器立即删除这些Cookie信息。)

    • setPath() 和 getPath()

      若没设置Path属性,则Cookie只对当前访问路径所属目录和子目录有效。若想让所有目录都有效,则可以将Path属性设置为"/"。

    • setDomain 和 getDomain

      domain属性是设置浏览器访问的域。如果访问的地址在这个域中,则带上Cookie。

    四、Session

    Session是一种将会话数据保存在服务器端的技术。

    1、HttpSession Api

    • getSession() 和 getSession(boolean create) 必须在发送响应之前调用

      两者都会返回与当前请求相关的HttpSession对象。

      getSession(boolean create): 如果参数为true,则在HttpSession不存在的情况下,创建新的HttpSession。否则不创建新的HttpSession,直接返回null。

      getSession():相当于getSession(true)

    • setAttribute()、removeAttribute() 和 getAttribute()

      存储、移除、获取参数到HttpSession对象。

    • invalidate()强制将Session失效

    2、Session超时管理

    由于服务器不清楚客户端浏览器何时不访问,如果长期保留Session,会使得服务器内存耗尽。所以需要给Session设置超时时间。Tomcat默认超时时间是30分钟。如果session-timeout设置为0或者负数,则Session永不超时。

    <session-config>
       <session-timeout>30</session-timeout>
    </session-config>
    

    使Session超时的方法:1、等待超时时间 2、调用invalidate()强制其失效

    相关文章

      网友评论

          本文标题:请求响应与会话相关内容

          本文链接:https://www.haomeiwen.com/subject/qicuxctx.html