JSP Cookie

Cookie是存储在客户机的文本文件,它们保存了大量轨迹信息。在servlet技术基础上,JSP显然能够提供对HTTP cookie的支持。

通常有三个步骤来识别回头客:

●服务器脚本发送一系列cookie至浏览器。比如名字,年龄,ID号码等等。

●浏览器在本地机中存储这些信息,以备不时之需。

●当下一次浏览器发送任何请求至服务器时,它会同时将这些cookie信息发送给服务器,然后服务器使用这些信息来识别用户或者干些其它事情。

下面的代码将展示如何使用JSP来设置Cookie:

main.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.net.*" %>
<%
    //编码,解决中文乱码问题
    String str = URLEncoder.encode(request.getParameter("name"),"utf-8");
    //设置name和url cookie
    Cookie name = new Cookie("name",str);
    Cookie url = new Cookie("url",request.getParameter("url"));
    //设置cookie的时间
    name.setMaxAge(60*60*24);
    url.setMaxAge(60*60*24);
    //在响应的头部添加cookie
    response.addCookie(name);
    response.addCookie(url);
%>    
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>获取Cookie</title>
</head>
<body>
    <h1>获取到的Cookie</h1>
    <ul>
        <li><p><b>网站名:</b>
        <%= request.getParameter("name")%>
        </p></li>
        <li><p><b>网址:</b>
        <%= request.getParameter("url")%>
        </p></li>
</ul>
</body>
</html>

test.html

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Cookie</title>
</head>
<body>
    
    <form action="main.jsp" method=GET>
    站点名: <input type="text" name="name">
    <br />
    网址: <input type="text" name="url" />
    <input type="submit" value="提交" />
    </form>
</body>


</html>
图片.png

点击提交就能获取到我们之前所设置的name和url。

图片.png

下一个例子是关于JSP如何来读取Cookie的:

想要读取cookie,您就需要调用request.getCookies()方法来获得一个javax.servlet.http.Cookie对象的数组,然后遍历这个数组,使用getName()方法和getValue()方法来获取每一个cookie的名称和值。

cookie.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.net.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>读取Cookie</title>
</head>
<body>
<%
    //创建好cookie与cookies
    Cookie cookie = null;
    Cookie[] cookies = null;
    //获取cookies
    cookies = request.getCookies();
    //判断cookies是否为空
    if(cookies != null) {
        out.println("<h2>查找Cookie的名与值</h2>");
        //通过遍历cookies来一个个地获取我们所需要的cookie
        for(int i = 0; i<cookies.length; i++) {
            cookie = cookies[i];
            out.println("参数名:"+cookie.getName());
            out.println("<br>");
            out.println("参数值:"+URLDecoder.decode(cookie.getValue(),"utf-8")+"<br>");
            out.println("<br>");
        }
    } else {
        out.println("<h2>没有发现Cookie</h2>");
    }
%>
</body>
</html>

运行的结果如下:

图片.png

如何使用JSP删除Cookie:

1、首先要获取一个已经存在的cookie。
2、将cookie的有效期设置为0,使用cookie.setMaxAge()方法,方法里面的参数为0。
3、将这个cookie重新添加进响应头中。

在原来的获取cookie的代码后面(即cookie = cookies[i])加上这几句代码:

if((cookie.getName()).compareTo("name") == 0) {
                cookie.setMaxAge(0);
                response.addCookie(cookie);
                out.println("删除cookie:" + cookie.getName() + "<br>");
            }

第一次运行:

图片.png

第二次运行:

图片.png

可以看到第二次运行过后我们想要删除的名称为"name"的cookie被成功地给删除了。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 本文目录: JSP基础 Cookie HttpSession JSP基础 JSP(Java Server Page...
    极客圈阅读 584评论 0 3
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,727评论 11 349
  • 从去年年初,我报了硬笔书法的线下课。学习了快两年的硬笔书法。但是发现我的字依然写得那么丑。两年养成的每天必须练字半...
    小鱼在变好阅读 192评论 0 0
  • 今天到学校去拿快递,一个月不见,校园里树木长得更茂盛了,晚归的鸟儿叽叽喳喳的在树上闹着,走在学校的林荫大...
    甜蜜荔枝阅读 546评论 0 3
  • 阅读进度:第二部分Chapter 1-2 @ 2017/3/28 这两部分看得还是比较爽的,遇到爱情,总是比较容易...
    冰洛洛阅读 265评论 0 0

友情链接更多精彩内容