您的位置:首页 > 其它

sed的用法

2015-12-23 15:01 288 查看
在实际应用中,向服务端获取数据,每次都需要登录,十分麻烦。希望登录一次后,在一定时间内不需要再次登录,就能直接访问服务了。
要实现该功能,也十分简单,首先需要服务端支持记住我的功能,客户端登录的时候选择记住我,这个时候服务端就会把记住我的信息存在cookie中返回给客户端,客户端后面登录的时候只需要带上这个cookie中的值,就可以直接免登录了
具体实现代码:

第一步,模拟登录请求,保存cookie
public static List<String> sendLogin(String url) {
List<String> list = new ArrayList<String>();
HttpGet request = new HttpGet(url);
try {
HttpResponse response = HttpClients.createDefault()
.execute(request);
if (response.getStatusLine().getStatusCode() == 200) {
String result = EntityUtils.toString(response.getEntity());
// 从响应消息中获取cookie中的rememberMe值,并保存到list中,供后面使用
Header[] hhh = response.getHeaders("Set-Cookie");
for (Header t : hhh) {
String v = t.getValue();
if (v.startsWith("rememberMe")) {
list.add(v);
}
}
}
} catch (Exception ex) {
ex.printStackTrace();
}
return list;
}

第二步,使用返回的cookie值,发送直接请求
public static String getDate(String url, List<String> cookies) {
HttpGet request = new HttpGet(url);
try {
for (String cookie : cookies) {
request.addHeader("Cookie", cookie);
}

HttpResponse response = HttpClients.createDefault()
.execute(request);
if (response.getStatusLine().getStatusCode() == 200) {
String result = EntityUtils.toString(response.getEntity());
return result;

}
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}


第一次获取的cookie值也可以保存在文件,下次直接使用cookie值进行请求,而不需要再次登录。
该功能对于服务端也有要求,对于第二次请求的url,在服务端设置对于记住我功能可以访问。

需要的jar包:
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpcore</artifactId>
<version>4.4.1</version>
</dependency>

<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5</version>
</dependency>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: