JSP之Session,Cookie对象用法介绍

HTTP是无状态协议,这意味着每次客户端检索网页时,都要单独打开一个服务器连接,因此服务器不会记录下先前客户端请求的任何信息。

因为这个原因于是就有了Cookie和Session。

Session对象:

session对象是一个JSP内置对象。

session对象在第一个JSP页面被装载时自动创建,完成会话期管理。

从客户端打开浏览器并连接到服务器开始,到客户端关闭浏览器离开这个服务器结束,被称为一个会话。

当一个客户访问一个服务器,可能会在服务器的几个页面之间切换,服务器应当通过某种办法知道这是一个客户,就需要session对象。

session对象常用方法:

String getId()返回session对象的ID

void invalidate()将session无效化,解绑任何与该session绑定的对象

void setAttribute(String name, Object value) 使用指定的名称和值来产生一个对象并绑定到session中

Object getAttribute(String name)返回session对象中与指定名称绑定的对象,如果不存在则返回null,注意返回的是object对象,用的时候要强制转化

void removeAttribute(String name)移除session中指定名称的对象

public void setMaxInactiveInterval(int interval)用来指定时间,以秒为单位,servlet容器将会在这段时间内保持会话有效

int getMaxInactiveInterval()返回最大时间间隔,以秒为单位,servlet 容器将会在这段时间内保持会话打开

Cookie对象也是在web开发中常用的一个对象,他是储存在客户端的一个文本文件,用于记录一些服务器和客户端交互的信息,比如浏览记录,设置一个期限自动保存姓名密码什么的都是通过这个对象来处理,实现原理其实是一个map也就是键值对的形式

Cookie对象的常用方法:

Cookie cookie = new Cookie(String key, String value) 创建一个新的Cookie对象

response.addCookie(cooke)写入Cookie对象

Cookie[] cookies = request.getCookies()读取Cookie对象,这里得到的是一个Cookie数组

void setMaxAge(int expiry)设置Cookie有效期,以秒为单位

void setValue(String value)Cookie创建后,对Cookie进行赋值

String getName()获取Cookie名称

String getValue()获取Cookie的值

int getMaxAge()获取Cookie的有效时间,以秒为单位,删除一个Cookie的方法也是将有效时间设为0再用上面的response的addCookie方法

不过注意Cookie是用的Ascii码,所以对于中文字符要进行特殊的编码和解码,不然会导致页面出错和乱码

对于请求的编码:

request.setCharacterEncoding("UTF-8");

然后下面两个函数是属于java.net包下的记得导入

编码要加入信息的中文字符:String  str=URLEncoder.encode("中文","UTF-8");

从Cookie中提取出的中文字符要解码:String  str=URLDecoder.decode("编码后的字符串","UTF-8");

Cookie和Session的不同也是面试常考话题,然后我保存了一张慕课网的图:

JSP之Session,Cookie对象用法介绍_第1张图片

看的可能有点懵我把我刚刚测试的jsp页面登录并记录中文名字账号密码的代码上传作为例子,里面用了之前学的JavaBean相结合,这也是web开发的日常操作:

主页index.jsp:

<%--
  Created by IntelliJ IDEA.
  User: hjy
  Date: 2018/1/1
  Time: 15:55
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" import="java.net.*,java.util.*" %>
<%
  request.setCharacterEncoding("UTF-8");
  Cookie cookies[]=null;
  cookies=request.getCookies();
  String name="";
  String password="";
  if(cookies!=null)
  {
      for(Cookie c:cookies)
      {
          String s=c.getName();
          if("name".equals(s))
          {
              name= URLDecoder.decode((String)c.getValue(),"UTF-8");
          }
          if("password".equals(s))
          {
              password=URLDecoder.decode((String)c.getValue(),"UTF-8");
          }
      }
  }
%>

  
    Cookie测试
  
  
    

Cookie测试

姓名:
密码:

判断页judge.jsp:

<%@ page contentType="text/html;charset=UTF-8" language="java" import="java.util.*" %>
<%@ page import="java.net.URLEncoder" %>
<%
    request.setCharacterEncoding("UTF-8");
%>


    judge


    

judge

姓名:

密码:

<% String name= URLEncoder.encode(temp.getName(),"UTF-8"); String password= URLEncoder.encode(temp.getPassword(),"UTF-8"); Cookie c1=new Cookie("name",name); c1.setMaxAge(60*20); response.addCookie(c1); Cookie c2=new Cookie("password",password); c2.setMaxAge(60*20); response.addCookie(c2); %>
然后是javabean的res.java:

package tool;
public class res {
    private String name;
    private String password;
    public res()
    {
    }
    public void setName(String n)
    {
        name=n;
    }
    public String getName()
    {
        return name;
    }
    public void setPassword(String p)
    {
        password=p;
    }
    public String getPassword()
    {
        return password;
    }
}

你可能感兴趣的:(WEB,Java学习,日志)