JSP之Session,Cookie对象用法介绍

35 篇文章 1 订阅
34 篇文章 0 订阅

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页面登录并记录中文名字账号密码的代码上传作为例子,里面用了之前学的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");
          }
      }
  }
%>
<html>
  <head>
    <title>Cookie测试</title>
  </head>
  <body>
    <h1>Cookie测试</h1>
    <form action="judge.jsp" method="post">
      <table>
        <tr>
          <td>姓名:</td><td><input type="text" name="name" value="<%=name%>"/></td>
        </tr>
        <tr>
          <td>密码:</td><td><input type="password" name="password" value="<%=password%>"></td>
        </tr>
        <tr >
          <td colspan="2"><input type="submit" value="登录"/></td>
        </tr>
      </table>
    </form>
  </body>
</html>

判断页judge.jsp:

<%@ page contentType="text/html;charset=UTF-8" language="java" import="java.util.*" %>
<%@ page import="java.net.URLEncoder" %>
<%
    request.setCharacterEncoding("UTF-8");
%>
<html>
<head>
    <title>judge</title>
</head>
<body>
    <h1>judge</h1>
    <jsp:useBean id="temp" scope="page" class="tool.res"/>
    <jsp:setProperty name="temp" property="*"/>
        <p>姓名:<jsp:getProperty name="temp" property="name"/></p>
        <p>密码:<jsp:getProperty name="temp" property="password"/></p>
    <%
        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);
    %>
</body>
</html>
然后是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;
    }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值