版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、高级软件人才实作培训专家!会话管理方立勋北京传智播客教育高级软件人才实作培训专家!Tip:会话 什么是会话? 会话可简单理解为:用户开一个浏览器,点击多个超链接, 访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话。 会话过程中要解决的一些问题? 每个用户在使用浏览器与服务器进行会话的过程中,不可避免各自会产生一些数据,程序要想办法为每个用户保存这些数据。例如:用户点击超链接通过一个servlet购买了一个商品,程序应该想办法保存用户购买的商品,以便于用户点结帐servlet时,结帐servlet可以得到用户购买的商品为用户结帐。思考:用户购买的商品保存
2、在request或servletContext中行不行?北京传智播客教育 高级软件人才实作培训专家!Tip:保存会话数据的两种技术: Cookie Cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务 器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。 Session Session是服务器端技术,利用这个技术,服务器在运行时可以为每一个用户的浏览器创建一个其独享的session对象,由于session为用户浏览器独享,所以用户在访问服务器的web 资源时,可以把各自的
3、数据放在各自的session中,当用户再去访问服务器中的其它web资源时,其它web资源再从用户各自的session中取出数据为用户服务。北京传智播客教育 高级软件人才实作培训专家!Tip:Cookie技术servlet1Set-Cookie2: name=洗衣机Set-Cookie2: name=洗衣机servlet2cookie: name=洗衣机cookie: name=洗衣机name=洗衣机IE缓存区.北京传智播客教育 服务器浏览器高级软件人才实作培训专家!Tip:sessionSession(a)name=洗衣机Session(b)
4、name=电视Session(c)name=冰箱北京传智播客教育 浏览器Servlet2(结帐)Session = request.getsession() obj = Session.getAttribute(name);浏览器浏览器Servlet1(购买)session = request.getSession()Session.setAttribute(name,objcet)高级软件人才实作培训专家!Tip:Cookie API javax.servlet.http.Cookie类用于创建一个Cookie, response接口也中定义了一个addCookie
5、方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。 同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。Cookie类的方法: public Cookie(String name,String value) setValue与getValue方法 setMaxAge与getMaxAge方法 setPath与getPath方法/day06 setDomain与getDomain方法 getName方法北京传智播客教育 高级软件人才实作培训专家!Tip:Cookie应用 显示用户上次访问时间北京传智播客教育
6、高级软件人才实作培训专家!Tip:Cookie细节一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏 览器也可以存储多个WEB站点提供的Cookie。浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上, 则
7、需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。注意,删除cookie时,path必须一致,否则不会删除北京传智播客教育 高级软件人才实作培训专家!Tip:Cookie应用 显示用户上次浏览过的商品北京传智播客教育 高级软件人才实作培训专家!Tip:显示上次浏览商品的实现过程bookHistory=1bookHistory=1-2Id=1bookHistory=1Id=2bookHistory=1-2.北京传智播客教育 Servlet(根据ID显示商品详细信息)发送
8、Cookie浏览器显示网站商品的servlet:Javaweb开发Jdbc开发Spring开发您曾经浏览过的商品Javaweb开发Jdbc开发高级软件人才实作培训专家!Tip:session 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默 认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。 Session和Cookie的主要区别在于: Cookie是把用户的数据写给
9、用户的浏览器。 Session技术把用户的数据写到用户独占的session中。 Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。北京传智播客教育 高级软件人才实作培训专家!Tip:session 注意,虽然代码相同,但不同浏览器得到的各自的数据Session(a)name=洗衣机Session(b)name=电视Session(c)name=冰箱 Session小实验:使用IE访问某一个servlet,其它IE可以取到这个servlet存的数据吗?北京传智播客教育 浏览器Se
10、rvlet2Session = request.getsession() obj = Session.getAttribute(name);浏览器浏览器servlet1Session = request.getsession()Session.setAttribute(name,objcet)高级软件人才实作培训专家!Tip:session案例 使用Session完成简单的购物功能北京传智播客教育 高级软件人才实作培训专家!Tip:session实现原理 疑问:服务器是如何实现一个session为一个用户浏览器服务的?SessionId=111cookie:Jsess
11、ionid=111cookie:Jsessionid=111cookie:Jsessionid=222Session Id=222cookie:Jsessionid=222.实验 问题:如何实现多个IE浏览器共享同一session?(应用:关掉IE后,再开IE,上次购买的商品还在。)北京传智播客教育 浏览器Servlet2session = request.getsession()浏览器servlet1session = request.getSession()高级软件人才实作培训专家!Tip:IE禁用Cookie后的session处理 实验演示禁用Cookie后se
12、rvlet共享数据导致的问题。 解决方案:URL重写response. encodeRedirectURL(java.lang.String url) 用于对sendRedirect方法后的url地址进行重写。response. encodeURL(java.lang.String url) 用于对表单action和超链接的url地址进行重写 附加:Session的失效Web.xml文件配置session失效时间北京传智播客教育 高级软件人才实作培训专家!Tip:session案例 使用Session完成用户登陆 利用Session防止表单重复提交 利用Session
13、实现一次性验证码北京传智播客教育 高级软件人才实作培训专家!Tip:session案例防止表单重复提交 不足:但用户单击”刷新”,或单击”后退”再次提交表单,将导致表单重复提交北京传智播客教育 高级软件人才实作培训专家!Tip:session案例防止表单重复提交 表单页面由servlet程序生成,servlet为每次产生的表单页面分配一个唯一的随机标识号,并在FORM表单的一个隐藏字段中设置这个标识号,同时在当前用户的Session域中保存这个标识号。 当用户提交FORM表单时,负责处理表单提交的serlvet得到表单 提交的标识号,并与session中存储的标识号比较,如果相同则 处理表单提交,处理完后清除当前用户的Session域中存储的标识号。 在下列情况下,服务器程序将拒绝用户提交的表单请求: 存储Session域中的表单标识号与表单提交的标识号不同 当前用户的Session中不存在表单标识号 用户提交的表单数据中没有标识号字段 编写工具类生成表单标识号:TokenProcessor北京传智播客教育 高级软件人才实作培训专家!Tip:session案例一次性校验码 一次性验证码的主要目的就是为了限制人们利用工具软件来暴力猜测。 服务器程
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 智能辅助诊断系统开发与应用
- 己二腈装置操作工安全技能测试水平考核试卷含答案
- 多晶硅后处理工安全防护强化考核试卷含答案
- 中药炮炙工安全宣贯评优考核试卷含答案
- 酸性水汽提装置操作工发展趋势模拟考核试卷含答案
- 网络安全态势感知中的数据融合与可视化在网络安全态势可视化系统智能升级研究教学研究课题报告
- 药芯焊丝成型工保密水平考核试卷含答案
- 视频创推员安全理论能力考核试卷含答案
- 输气工岗前技能实操考核试卷含答案
- 工业供气工岗前实操综合知识考核试卷含答案
- 河北省石家庄市裕华区石家庄市第四十中学2024-2025学年七年级上学期期中地理试题(含答案)
- 手术清点记录评分标准
- 中国戏曲剧种鉴赏智慧树知到期末考试答案章节答案2024年上海戏剧学院等跨校共建
- pet薄膜生产工艺
- 二年级【语文(统编版)】语文园地一(第一课时)课件
- 肝脏的营养与保健知识讲座
- 2024届辽宁省抚顺市名校数学九年级第一学期期末达标检测模拟试题含解析
- 2023年广东省佛山市顺德区小升初数学试卷(含答案)
- 富士相机使用说明书
- 区域经济空间结构理论之增长极理论
- 北京工商大学大一高等数学上册期末考试卷及答案
评论
0/150
提交评论