栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

android与asp.net服务端共享session的方法详解

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

android与asp.net服务端共享session的方法详解

前言

最近因为工作的需要,要实现一个功能,就是需要通过发送短信进行注册,现在想把短信验证码放到服务器的session值中,当客户端收到短信并提交短信码时由asp.net服务端进行判断,那么如何共享这个session那么需要在android客户端中添加几行代码。

实现方法

如下操作。第一次数据请求时就获取这个cookie的名称并且得到这个cookie的值,这个即是sessionid的值并保存在一个静态变量中,然后在第二次请求数据的时候要将这个sessionid一并放在cookie中发给服务器,服务器则是通过这个sessionid来识别究竟是那个客户端在请求数据的,在asp.net中这个sessionid的名字叫做ASP.NET_SessionId,当然我们可以从程序中获取。

如下代码:

//获取服务端的这个sessionid的名称

 
List cookies = cookieStore.getcookies(); 
for(int i=0;i

获取sessionid的值

for(int i=0;i

完整的httputils代码如下:

public static DefaultHttpClient httpClient = null;

 private static String JSESSIONID; //定义一个静态的字段,保存sessionID 

 public static String getRequest(String url)

 {

 httpClient = new DefaultHttpClient();

 HttpGet get = new HttpGet(url);

 try

 {

 HttpParams params = new BasicHttpParams();

  HttpConnectionParams.setConnectionTimeout(params, 10000);//设置连接超时

  HttpConnectionParams.setSoTimeout(params, 15000);//设置请求超时

  get.setParams(params);

  get.setHeader("Content-Type", "application/x-www-form-urlencoded; charset=utf-8");

  if(null != JSESSIONID){ 

  get.setHeader("cookie", "ASP.NET_SessionId="+JSESSIONID); 

  }

  //连接响应,通过HttpResponse获得响应信息

 HttpResponse httpResponse = httpClient.execute(get);

 if(httpResponse.getStatusLine().getStatusCode() == 200)

 {

 //取得响应字符串

 String result = EntityUtils.toString(httpResponse.getEntity());

 return result;

 }

 }

 catch (ClientProtocolException e)

 {

 return null;

 }

 catch (IOException e)

 {

 return null;

 }

 return null;

 }

 

 public static String postRequest(String url, HashMap rawParams) throws Exception

 {

 httpClient = new DefaultHttpClient();

 //创建POST请求方式

 HttpPost post = new HttpPost(url);

 

 HttpParams cparams = new BasicHttpParams();

 

 HttpConnectionParams.setConnectionTimeout(cparams, 10000);//设置连接超时

 HttpConnectionParams.setSoTimeout(cparams, 15000);//设置请求超时

 post.setParams(cparams);

 post.setHeader("Content-Type", "application/x-www-form-urlencoded; charset=utf-8");

 if(null != JSESSIONID){ 

 post.setHeader("cookie", "ASP.NET_SessionId="+JSESSIONID); 

  }

 //使用NamevaluePair来保存要传递的参数,可以使用BasicNamevaluePair来构造一个要被传递的参数

 //通过add添加这个参数到NamevaluePair中

 ArrayList params = new ArrayList();

 for(String key : rawParams.keySet())

 {

 //添加要传传递的参数

 params.add(new BasicNamevaluePair(key, rawParams.get(key)));

 }

 //post需要为参数设置字符集

 HttpEntity httpEntity = new UrlEncodedFormEntity(params, HTTP.UTF_8);

 //请求httpRequest

 post.setEntity(httpEntity);

 //发送POST请求并获取响应

 HttpResponse httpResponse = null;

 try

 {

  httpResponse = httpClient.execute(post);

 }

 catch(Exception ex)

 {

 String ee = ex.getMessage();

 }

 if(httpResponse.getStatusLine().getStatusCode() == 200)

 {

 String result = EntityUtils.toString(httpResponse.getEntity(), HTTP.UTF_8);

  

   cookieStore cookieStore = httpClient.getcookieStore(); 

   List cookies = cookieStore.getcookies();

   for(int i=0;i

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对考高分网的支持。
 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/157878.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号