顺昌网站建设,新闻发布会方案,网站模板和后台,手机百度浏览器1. Cookie饼干
1.1 什么是Cookie#xff1f;
Cookie翻译过来就是饼干的意思Cookie是服务器通知客户端保存键值对的一种技术客户端有了Cookie后#xff0c;每次请求都发送给服务器每个Cookie的大小不能超过4kb
1.2 如何创建Cookie BaseServlet 程序
package com.gdhd;impo…1. Cookie饼干
1.1 什么是Cookie
Cookie翻译过来就是饼干的意思Cookie是服务器通知客户端保存键值对的一种技术客户端有了Cookie后每次请求都发送给服务器每个Cookie的大小不能超过4kb
1.2 如何创建Cookie BaseServlet 程序
package com.gdhd;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.lang.reflect.Method;public class BaseServlet extends HttpServlet {Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {doPost(req,resp);}Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {resp.setContentType(text/html;charsetutf-8);String action req.getParameter(action);try {Method method this.getClass().getDeclaredMethod(action, HttpServletRequest.class, HttpServletResponse.class);method.invoke(this,req,resp);} catch (Exception e) {e.printStackTrace();}}
}
html
!DOCTYPE html PUBLIC -//W3C//DTD HTML 4.01 Transitional//EN http://www.w3.org/TR/html4/loose.dtd
html
headmeta http-equivpragma contentno-cache /meta http-equivcache-control contentno-cache /meta http-equivExpires content0 /meta http-equivContent-Type contenttext/html; charsetUTF-8titleCookie/titlebase hrefhttp://localhost:8080/style typetext/cssul li {list-style: none;}/style
/head
body
iframe nametarget width500 height500 stylefloat: left;/iframe
div stylefloat: left;ullia hrefcookieServlet?actioncreateCookie targettargetCookie的创建/a/lilia hrefcookieServlet?actiongetCookie targettargetCookie的获取/a/lilia hrefcookieServlet?actionupdateCookie targettargetCookie值的修改/a/liliCookie的存活周期/liliullia hrefcookieServlet?actiondefaultLife targettargetCookie的默认存活时间会话/a/lilia hrefcookieServlet?actiondeleteNow targettargetCookie立即删除/a/lilia hrefcookieServlet?actionlife3600 targettargetCookie存活3600秒1小时/a/li/ul/lilia hrefcookieServlet?actiontestPath targettargetCookie的路径设置/a/lilia href targettargetCookie的用户免登录练习/a/li/ul
/div
/body
创建Cookie
protected void createCookie(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
//1 创建 Cookie 对象
Cookie cookie new Cookie(key4, value4);
//2 通知客户端保存 Cookie
resp.addCookie(cookie);
//1 创建 Cookie 对象
Cookie cookie1 new Cookie(key5, value5);
//2 通知客户端保存 Cookie
resp.addCookie(cookie1);
resp.getWriter().write(Cookie 创建成功);
}1.3 服务器如何获取Cookie
服务器获取客户端的Cookiereq.getCookies:cookie[]; Cookie工具类
public class CookieUtils {
/**
* 查找指定名称的 Cookie 对象
* param name
* param cookies
* return
*/
public static Cookie findCookie(String name , Cookie[] cookies){
if (name null || cookies null || cookies.length 0) {
return null;
}
for (Cookie cookie : cookies) {
if (name.equals(cookie.getName())) {
return cookie、}
}
return null;
}
}
Servlet程序中的代码
protected void getCookie(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
Cookie[] cookies req.getCookies();
for (Cookie cookie : cookies) {
// getName 方法返回 Cookie 的 key名
// getValue 方法返回 Cookie 的 value 值
resp.getWriter().write(Cookie[ cookie.getName() cookie.getValue() ] br/);
}
Cookie iWantCookie CookieUtils.findCookie(key1, cookies);
// for (Cookie cookie : cookies) {
// if (key2.equals(cookie.getName())) {
// iWantCookie cookie;
// break;
// }
// }
// 如果不等于 null说明赋过值也就是找到了需要的 Cookie
if (iWantCookie ! null) {
resp.getWriter().write(找到了需要的 Cookie);
}
}1.4 Cookie值的修改
方案一
// 方案一
// 1、先创建一个要修改的同名的 Cookie 对象
// 2、在构造器同时赋于新的 Cookie 值。
Cookie cookie new Cookie(key1,newValue1);
// 3、调用 response.addCookie( Cookie ); 通知 客户端 保存修改
resp.addCookie(cookie);方案二
// 方案二
// 1、先查找到需要修改的 Cookie 对象
Cookie cookie CookieUtils.findCookie(key2, req.getCookies());
if (cookie ! null) {
// 2、调用 setValue()方法赋于新的 Cookie 值。
cookie.setValue(newValue2);
// 3、调用 response.addCookie()通知客户端保存修改
resp.addCookie(cookie);
}1.5 浏览器查看Cookie
谷歌浏览器如何查看Cookie 火狐浏览器如何查看Cookie:
1.6 Cookie生命控制
Cookie的声明控制指的是如何管理Cookie什么时候被销毁setMaxAge() 1. 正数表示在指定秒数后被销毁 2. 负数表示浏览器一关,Cookie就会被删除(默认值是-1) 3. 零 表示马上删除Cookie
/**
* 设置存活 1 个小时的 Cooie
* param req
* param resp
* throws ServletException
* throws IOException
*/
protected void life3600(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
Cookie cookie new Cookie(life3600, life3600);
cookie.setMaxAge(60 * 60); // 设置 Cookie 一小时之后被删除。无效
resp.addCookie(cookie);
resp.getWriter().write(已经创建了一个存活一小时的 Cookie);
}
/**
* 马上删除一个 Cookie
* param req
* param resp
* throws ServletException
* throws IOException
*/
protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
// 先找到你要删除的 Cookie 对象
Cookie cookie CookieUtils.findCookie(key4, req.getCookies());
if (cookie ! null) {
// 调用 setMaxAge(0);
cookie.setMaxAge(0); // 表示马上删除都不需要等待浏览器关闭
// 调用 response.addCookie(cookie);
resp.addCookie(cookie);
resp.getWriter().write(key4 的 Cookie 已经被删除);
}
}
/**
* 默认的会话级别的 Cookie
* param req
* param resp
* throws ServletException
* throws IOException
*/
protected void defaultLife(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
Cookie cookie new Cookie(defalutLife,defaultLife);
cookie.setMaxAge(-1);//设置存活时间
resp.addCookie(cookie);
}1.7 Cookie有效路径Path的设置
Cookie的Path属性可以有效的过滤那些Cookie可以发送给服务器哪些不发。Path属性是通过请求的地址来进行有效的过滤
CookieA path/工程路径
CookieB path/工程路径/abc
请求地址如下
http://ip:port/工程路径/a.html
CookieA 发送
CookieB 不发送
http://ip:port/工程路径/abc/a.html
CookieA 发送
CookieB 发送protected void testPath(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
Cookie cookie new Cookie(path1, path1);
// getContextPath() 得到工程路径
cookie.setPath( req.getContextPath() /abc ); // /工程路径/abc
resp.addCookie(cookie);
resp.getWriter().write(创建了一个带有 Path 路径的 Cookie);
}
2. Session会话
2.1 什么是Session会话
Session就一个接口(HttpSession)Session就是会话它是用来维护一个客户端和服务器之间关联的一种技术每个客户端都有之间的一个Session会话Session会话中我们经常用来保存用户登录之后的信息
2.2 如何创建Session和获取(id号是否为新)
如何创建和获取Session它们的API是一样的 request.getSession() 第一次调用是创建Session会话之后调用都是获取前面创建好的Session会话对象 isNew()判断是不是刚创建出来的 true表示刚创建false表示获取之前创建 每一个会话都有一个id值而且这个id值是唯一的 getId()得到Session的会话id值
2.3 Session域数据的存取
/**
* 往 Session 中保存数据
* param req
* * param resp
* throws ServletException
* throws IOException
*/
protected void setAttribute(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
req.getSession().setAttribute(key1, value1);
resp.getWriter().write(已经往 Session 中保存了数据);
}
/**
* 获取 Session 域中的数据
* param req
* param resp
* throws ServletException
* throws IOException
*/
protected void getAttribute(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
Object attribute req.getSession().getAttribute(key1);
resp.getWriter().write(从 Session 中获取出 key1 的数据是 attribute);
}
2.4 Session生命周期的控制
public void set MaxInactiveInterval(int interval)设置Session的超时时间(以秒为单位),超过指定的时长Session就会被销毁 值为正数的是设定Session的超时时长负数表示永不超时极少使用 public int getMaxInactiveInterval()获取Session的超时时长public void invalidate()让当前Sessionion会话马上超时无效Session默认的超时时长是多少 Session默认的超时时长为30分钟因为在Tomcat服务器的配置文件web.xml中配置有 以下的配置它就表示配置了当前Tomcat服务器下所有的Session超时配置默认时长为30分钟
session-config
session-timeout30/session-timeout
/session-config如果说你希望你的web工程默认的Session的超时时长为其他时长你可以在你自己的web.xml配置文件中做以上相同的配置就可以修改你的web工程所以Session的默认超时时长
!--表示当前 web 工程。创建出来 的所有 Session 默认是 20 分钟 超时时长--
session-config
session-timeout20/session-timeout
/session-config如何你想修改个别的Session的超时时长就可以使用Session的方法SetMaxInactiveInterval(int interval)来进行单独的设置
Session超时的概念介绍 实例代码
protected void life3(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
// 先获取 Session 对象
HttpSession session req.getSession();
// 设置当前 Session3 秒后超时
session.setMaxInactiveInterval(3);
resp.getWriter().write(当前 Session 已经设置为 3 秒后超时);
}
Session马上被超时实例
protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException,
IOException {
// 先获取 Session 对象
HttpSession session req.getSession();
// 让 Session 会话马上超时
session.invalidate();
resp.getWriter().write(Session 已经设置为超时无效);
}2.5 浏览器和Session之间关联的技术内幕
Session技术底层其实是基于Cookie技术来实现的