主题:http session状态保持

项目中需要保持http的session状态,研究了一下http中保持会话的资料,总结如下
http协议是面向无连接的协议,一次请求,一次操作,然后就结束了,是没有状态的。然后在实际应

用中需要保存用户信息的时候,可以采用cookie和session这2种方式,cookie是保存在客户端,

session是保存在服务器端的,个人觉得session比较安全。网上看资料,说是session的实现,是服务

器在内存中开辟一段内存区域,返回一个索引,即生成一个sessionid,发送到客户端,在客户端下一

次发送请求的时候将sessionid回传,则服务器可以找到用户的信息,相当于实现了状态的保持,因此

客户端还是要保存这个sessionid,我测试了一下在返回的response结果集中,将cookie键值对保存,

在下次发送请求的时候,将这个键值对以cookie的方式发送,结果成果。测试的例子是ww.our023.com

,测试结果很成果,如果没有登录,则返回的是无效的结果,但是如果登录了,然后将cookie中的内

容在下一次的请求中发送,则相当于包sessionid一起发送过去,则session状态保持成功。在cookie

中的键值对名,关系到sessionid的键值对,命名不知道是正面来的,反正接受到的参数都回传就是了

,这个估计和具体的服务器有一定的关系,或是和开发后台web的语言有一定关系,在此不在研究。
例子如下:

Java代码

1. public static void main(String[] args) throws Exception {
2.
3. String userName = "testyuce";
4. String password = "123456";
5. Map<String, String> loginData = new HashMap<String, String>();
6. loginData.put("username", userName);
7. loginData.put("password", password);
8. loginData.put("radio", "31536000");
9. loginData.put("referer", "/bbs");
10. //登录地址
11. Connection con = Jsoup.connect("http://www.our023.com/bbs/logging.php?action=login&loginsubmit=1");
12. con.data(loginData);
13. Response response = con.execute();
14. Document doc = response.parse();
15.
16. //如果包含则代表返回的页面不是错误页面
17. System.out.println("测试登录结果11111,是否包含testyuce:" + doc.html().contains("testyuce"));
18. // System.out.println(doc.html());
19. System.out.println("==============================================");
20.
21. Map<String, String> cookie = response.cookies();
22. //搜索地址
23. Connection conSearch = Jsoup.connect("http://www.our023.com/bbs/search.php?srchtxt=重庆&srchtype=title&searchsubmit=yes");
24. //设置请求时的cookie值,其中包含了上一次请求时服务器放回的sessionid
25. Iterator<Entry<String, String>> iterCookie = cookie.entrySet().iterator();
26. while(iterCookie.hasNext()){
27. Entry<String, String> entry = iterCookie.next();
28. conSearch.cookie(entry.getKey(), entry.getValue());
29. }
30. doc = conSearch.get();
31. //如果包含则代表返回的页面不是错误页面,则说明session状态保持成功
32. System.out.println("测试搜索结果2222,是否包含testyuce:" + doc.html().contains("testyuce"));
33.
34.
35. //如果熟悉html语言,可以看到返回的结果集合
36. // System.out.println(doc.html());
37. System.out.println("===============================================");
38. }

public static void main(String[] args) throws Exception {

String userName = "testyuce";
String password = "123456";
Map<String, String> loginData = new HashMap<String, String>();
loginData.put("username", userName);
loginData.put("password", password);
loginData.put("radio", "31536000");
loginData.put("referer", "/bbs");
//登录地址
Connection con = Jsoup.connect("http://www.our023.com/bbs/logging.php?action=login&loginsubmit=1");
con.data(loginData);
Response response = con.execute();
Document doc = response.parse();

//如果包含则代表返回的页面不是错误页面
System.out.println("测试登录结果11111,是否包含testyuce:" + doc.html().contains("testyuce"));
// System.out.println(doc.html());
System.out.println("==============================================");

Map<String, String> cookie = response.cookies();
//搜索地址
Connection conSearch = Jsoup.connect("http://www.our023.com/bbs/search.php?srchtxt=重庆&srchtype=title&searchsubmit=yes");
//设置请求时的cookie值,其中包含了上一次请求时服务器放回的sessionid
Iterator<Entry<String, String>> iterCookie = cookie.entrySet().iterator();
while(iterCookie.hasNext()){
Entry<String, String> entry = iterCookie.next();
conSearch.cookie(entry.getKey(), entry.getValue());
}
doc = conSearch.get();
//如果包含则代表返回的页面不是错误页面,则说明session状态保持成功
System.out.println("测试搜索结果2222,是否包含testyuce:" + doc.html().contains("testyuce"));


//如果熟悉html语言,可以看到返回的结果集合
// System.out.println(doc.html());
System.out.println("===============================================");
}


注:测试中用到了解析html的开源包jsoup
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值