java&android session共享 cookie共享 跨域
来源:互联网 发布:找工作 知乎 编辑:程序博客网 时间:2024/05/15 08:08
先描述下场景:1.我需要请求一个服务器的一张图片看到验证码。
2.我拿到验证码后去令一个服务器去发送登陆请求,这个时候登陆接口的这个服务器需要把我请求图片时的session同步过来,否则他无法验证验证码。
解决方案:也就是java&android 跨域时session同步,因为session是在cookie里的,所以只要同步cookie就ok!
代码:
urlConnection = (HttpURLConnection) url.openConnection();
String netType = getNetType(context);
if (!TextUtils.isEmpty(netType) && netType.toLowerCase().equals("wap")) {
// 中国移动GPRS无线上网参数的IP地址
Proxy proxy = new Proxy(java.net.Proxy.Type.HTTP, new InetSocketAddress("10.0.0.172", 80));
urlConnection = (HttpURLConnection) url.openConnection(proxy);
}
urlConnection.connect();
InputStream in = new BufferedInputStream(urlConnection.getInputStream(), ioBufferSize);
FilterInputStream fit = new FlushedInputStream(in);
//此时获取cookie 保存在application变量里
JdApplication.getInstance().mapCookie = getCookies(urlConnection);
public static Map<String, String> getCookies(URLConnection conn) {
Map<String, String> map = new HashMap<String, String>();
String headerName = null;
for (int i = 1; (headerName = conn.getHeaderFieldKey(i)) != null; i++) {
if (headerName.equalsIgnoreCase("Set-Cookie")) {
StringTokenizer st = new StringTokenizer(conn.getHeaderField(i), ";");
// the specification dictates that the first name/value pair
// in the string is the cookie name and value, so let's handle
// them as a special case:
if (st.hasMoreTokens()) {
String token = st.nextToken();
String name = token.substring(0, token.indexOf('='));
String value = token.substring(token.indexOf('=') + 1, token.length());
map.put(name, value);
}
}
}
return map;
}
然后在请求登陆的时候把cookie同步过来
在HttpClient对象执行execute()方法之前同步
if (JdApplication.getInstance().isImageCookie) {
String map ;
Map<String,String> smap = JdApplication.getInstance().mapCookie;
StringBuffer buf = new StringBuffer();
for(java.util.Map.Entry<String, String> en:smap.entrySet()){
buf.append(en.getKey()).append("=").append(en.getValue()).append("; ");
}
request.setHeader("Cookie", buf.toString());
}
这样就可以了。代码简单的写下,明白原理就可以了。不懂的可以私信我。
- java&android session共享 cookie共享 跨域
- cookie跨域session共享
- session、cookie、redis、session共享
- java session 共享
- java memcached 共享session
- java session共享
- 结合实践谈谈cookie和session——cookie跨域session共享
- 跨域共享cookie和跨域共享session
- 跨域共享cookie和跨域共享session
- 跨域共享cookie和跨域共享session
- IE8 的session cookie共享问题
- tomcat 动态域名共享session和cookie
- redis缓存和cookie实现Session共享
- cookie共享
- Cookie共享
- 关于java的session共享
- 关于java的session共享
- Java session共享的问题
- 深入浅出理解索引结构
- 汉诺塔————这是从别人那拷过来的程序,有能读懂调用函数的请指教
- Hive的基本原理与应用
- 重置SQLSERVER表的自增列,让自增列重新计数
- IOS MDM流程
- java&android session共享 cookie共享 跨域
- Google X:计算机更智能了,比人类还聪明
- 数据结构第二章总结
- inet_ntop, inet_pton
- 调试器(GDB)的基本使用方法(之一)
- 类似淘宝的搜索智能提示
- 如何保存chrome toolbar 下面对css的修改
- index rebuild vs index coalesce vs index shrink
- Best Practise for Runner/Service on Nexenta