Javaweb基础--会话与状态

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

—高级软件人才实作培训专家!北京传智播客教育会话管理焦宁波—高级软件人才实作培训专家!北京传智播客教育:会话什么是会话?•会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话。会话过程中要解决的一些问题?•每个用户在使用浏览器与服务器进行会话的过程中,不可避免各自会产生一些数据,程序要想办法为每个用户保存这些数据。•例如:用户点击超链接通过一个Servlet购买了一个商品,程序应该想办法保存用户购买的商品(ID),以便于用户点结帐Servlet时,结帐Servlet可以得到用户购买的商品为用户结帐。•思考:用户购买的商品保存在request或ServletContext中行不行?—高级软件人才实作培训专家!北京传智播客教育:保存会话数据的两种技术:Cookie•Cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。Session•Session是服务器端技术,利用这个技术,服务器在运行时可以为每一个用户的浏览器创建一个其独享的session对象,由于session为用户浏览器独享,所以用户在访问服务器的web资源时,可以把各自的数据放在各自的session中,当用户再去访问服务器中的其它web资源时,其它web资源再从用户各自的session中取出数据为用户服务。—高级软件人才实作培训专家!北京传智播客教育:Cookie技术浏览器服务器BuyServlketPayServletSet-Cookie2:name=洗衣机Set-Cookie2:name=洗衣机name=洗衣机IE缓存区cookie:name=洗衣机cookie:name=洗衣机.—高级软件人才实作培训专家!北京传智播客教育:session浏览器B浏览器A浏览器CServlet1(购买)session=request.getSession()Session.setAttribute(name,objcet)Servlet2(结帐)Session=request.getsession()obj=Session.getAttribute(name);Session(a)name=洗衣机Session(b)name=电视Session(c)name=冰箱—高级软件人才实作培训专家!北京传智播客教育:CookieAPIjavax.servlet.http.Cookie类用于创建一个Cookie,response接口也中定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。Cookie类的方法:publicCookie(Stringname,Stringvalue)getName方法setValue与getValue方法setMaxAge与getMaxAge方法setPath与getPath方法setDomain与getDomain方法.sina.com—高级软件人才实作培训专家!北京传智播客教育:Cookie应用显示用户上次访问时间—高级软件人才实作培训专家!北京传智播客教育:Cookie细节一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。注意,删除cookie时,path必须一致,否则不会删除—高级软件人才实作培训专家!北京传智播客教育:Cookie应用显示用户上次浏览过的商品—高级软件人才实作培训专家!北京传智播客教育:显示上次浏览商品的实现过程显示网站商品的servlet:ahref=/servlet?id=1Javaweb开发/aahref=/servlet?id=2Jdbc开发/aahref=/servlet?id=3Spring开发/a您曾经浏览过的商品Javaweb开发Jdbc开发浏览器Servlet(根据ID显示商品详细信息)发送CookieId=2bookHistory=1bookHistory=1Id=1bookHistory=1-2bookHistory=1-2.—高级软件人才实作培训专家!北京传智播客教育:session在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个会话独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户会话独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。Session和Cookie的主要区别在于:•Cookie是把用户的数据写给用户的浏览器。•Session技术把用户的数据写到用户独占的session中。Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。—高级软件人才实作培训专家!北京传智播客教育:session浏览器B浏览器A浏览器Cservlet1Session=request.getsession()Session.setAttribute(name,objcet)Servlet2Session=request.getsession()obj=Session.getAttribute(name);Session(a)name=洗衣机Session(b)name=电视Session(c)name=冰箱Session小实验:使用IE访问某一个servlet,其它IE可以取到这个servlet存的数据吗?注意,虽然代码相同,但不同浏览器得到的各自的数据—高级软件人才实作培训专家!北京传智播客教育:session案例使用Session完成简单的购物功能—高级软件人才实作培训专家!北京传智播客教育:session实现原理疑问:服务器是如何实现一个session为一个用户浏览器服务的?浏览器B浏览器Aservlet1session=request.getSession()Servlet2session=request.getsession()SessionId=111SessionId=222cookie:Jsessionid=111cookie:Jsessionid=111cookie:Jsessionid=222cookie:Jsessionid=222问题:如何实现多个IE浏览器共享同一session?(应用:关掉IE后,再开IE,上次购买的商品还在。).实验—高级软件人才实作培训专家!北京传智播客教育无效getMaxInactiveInterval()invalidate()WEB应用的web.xml服务器的web.xml—高级软件人才实作培训专家!北京传智播客教育:IE禁用Cookie后的session处理实验演示禁用Cookie后servlet共享数据导致的问题。解决方案:URL重写•response.encodeRedirectURL(java.lang.Stringurl)•用于对sendRedirect方法后的url地址进行重写。•response.encodeURL(java.lang.Stringurl)•用于对表单action和超链接的url地址进行重写附加:•Session的失效•Web.xml文件配置session失效时间(默认30分钟)—高级软件人才实作培训专家!北京传智播客教育域RequestSessionServletContext—高级软件人才实作培训专家!北京传智播客教育:session案例使用Session完成用户登陆,注销•session.invalidate();•response.sendRedirect()利用Session防止表单重复提交1、网络延时,用户重复提交2、直接刷新处理页3、后退、提交利用Session实现一次性验证码—高级软件人才实作培训专家!北京传智播客教育:session案例-防止表单重复提交不足:但用户单击”刷新”,或单击”后退”再次提交表单,将导致表单重复提交—高级软件人才实作培训专家!北京传智播客教育:session案例-防止表单重复提交表单页面由servlet程序生成,servlet为每次产生的表单页面分配一个唯一的随机标识号,并在FORM表单的一个隐藏字段中设置这个标识号,同时在当前用户的Session域中保存这个标识号。当用户提交FORM表单时,负责处理表单提交的serlvet得到表单提交的标识号,并与session中存储的标识号比较,如果相同则处理表单提交,处理完后清除当前用户的Session域中存储的标识号。在下列情况下,服务器程序将拒绝用户提交的表单请求:存储Session域中的表单标识号与表单提交的标识号不同当前用户的Session中不存在表单标识号用户提交的表单数据中没有标识号字段编写工具类生成表单标识号:TokenProcessor—高级软件人才实作培训专家!北京传智播客教育:session案例一次性校验码一次性验证码的主要目的就是为了限制人们利用工具软件来暴力猜测密码。服务器程序接收到表单数据后,首先判断用户是否填写了正确的验证码,只有该验证码与服务器端保存的验证码匹配时,服务器程序才开始正常的表单处理流程。密码猜测工具要逐一尝试每个密码的前题条件是先输入正确的验证码,而验证码是一次性有效的,这样基本上就阻断了密码猜测工具的自动地处理过程。—高级软件人才实作培训专家!北京传智播客教育:综合案例应用Session+Cookie技术完成用户自动登陆功能

1 / 22
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功