欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

android與asp.net服務(wù)端共享session的方法詳解

 更新時間:2017年09月07日 08:53:02   作者:KimhillZhang  
這篇文章主要給大家介紹了關(guān)于android與asp.net服務(wù)端如何共享session的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋們下面隨著小編來一起學習學習下吧。

前言

最近因為工作的需要,要實現(xiàn)一個功能,就是需要通過發(fā)送短信進行注冊,現(xiàn)在想把短信驗證碼放到服務(wù)器的session值中,當客戶端收到短信并提交短信碼時由asp.net服務(wù)端進行判斷,那么如何共享這個session那么需要在android客戶端中添加幾行代碼。

實現(xiàn)方法

如下操作。第一次數(shù)據(jù)請求時就獲取這個cookie的名稱并且得到這個cookie的值,這個即是sessionid的值并保存在一個靜態(tài)變量中,然后在第二次請求數(shù)據(jù)的時候要將這個sessionid一并放在Cookie中發(fā)給服務(wù)器,服務(wù)器則是通過這個sessionid來識別究竟是那個客戶端在請求數(shù)據(jù)的,在asp.net中這個sessionid的名字叫做ASP.NET_SessionId,當然我們可以從程序中獲取。

如下代碼:

//獲取服務(wù)端的這個sessionid的名稱

/* 獲取cookieStore */ 
List<Cookie> cookies = cookieStore.getCookies(); 
for(int i=0;i<cookies.size();i++){ 
  String sessionid = cookies.get(i).getName(); 從這里可以獲取到這個sessionid,即為 ASP.NET_SessionId

}

獲取sessionid的值

for(int i=0;i<cookies.size();i++){

if("ASP.NET_SessionId".equals(cookies.get(i).getName())){ 
  JSESSIONID = cookies.get(i).getValue(); //這個即為sessionid的值
  break; 
}

}

完整的httputils代碼如下:

public static DefaultHttpClient httpClient = null;

 private static String JSESSIONID; //定義一個靜態(tài)的字段,保存sessionID 

 public static String getRequest(String url)

 {

 httpClient = new DefaultHttpClient();

 HttpGet get = new HttpGet(url);

 try

 {

 HttpParams params = new BasicHttpParams();

  HttpConnectionParams.setConnectionTimeout(params, 10000);//設(shè)置連接超時

  HttpConnectionParams.setSoTimeout(params, 15000);//設(shè)置請求超時

  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); 

  }

  //連接響應(yīng),通過HttpResponse獲得響應(yīng)信息

 HttpResponse httpResponse = httpClient.execute(get);

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

 {

 //取得響應(yīng)字符串

 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<String, String> rawParams) throws Exception

 {

 httpClient = new DefaultHttpClient();

 //創(chuàng)建POST請求方式

 HttpPost post = new HttpPost(url);

 

 HttpParams cparams = new BasicHttpParams();

 

 HttpConnectionParams.setConnectionTimeout(cparams, 10000);//設(shè)置連接超時

 HttpConnectionParams.setSoTimeout(cparams, 15000);//設(shè)置請求超時

 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來保存要傳遞的參數(shù),可以使用BasicNameValuePair來構(gòu)造一個要被傳遞的參數(shù)

 //通過add添加這個參數(shù)到NameValuePair中

 ArrayList<NameValuePair> params = new ArrayList<NameValuePair>();

 for(String key : rawParams.keySet())

 {

 //添加要傳傳遞的參數(shù)

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

 }

 //post需要為參數(shù)設(shè)置字符集

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

 //請求httpRequest

 post.setEntity(httpEntity);

 //發(fā)送POST請求并獲取響應(yīng)

 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

        ASP.NET_SessionId就是通過上面的方法獲取到。

      */ 

   CookieStore cookieStore = httpClient.getCookieStore(); 

   List<Cookie> cookies = cookieStore.getCookies();

   for(int i=0;i<cookies.size();i++){ 

    if("ASP.NET_SessionId".equals(cookies.get(i).getName())){ 

     JSESSIONID = cookies.get(i).getValue(); 

     break; 

    } 

   } 

 return result;

 }

 return null;

 }

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
 

相關(guān)文章

最新評論