jsessionid文件包含漏洞在请求url里是不是漏洞

查看: 3016|回复: 7
关于模拟登录取得JSESSIONID的问题!
TA的每日心情奋斗 10:10签到天数: 5 天[LV.2]偶尔看看I
是这样的,我写了一个程序去爬取一个jsp的后台,程序版本是.net 4.5。我用chrome浏览器的f12抓取到的JSESSIONID添加到webclient的请求header中,可以正常爬取该后台。但是我用httpwebrequest去模拟登录,得到返回的JSESSIONID,再加入到webclient或者webrequest的请求header中,就无法正确爬取了。请问是什么原因呢?
TA的每日心情开心8&小时前签到天数: 143 天[LV.7]常住居民III
你对比一下获取的有什么不同,是不是自己登录的没有成功啊,或者是Cookie格式不对
TA的每日心情奋斗 10:10签到天数: 5 天[LV.2]偶尔看看I
模拟登录成功了,拿到了返回的JSESSIONID,和浏览器里获取的JSESSIONID格式是一样的。代码是同一套,就是用模拟登录拿到的JSESSIONID就不能爬,用浏览器获取的JSESSIONID就能爬
TA的每日心情开心8&小时前签到天数: 143 天[LV.7]常住居民III
模拟登录成功了,拿到了返回的JSESSIONID,和浏览器里获取的JSESSIONID格式是一样的。代码是同一套,就是用 ...
这只能证明一个问题,登录未成功,并没有真正成功,也许只是成功了一半。很多网站是在登录成功之后要跳转或者设置Cookie值的,你确实只加JSESSIONID这一个Cookie值就行了,没有其他的了?如果有也许是其他值影响的
TA的每日心情奋斗 10:10签到天数: 5 天[LV.2]偶尔看看I
我用浏览器获取的JSESSIONID,只需要加入这个cookie就能正常抓取数据。要么就是用webrequest请求得到的JSESSIONID是不对的,但是我不知道为什么不对。。
TA的每日心情开心8&小时前签到天数: 143 天[LV.7]常住居民III
我用浏览器获取的JSESSIONID,只需要加入这个cookie就能正常抓取数据。要么就是用webrequest请求得到的JSES ...
你打出来对比一下,看看不是多什么参数了,比如Path=/之后的过滤一下
TA的每日心情奋斗 10:10签到天数: 5 天[LV.2]偶尔看看I
是多了Path=/,不过我用正则提取了JSESSIONID=这一部分,然后放到了header中
TA的每日心情开心 11:14签到天数: 3 天[LV.2]偶尔看看I
我也是遇到了这个问题,例如YY.COM,有验证码的账号登陆时的包就包含一个JSESSIONID,火狐浏览器可以重发包,在哪上面把截取的包重新发一遍是可以返回内容的,但是我把那些内容用HttpHelper发送就不可以
( 豫ICP备号-1)&&1046人阅读
最近用struts2 +ajax实验了一个登陆的页面,第一次在浏览器里输入地址时后面会附带jsessionid=************,遂上网搜了搜
在web应用的开发中我们会经常看到这样的url:...。这跟一般的url基本一样,只有一个地方有区别,那就是“;jessionid=xxxxxxxx”。这个参数有时候有,有时候又没有,说它是参数可又跟一般传递的参数不同,它是紧跟在url后面用分号来分隔的,用一般的request.getParameter()方法还取不到。那这个参数到底是干嘛用的呢?要了解它还要先了解session的实现方式。
session的实现方式
做web开发的同学都知道,http是无状态的会话协议,也就是说无法保存用户的信息。那如果有一些信息需要在用户的浏览活动中一直保持,该怎么做呢?我们可以把这些信息在每次请求的时候作为参数传递给服务器,但这样做既麻烦又耗费资源,这时候就体现出了session的重要性。session是web开发中不可或缺的一个特性。它是对于一个特定的用户请求,在web服务器上保存的一个全局变量。有了它我们就可以把用户的一些信息保存在服务器上,而不用在服务器和客户端之间来回传递。知道了session的作用,那session是怎么实现的呢?服务器上为每个用户都保存了一个session,那当用户请求过来的时候是怎么知道某一个用户应该对应哪个session呢?这时jsessionid就派上用场了。每一个session都有一个id来作为标识,这个id会传到客户端,每次客户端请求都会把这个id传到服务器,服务器根据id来匹配这次请求应该使用哪个session。jsessionid就是客户端用来保存sessionid的变量,主要是针对j2ee实现的web容器,没有研究过其他语言是用什么变量来保存的。一般对于web应用来说,客户端变量都会保存在cookie中,jsessionid也不例外。不过与一般的cookie变量不同,jsessionid是保存在内存cookie中的,在一般的cookie文件中是看不到它的影子的。内存cookie在打开一个浏览器窗口的时候会创建,在关闭这个浏览器窗口的时候也同时销毁。这也就解释了为什么session变量不能跨窗口使用,要跨窗口使用就需要手动把jsessionid保存到cookie里面。
jsessionid的作用
在以上的文字中我们了解了session的实现原理,同时也知道了session跟jsessionid紧密不可分割的联系。只有通过jsessionid才能使session机制起作用,而jsessionid又是通过cookie来保存。看到这里,也许你会发现一个问题,如果用户禁用了cookie,那jsessionid不是就不能保存了吗?session不是不起作用了吗?我们真的对此束手无策了吗?当然不是。在用户禁用了cookie时候,我们可以通过url重写来实现jsessionid的传递。这就是我上面指出的那样的url:..。jessionid通过这样的方式来从客户端传递到服务器端,从而来标识session。注意一点,jsessionid跟一般的url参数传递方式是不同的,不是作为参数跟在?后面,而是紧跟在url后面用;来分隔。这样在用户禁用cookie的时候我们也可以传递jsessionid来使用session了,只不过需要每次都把jseesionid作为参数跟在url后面传递。那这样岂不是很麻烦,每次请求一个url都要判断cookie是否可用,如果禁用了cookie,还要从url里解析出jsessionid,然后跟在处理完后转到的url后面,以保持jsessionid的传递。这些问题sun当然已经帮我们想到了,所以提供了2个方法来使事情变得简单:response.encodeURL()和response.encodeRedirectURL()。这2个方法会判断cookie是否可用,如果禁用了会解析出url中的jsessionid,并连接到指定的url后面,如果没有找到jessionid会自动帮我们生成一个。至于为什么要有2个方法?这2个方法有什么不同?google了一下,说是这2个方法在判断是否要包含jsessionid的逻辑上会稍有不同。在调用HttpServletResponse.sendRedirect前,应该先调用encodeRedirectURL()方法,否则可能会丢失Sesssion信息。这2个方法的使用方法如:response.sendRedirect(response.encodeURL(&/myapp/input.jsp&));。如果cookie没有禁用,我们在浏览器地址栏中看到的地址是这样的:/myapp/input.jsp,如果禁用了cookie,我们会看到:/myapp/input.jsessionid=73E6BAFD44F4。所以,我们在写web应用的时候,为了保险起见,应该在程序里的每一个跳转url上都使用这2个方法,来保证session的可用性。
另一篇文章(关于安全问题,也不知道到底说的是什么?先贴出来,本人菜鸟,还望高人指点一二)
发信人: canper (洗衣粉), 信区: Java&
标&&题: [合集] struts2进行action跳转时的jsessionid是什么&
发信站: 水木社区 (Fri May 28 21:01:52 2010), 站内&
☆─────────────────────────────────────☆&
&&&seaver31 (benny)&于&(Sat
Mar&&6 08:34:25 2010)&提到:&
比如是xx.action 点击链接后 地址栏是xx.jsessionid=CBA1C614XXXXXXXX&&为什么会有jsessionid呢?谢谢!&
☆─────────────────────────────────────☆&
&&&bestboy (百斯特抱爱)&于&(Sat
Mar&&6 08:58:20 2010)&提到:&
第一次会有,这个东西的存在是有必要的,&
如果浏览器不支持cookie,起码这个id会一直带着,这是http协议交互时候保证状态用的&
另外比如一些前端分配做集群时候可以直接重写这个id来同步,这个至少我这么理解的,也不知道对不对&
以后你可以request.getSession().getId()来获取&
【 在 seaver31 (benny) 的大作中提到: 】&
: 比如是xx.action 点击链接后 地址栏是xx.jsessionid=CBA1C614XXXXXXXX&&为什么会有jsessionid呢?谢谢!&
☆─────────────────────────────────────☆&
&&&seaver31 (benny)&于&(Sat
Mar&&6 09:30:42 2010)&提到:&
谢谢 可是不同页面点击同样的action链接有的 有这个 有的没有 是不是和进入页面的action type有关系? 另外 存在这个会不会又安全的问题?&
【 在 bestboy (百斯特抱爱) 的大作中提到: 】&
: 第一次会有,这个东西的存在是有必要的,&
: 如果浏览器不支持cookie,起码这个id会一直带着,这是http协议交互时候保证状态用的&
: 另外比如一些前端分配做集群时候可以直接重写这个id来同步,这个至少我这么理解的,也不知道对不对&
: ...................&
☆─────────────────────────────────────☆&
&&&helloweenpad (helloweenpad)&于&(Sun
Mar&&7 22:35:34 2010)&提到:&
有的有,是因为request没有携带名为jsessionid的cookie。有的没有,是因为访问过这个context,名为jsessionid的cookie已经生成了,就不需要再在url中包括jsessionid了。复习一下基本知识吧。&
【 在 seaver31 (benny) 的大作中提到: 】&
: 谢谢 可是不同页面点击同样的action链接有的 有这个 有的没有 是不是和进入页面的action type有关系? 另外 存在这个会不会又安全的问题?&
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:165740次
积分:2580
积分:2580
排名:第11005名
原创:67篇
转载:144篇
(1)(1)(11)(4)(1)(1)(1)(1)(3)(2)(2)(3)(4)(2)(2)(4)(4)(1)(1)(4)(15)(4)(2)(4)(2)(23)(8)(11)(17)(18)(52)(8)会话状态保持,JSESSIONID,COOKIE,URL重写 - zzm - ITeye技术网站
博客分类:
在服务器端,我们用惯了session.setAttribute("",userInfo)这样的一行代码,估计你很少想到:服务器与浏览器之间是如何保持会话状态的。好了,先引用一些文章的精彩片段:
/xxx_jsessionid=xxxxxxxxxx?a=x&b=x。
这跟一般的url基本一样,只有一个地方有区别,那就是“;jessionid=xxxxxxxx”。这个参数有时候有,有时候又没有,说它是参数可又跟一般传递的参数不同,它是紧跟在url后面用分号来分隔的 ,用一般的request.getParameter()方法还取不到jsessionid 。
启动你的tomcat,打开FireFox(爱得不得了,一定要安装FireBug),输入localhost就行,打开firebug,点网络,你会看到,浏览器与服务器会话的信息,给出浏览器
(1)第一次请求服务器:
浏览器的请求头信息
服务器响应头信息
(2)第二次请求服务器:
浏览器的请求头信息
服务器响应头信息
重复第三次,每四次...第N次请求服务器,浏览器和服务器的请求头信息都是与第二次请求服务器是一样的。
(3)但是,如果你在服务器端加入如下一行代码:
("SessionId:" + request.getSession().getId());
你会看到,当你第一次请求服务器时,就会默认有一个新的session被创建,而且在session的有效时间范围内,这个输出值是不会变的,否则,服务器会重新创建一个session,自然,sessionId也就不同了,这段代码的输出自然也会不同了。
(4)你必须注意这一点:你用的是浏览器与服务器通信:
有一些事情是浏览器帮助我们去做了,那就是:当你第一次与服务器通信时,浏览器会保存服务器返回的 Set-Cookie 这个健的值( JSESSIONID=64D21B4D69DFB32BD6CB ),只要你不关闭浏览器(彻底关闭,关闭选项卡不算),浏览器会从第二次向服务器发出请求开始,一直带上这个键值对,发给服务器。服务器就会知道,这是同一个人(同一个会话)发起的请求。
(5)我们再注意一下:request.setAttribute("sysuser",userInfo)这句话:
当你第一次请求服务器时,这句代码会根据服务器默认产生的session得到ID,并与sysuser=userInfo这个键值对挂上钩(当然,userInfo可以是任何对象),保证唯一关联,检测用户是否登录就是这样实现的。
我一定要声明一点:保持一个会话与用户是否登录是没有任何关系的。
(6)再次引深一下,如果你用的不是浏览器,比如说做J2ME开发,怎样保持会话呢?
(1) 在你写完这行代码后:HttpConnection hc = (HttpConnection)Connector.open(httpURL),加入以下代码:(Constant.sessionID只是一个静态变量 )
if (Constant.sessionID != null) {
hc.setRequestProperty("Cookie", AppContext.CurrentAppContext.sessionID);
(2) A:只向服务器读数据,不向服务写数据,B:先向服务器写数据,再从服务器读数据
对于这两种情况,只要你第一次打开openDataInputStream(),这可以加入以下代码( Constant.isLogin 只是一个静态变量boolean ):
String cookie = hc.getHeaderField("Set-Cookie");
if (cookie != null) {
String jsessionId = cookie.substring(0,cookie.indexOf(";"));
if(Constant.sessionID != null && !Constant.sessionID.equals(jsessionId) && Constant.isLogin ){
("sessionid超时, will get new sessionid, but you must login again");
Constant.isLogin = false;
Constant.sessionID = jsessionId;
这样就可以保持一个会话了。
(7)最后,关于URL重定向
引用一段话:sun帮我们想到了,所以提供了2个方法来使事情变得简单:response.encodeURL()和response.encodeRedirectURL()。这2个方法会判断cookie是否可用,如果禁用了会解析出url中的jsessionid,并连接到指定的url后面,如果没有找到jessionid会自动帮我们生成一个。至于为什么要有2个方法?这2个方法有什么不同?google了一下,说是这2个方法在判断是否要包含jsessionid的逻辑上会稍有不同。在调用 HttpServletResponse.sendRedirect前,应该先调用encodeRedirectURL()方法,否则可能会丢失 Sesssion信息。这2个方法的使用方法如:response.sendRedirect(response.encodeURL("/myapp /input.jsp"));。如果cookie没有禁用,我们在浏览器地址栏中看到的地址是这样的:/myapp/input.jsp,如果禁用了 cookie,我们会看到:/myapp /input.jsessionid=73E6BAFD44F4。所以,我们在写web应用的时候,为了保险起见,应该在程序里的每一个跳转url上都使用这2个方法,来保证session的可用性。
http://blog.csdn.net/collonn/article/details/5698906
浏览: 656295 次
来自: 南京
浅入深出ElasticSearch构建 ...
分布式的没有减少么
分布式事务数据一致性推荐一个参考文章:http://www.r ...
杭州机房挂了怎么办,其他机房的zk都不能进行选举,也不能提供写 ...
都按步骤走了,更新完后,索引文件都被删除了,怎么解压

我要回帖

更多关于 url 自动加jsessionid 的文章

 

随机推荐