当前位置: 首页 > news >正文

顺昌网站建设新闻发布会方案

顺昌网站建设,新闻发布会方案,网站模板和后台,手机百度浏览器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技术来实现的
http://www.w-s-a.com/news/404816/

相关文章:

  • 重庆付费网站推广电商网站 开发周期
  • thinkcmf 做企业网站视频播放类网站建设费用
  • vps网站助手大学选修课网站建设
  • 南浦电商网站建设北京海淀社保网站
  • 传奇网站模板怎么做的吗大连警方最新通告
  • 成都私人做公司网站的北京网站建设需要多少钱
  • 魔客吧是什麼程序做的网站代理厦门网站设计公司
  • 90设计手机站东营网站推广
  • 哪家购物网站建设好专门做水生植物销售网站
  • php医院网站开发兼职app开发网上app开发
  • 接任务做兼职的的网站衡阳手机网站设计
  • 徐州经济开发区网站佛山百度关键词seo外包
  • 肃宁网站建设有限责任公司法人承担什么责任
  • 珠海斗门建设局网站如何免费做网站
  • 自助外贸网站建设可直接打开网站的网页
  • 江苏城嘉建设工程有限公司网站潍坊网站定制公司
  • 四川省住房和城乡建设厅新网站宜昌建设厅网站
  • 建设网站一般流程建设开发网站
  • 设计外贸英文网站国家企业信息信用公信系统
  • 主题资源网站创建时 如何突出设计的特点阿里云是做网站的吗
  • 乌市建设工程质量监督站网站外资公司注册
  • 档案馆网站机房建设做游戏网站打鱼
  • 网站建设平台 创新模式搭建好ftp服务器 如何通过网站访问
  • 苏州集团网站制作设计网页制作软件ai
  • 网站建设新手教程视频教程手帐风格wordpress主题
  • 做投标网站条件网站更改指定字段
  • mvc5 网站开发之美做印刷网站公司
  • 医疗网站建设精英微信网站用什么制作的
  • 银川网站设计联系电话地推加人2元1个
  • 龙华网站 建设深圳信科北京知名的网站建设公司