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

url中的jsessionid

 url中的jsessionid解释                                
(1)

这是一个保险措施
因为Session默认是需要Cookie支持的
但有些客户浏览器是关闭Cookie的
这个时候就需要在URL中指定服务器上的session标识

(2)

链接1:wapbrowse.jsp?curAlbumID=9 ;
链接2:wapbrowse.jsp;jsessionid=5AC6268DD8D4D5D1FDF5D41E9F2FD960?curAlbumID=9;
这两个链接是从模拟器运行时生成的source中拷贝过来的,两个链接都是指向wapbrowse.jsp,链接1由于不包含jsessionid,所以在 wapbrowse.jsp中变量为null,通过链接2打开wapbrowse.jsp可以正常访问session 变量

(3)

URL重写功能,为了防止一些用户把Cookie禁止而无法使用session而设置的功能.jsessionid后面的一长串就是你服务器上的session的ID号,这样无需cookie也可以使用session.

(4)

http本身是无session的,无法跟踪客户端的信息,换句话说:http协议不管是谁联接自己。
为了实现session,必须有浏览器支持。浏览器可以用cookie存储session,这是最通用的做法。
但是,如果我自己写一个完全符合http协议的浏览器,但是不配合服务器的session要求,那么服务器就无法产生session。
好在现在的浏览器都支持session要求,即使关闭了cookie,浏览器也会向服务器传递sessionid,这个id是存储在浏览器的内存空间中的,不保存在硬盘cookie中。

(5)

sessionid是作为一个临时cookie放在浏览器端的。

session的具体信息放在服务器端。

每次浏览器发出的请求,都会在http header里 带上 sessionid来标识自己。

既然用Struts,顺便再把JSTL用上,

下面一个非常有用的标签:

清单 12. 操作的语法
    var="name" scope="scope">

...

 


URL 重写是由 操作自动执行的。如果 JSP 容器检测到一个存储用户当前会话标识的 cookie,那么就不必进行重写。但是,如果不存在这样的 cookie,那么 生成的所有 URL 都会被重写以编码会话标识。注:如果在随后的请求中存在适当的 cookie,那么 将停止重写 URL 以包含该标识。


参考:http://www-900.ibm.com/developerWorks/cn/java/j-jstl0318/index.shtml

(6)

方法一:url中紧跟servlet/jsp文件名加;jsessionid=sessionId,其中sessionId由HttpSession.getId()得到,如http://localhost:8080/aaa/bbb.jsp;jsessionid=saldjfsdflsaeir234?para=1?2=2

方法二:在application(ServletContext)里保存一个session管理器HashMap:sessionId---sessionRef,这样可以在所有的servlet/jsp里调用,这需要在url里将sessionId以参数形式传递,如http://localhost:8080/aaa/bbb.jsp?sessionId=saldjfsdflsaeir234?para=1?2=2,在服务器端用request.getParameter("sessionId")获取

(7)

session是在服务器端保存。服务器根据url请求中的session_id来查找对应的session。

以一个bbs为例,网站需要根据每个请求url获取用户的信息,如果以cookie方式,用户信息全部是存放在cookie中的,这样可能会不安全;如果以 session方式,用户信息可以存放在服务器端,服务器只要从http请求中得到session_id,就可以得到存放在session中的用户信息了,这样安全性比较高。session在服务器中的表现方式依服务器而定,可能是写到临时文件中,也可能直接放在内存中。

服务器从http 请求中得到session_id的方式有两种:cookie和url重写。如果客户端启用cookie,那么session_id可以保存在cookie 中;如果禁用cookie,就用url重写方式,在url中添加.jsessionid=xxxxx参数部分,服务器会试图从url中得到. jsessionid参数作为session_id.

(8)

cookie 是保存在客户端的文本格式数据,session是客户端登录到应用,由服务器为该客户端建立的唯一的标识,可以在session里面保存该客户端的数据比如说用户帐号。
一般cookie可以用来保存你的登录帐号和密码,在你登录到应用服务上,自动添加到登录界面或直接发送到服务器上进行登录,这就是你经常能在论坛上看到的你的登录信息保存一年的选项 的实现方式

(9)

在http的报文格式里面cookie和session是在同一个包文位置上的
如果ie发现包文里面包含cookie/session的信息的话,他会根据安全级别来决定是否保存相关信息,比如,如果安全机制允许使用cookie那么 ie将把cookie的信息保存到临时文件里面,每次在请求服务器文件的时候会把收到的session的信息加入到请求的报文里面,这就是session 保存信息的原理。如果安全机制不允许使用cookie的话,虽然ie收到了cookie和session的信息,那么cookie的信息不会被写入临时文件,当ie再次请求服务器文件的时候,也不会把收到的session的信息加入到请求报文里面,服务器就无法知道session的信息了

相关文章:

  • 精妙SQL语句
  • Tomcat及MySQL服务配置
  • document.referrer 用法
  • ssh框架有关数据源的配置
  • java解析xml的四种方法
  • double类型的数字变为汉字(金额)
  • 特长的string从一行变多行
  • SESSIONS.ser 的问题
  • 有关urlrewrite
  • Tomcat5.5配置-多域名绑定和虚拟目录
  • ajax的几个状态值
  • 跟着鼠标的眼睛
  • sql 实例
  • MYSQL常见出错代码解析
  • 编写不被各大主流邮箱过滤的能正常显示的HTML邮件的技巧
  • 【vuex入门系列02】mutation接收单个参数和多个参数
  • Android Studio:GIT提交项目到远程仓库
  • js如何打印object对象
  • js写一个简单的选项卡
  • Magento 1.x 中文订单打印乱码
  • SpringBoot 实战 (三) | 配置文件详解
  • Travix是如何部署应用程序到Kubernetes上的
  • vuex 学习笔记 01
  • 责任链模式的两种实现
  • ​MPV,汽车产品里一个特殊品类的进化过程
  • #LLM入门|Prompt#1.8_聊天机器人_Chatbot
  • #在线报价接单​再坚持一下 明天是真的周六.出现货 实单来谈
  • (09)Hive——CTE 公共表达式
  • (八)Flask之app.route装饰器函数的参数
  • (第61天)多租户架构(CDB/PDB)
  • (附源码)springboot家庭装修管理系统 毕业设计 613205
  • (附源码)计算机毕业设计ssm-Java网名推荐系统
  • (学习日记)2024.02.29:UCOSIII第二节
  • (转)ABI是什么
  • (转)关于多人操作数据的处理策略
  • .net 简单实现MD5
  • .NET6 命令行启动及发布单个Exe文件
  • .net使用excel的cells对象没有value方法——学习.net的Excel工作表问题
  • .NET中使用Protobuffer 实现序列化和反序列化
  • @Import注解详解
  • [ C++ ] STL---string类的使用指南
  • [100天算法】-目标和(day 79)
  • [AIGC] Spring Interceptor 拦截器详解
  • [bzoj 3124][sdoi 2013 省选] 直径
  • [bzoj2957]楼房重建
  • [C++]指针与结构体
  • [CakePHP] 在Controller中使用Helper
  • [DevOps云实践] 彻底删除AWS云资源
  • [Docker]十.Docker Swarm讲解
  • [GXYCTF2019]禁止套娃
  • [hdu 4405] Aeroplane chess [概率DP 期望]
  • [HNOI2010]BUS 公交线路
  • [iphone-cocos2d]关于Loading的若干处理和讨论
  • [JavaWeb学习] idea新建web项目
  • [LeetCode]-使用特殊算法的题目-2