本节将对 Cookie 进行介绍,下节将对 Session 进行介绍。
Cookie c = new Cookie("url", "www.lmcjl.com");其中参数 name 为 Cookie 的名称,参数 value 为 Cookie 的值,name 与 value 的取值不能包含
[ ] ( ) = , " / ? @ : ;
等字符方法 | 描述 | 所属接口 |
---|---|---|
void addCookie(Cookie cookie) | 用于在响应头中增加一个相应的 Set-Cookie 头字段。 | javax.servlet.http.HttpServletResponse |
Cookie[] getCookies() | 用于获取客户端提交的 Cookie。 | javax.servlet.http.HttpServletRequest |
返回值类型 | 方法 | 描述 |
---|---|---|
int | getMaxAge() |
用于获取指定 Cookie 的最大有效时间,以秒为单位。 默认情况下取值为 -1,表示该 Cookie 保留到浏览器关闭为止。 |
String | getName() | 用于获取 Cookie 的名称。 |
String | getPath() | 用于获取 Cookie 的有效路径。 |
boolean | getSecure() | 如果浏览器只通过安全协议发送 Cookie,则返回 true;如果浏览器可以使用任何协议发送 Cookie,则返回 false。 |
String | getValue() | 用于获取 Cookie 的值。 |
int | getVersion() | 用于获取 Cookie 遵守的协议版本。 |
void | setMaxAge(int expiry) |
用于设置 Cookie 的最大有效时间,以秒为单位。 取值为正值时,表示 Cookie 在经过指定时间后过期。取值为负值时,表示 Cookie 不会被持久存储,在 Web 浏览器退出时删除。取值为 0 时,表示删除该 Cookie。 |
void | setPath(String uri) | 用于指定 Cookie 的路径。 |
void | setSecure(boolean flag) | 用于设置浏览器是否只能使用安全协议(如 HTTPS 或 SSL)发送 Cookie。 |
void | setValue(String newValue) | 用于设置 Cookie 的值。 |
package net.biancheng.www.cookie; import java.io.IOException; import java.net.URLDecoder; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.util.Date; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * 使用 Cookie 记录上次的访问时间 * * @author 编程帮 www.lmcjl.com */ @WebServlet("/LoginTime") public class LoginTimeServlet extends HttpServlet { private static final long serialVersionUID = -5604481158386227221L; public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { /** * 1.获取所有的cookie,判断是否是第一次访问 * 2.如果是第一次访问 * * 输出欢迎,记录当前的时间,回写到浏览器 * 3.如果不是第一次访问 * * 获取时间,输出到浏览器,记录当前的时间,回写到浏览器。 * 记录当前的时间,回写到浏览器。 */ // 设置字符中文乱码问题 response.setContentType("text/html;charset=UTF-8"); // 获取所有的cookie Cookie[] cookies = request.getCookies(); // 通过指定cookie名称来查找cookie Cookie c = new Cookie("last","当前的时间"); Cookie cookie = getCookieByName(cookies, "lastTime"); // 判断,如果cookie==null,说明是第一次访问 if (cookie == null) { // 输出欢迎,记录当前的时间,回写到浏览器 response.getWriter().write("<h1>编程帮 www.lmcjl.com</h1>" + "<h3>编程帮,欢迎您的到来!</h3>"); } else { // 获取cookie的值,输出浏览器,记录当前的时间,回写到浏览器 String value = cookie.getValue(); // 输出浏览器(cookie的值中含有 “ ”,需要进行解码) response.getWriter().write("<h1>编程帮 www.lmcjl.com</h1>" + "<h3>编程帮,欢迎您的归来</h3><h3>您上次的时间是" + URLDecoder.decode(value) + "</h3>" + "<a href=\"/sessionDemo/removeCookie\" > 清除COOKIE</a>"); } // 记录当前的时间 Date date = new Date(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String sDate = sdf.format(date); // 回写到浏览器 // 使用cookie回写(cookie的值中含有 “ ”,需要进行编码才能使用) Cookie c = new Cookie("lastTime", URLEncoder.encode(sDate)); // 设置有效时间为一天 c.setMaxAge(60 * 60 * 24); // 秒 // 设置有效路径 c.setPath("/sessionDemo"); // 回写 response.addCookie(c); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } //通过指定名称查找指定的cookie public static Cookie getCookieByName(Cookie[] cookies, String name) { // 如果数组是null if (cookies == null) { return null; } else { // 循环遍历,目的:和name进行匹配,如果匹配成功,返回当前的cookie for (Cookie cookie : cookies) { // 获取cookie的名称,和name进行匹配 if (cookie.getName().equals(name)) { return cookie; } } return null; } } }
package net.biancheng.www.cookie; import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * 删除 Cookie * @author 编程帮 www.lmcjl.com */ @WebServlet("/removeCookie") public class RemoveCookieServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取cookie Cookie cookie = new Cookie("lastTime", ""); // 设置有效时间为0,删除cookie cookie.setMaxAge(0); // 设置有效路径,必须与要删除的Cookie的路径一致 cookie.setPath("/sessionDemo"); // 回写 response.addCookie(cookie); // 重定向商品列表页面 response.sendRedirect("/sessionDemo/LoginTime"); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
本文链接:http://task.lmcjl.com/news/13494.html