Cookie用法简介
java操作Cookie---javax.servlet.http.Cookie
1.增加一个Cookie
Cookie cookie = new Cookie("username","zhangsan");
cookie.setPath("/");
cookie.setMaxAge(7*24*3600);//设置生存期7天
response.addCookie(cookie);
2.读取Cookie
String username="";
Cookie[] cookies = request.getCookies();
for (Cookie cookie : cookies){
if (cookie.getName().equals("username")){
username = cookie.getValue();
}
}
3.删除Cookie
Cookie cookie = new Cookie("username",null);
cookie.setPath("/");
cookie.setMaxAge(0);
response.addCookie(cookie);
为了方便操作,将其封装进CookieUtil类中,如下:
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class CookieUtil {
/**
* 增加一个Cookie
*/
public static void addCookie(HttpServletResponse response,String name,String value,int maxAge){
Cookie cookie = new Cookie(name,value);
cookie.setPath("/");
if (maxAge>0){
cookie.setMaxAge(maxAge);
}
response.addCookie(cookie);
} /**
* 根据name获取Cookie的value值
*/
public static String getCookieValue(HttpServletRequest request,String name){
Cookie[] cookies = request.getCookies();
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)){
return cookie.getValue();
}
}
return null;
} /**
* 根据name获取Cookie
*/
public static Cookie getCookieByName(HttpServletRequest request,String name){
Cookie[] cookies = request.getCookies();
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)){
return cookie;
}
}
return null;
} /**
*删除Cookie
*/
public static void clear(HttpServletResponse response,String name){
addCookie(response,name,null,0);
} }
此时再进行操作就很方便了:
1.增加一个Cookie
CookieUtil.addCookie(response,"username","zhangsan",7*24*3600);
2.读取Cookie
String username = CookieUtil.getCookieValue(request,"username");
3.删除Cookie
CookieUtil.clear(response,"username");
jQuery操作Cookie---jquery.cookie.js
在jQuery中,引入Cookie插件后,可以很方便地定义某个cookie名称,并设置cookie值。
所需js文件:jquery-1.11.3.js 和 jquery.cookie.js
在导入cookie插件后,可以通过一个全局性的方法管理客户端的cookie对象,格式如下:
$.cookie(名称, 值, [option])
如果是写入或设置cookie值,其调用的格式如下:
$.cookie(cookieName, cookieValue)
如果是读取cookie值,其调用的格式如下:
$.cookie(cookieName)
如果是销毁cookie值,其调用的格式如下:
$.cookie(cookieName, null)
在方法$.cookie()中,可选项参数[option]以对象的形式展示,用于补充说明设置的cookie对象,其常用的属性如下:
$.cookie(cookieName, cookieValue, {
expires: //有限日期,可以是一个整数或一个日期(单位:天)
path: //cookie值被保存的路径,默认值与创建页路径一致
domain: //cookie域名属性,默认值与创建页域名一样
secure: //一个布尔值,表示传输cookie值时,是否需要一个安全协议
})
请看如下示例:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>cookie插件</title>
<script type="text/javascript" src="js/jquery-1.11.3.js"></script>
<script type="text/javascript" src="js/jquery.cookie.js"></script>
<style type="text/css">
body{font-size:13px}
.divFrame{width:260px;border:solid 1px #666}
.divFrame .divTitle{padding:5px;background-color:#eee;font-weight:bold}
.divFrame .divContent{padding:8px;line-height:1.6em}
.divFrame .divBtn,#divData{padding-bottom:8px;padding-left:8px}
.txt{border:#666 1px solid;padding:2px;width:150px;margin-right:3px}
.btn {border:#666 1px solid;padding:2px;width:80px;
filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#ffffff, EndColorStr=#ECE9D8);}
</style>
<script type="text/javascript">
$(function() {
if ($.cookie("UserName")!="null") { //如果有值,则显示在文本框中
$("#UserName").val($.cookie("UserName"));
$("#UserPass").val($.cookie("UserPass"));
}
$("#sbtUser").click(function() { //表单提交事件
if ($("#chkSave").prop("checked")) { //如果选中了保存"用户名"项
$.cookie("UserName", $("#UserName").val(), {path: "/", expires: 7} )//设置Cookie值,有效期为7天
$.cookie("UserPass", $("#UserPass").val(), {path: "/", expires: 7} )
}else {
$.cookie("UserName", null, {path: "/"})//销毁Cookie值
$.cookie("UserPass", null, {path: "/"})
}
// return false; //表单不提交
})
})
</script>
</head>
<body>
<form method="post" action="login.do">
<div class="divFrame">
<div class="divTitle">用户登录</div>
<div class="divContent">
<div>用户名:<br /><input id="UserName" name="UserName" type="text" class="txt" /></div>
<div>密码:<br /><input id="UserPass" name="UserPass" type="password" class="txt" /></div>
<div><input id="chkSave" type="checkbox" checked />记住我</div><%--默认为选中--%>
</div>
<div class="divBtn">
<input id="sbtUser" type="submit" value="提交" class="btn" />
</div>
</div>
</form>
</body>
</html>
代码执行后的效果如下:

左图为首次登陆的界面,右图为下次登陆的页面
Cookie用法简介的更多相关文章
- Apache自带压力测试工具ab用法简介
ab命令原理 ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL进行访问.它的测试目标是基于URL的,因此,既可以用来测试Apache的负载压力,也可以测试nginx.lighthttp ...
- Postman用法简介
转自:http://blog.csdn.net/flowerspring/article/details/52774399 Postman用法简介 转载 2016年10月10日 09:04:10 10 ...
- IOS NSInvocation用法简介
IOS NSInvocation用法简介 2012-10-25 19:59 来源:博客园 作者:csj007523 字号:T|T [摘要]在 iOS中可以直接调用某个对象的消息方式有两种,其中一种就是 ...
- jquery cookie 用法
jquery cookie 用法 $.cookie("name","value","options") 当不设置options时,此coo ...
- JodaTime用法简介
JodaTime用法简介 Java的Date和Calendar用起来简直就是灾难,跟C#的DateTime差距太明显了,幸好有JodaTime 本文简单罗列JodaTime的用法 package co ...
- jquery.cookie用法详细解析,封装的操作cookie的库有jquery.cookie.js
jquery.cookie用法详细解析 需要注意存入cookie前,对数据进行序列化, 得到后在反序列化: 熟练运用:JSON.stringify();和JSON.parse(): 通常分为如下几个步 ...
- golang 的 http cookie 用法
golang的http cookie用法 在服务端程序开发的过程中,cookie经常被用于验证用户登录.golang 的 net/http 包中自带 http cookie的定义,下面就来讲一下coo ...
- MSSQL Sql加密函数 hashbytes 用法简介
转自:http://www.maomao365.com/?p=4732 一.mssql sql hashbytes 函数简介 hashbytes函数功能为:返回一个字符,通过 MD2.MD4.MD5. ...
- java assert的用法简介【转】
assert的基本用法 assertion(断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制,如C,C++和Eiffel等,但是支持的形式不尽相同,有的是通过语言本身.有的是通过库 ...
随机推荐
- 实战Jquery(二)--能够编辑的表格
今天实现的是一个表格的样例,通过获取表格的奇数行,设置背景色属性,使得奇偶行背景色不同.这个表格能够在单击时编辑,回车即更改为新输入的内容;ESC还原最初的文本.表格的实现思路非常清晰,仅仅是在实现的 ...
- PhpMyAdmin 配置文件现在需要一个短语密码的解决方法
新版本的PhpMyAdmin 增强了安全性,需要在配置文件设置一个短语密码.否则进入之后会有“配置文件现在需要一个短语密码.”的红色警叹提示. 解决方法: 1.将 phpMyAdmin/librari ...
- linux无密登录
ssh-keygen -t rsa ssh-copy-id -i ~/.ssh/id_rsa.pub bigdata@cor2
- Mustache(2)
Web 模板引擎是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,通常是标准的 HTML 文档.当然不同的开发语言有不同模板引擎,如 Javascript 下的 Hogan . ...
- python资源网站
whl安装包资源网站:http://www.lfd.uci.edu/~gohlke/pythonlibs/#scipy
- urllib基本使用-Handler和自定义的opener()
""" 基本的urlopen()方法不支持代理.cookie等其他的HTTP/HTTPS高级功能.所以要支持这些功能: 使用相关的 Handler处理器 来创建特定功能的 ...
- 解决erlang R17无法识别中文问题
erlang更新到R17已有一段时间了.公司项目打算从旧版的erlang迁移到R17,却不料有不少的困扰,当中一个问题是中文问题. 这个问题非常easy重现:新建一个文件t.erl.保存为utf-8无 ...
- JQUERY实现的小巧简洁的无限级树形菜单
JQUERY实现的小巧简洁的无限级树形菜单,可用于后台或前台侧栏菜单!兼容性也比较好. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tra ...
- node.js中的路由(url)初步
1.建立n4_root.js var http = require('http'); var url = require('url'); //这是node.js中自带的var router = req ...
- NodeJS版本EasyDarwin开源流媒体服务器开发心得
title: Node版本EasyDarwin开发心得 date: 2018-03-27 22:46:15 tags: 年后着手Node版本EasyDarwin的开发工作,截止到今天2018年03月2 ...