您好,登錄后才能下訂單哦!
前言
最近因?yàn)楣ぷ鞯男枰?,要?shí)現(xiàn)一個(gè)功能,就是需要通過(guò)發(fā)送短信進(jìn)行注冊(cè),現(xiàn)在想把短信驗(yàn)證碼放到服務(wù)器的session值中,當(dāng)客戶端收到短信并提交短信碼時(shí)由asp.net服務(wù)端進(jìn)行判斷,那么如何共享這個(gè)session那么需要在android客戶端中添加幾行代碼。
實(shí)現(xiàn)方法
如下操作。第一次數(shù)據(jù)請(qǐng)求時(shí)就獲取這個(gè)cookie的名稱并且得到這個(gè)cookie的值,這個(gè)即是sessionid的值并保存在一個(gè)靜態(tài)變量中,然后在第二次請(qǐng)求數(shù)據(jù)的時(shí)候要將這個(gè)sessionid一并放在Cookie中發(fā)給服務(wù)器,服務(wù)器則是通過(guò)這個(gè)sessionid來(lái)識(shí)別究竟是那個(gè)客戶端在請(qǐng)求數(shù)據(jù)的,在asp.net中這個(gè)sessionid的名字叫做ASP.NET_SessionId,當(dāng)然我們可以從程序中獲取。
如下代碼:
//獲取服務(wù)端的這個(gè)sessionid的名稱 /* 獲取cookieStore */ List<Cookie> cookies = cookieStore.getCookies(); for(int i=0;i<cookies.size();i++){ String sessionid = cookies.get(i).getName(); 從這里可以獲取到這個(gè)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(); //這個(gè)即為sessionid的值 break; } }
完整的httputils代碼如下:
public static DefaultHttpClient httpClient = null; private static String JSESSIONID; //定義一個(gè)靜態(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è)置連接超時(shí) HttpConnectionParams.setSoTimeout(params, 15000);//設(shè)置請(qǐng)求超時(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),通過(guò)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請(qǐng)求方式 HttpPost post = new HttpPost(url); HttpParams cparams = new BasicHttpParams(); HttpConnectionParams.setConnectionTimeout(cparams, 10000);//設(shè)置連接超時(shí) HttpConnectionParams.setSoTimeout(cparams, 15000);//設(shè)置請(qǐng)求超時(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來(lái)保存要傳遞的參數(shù),可以使用BasicNameValuePair來(lái)構(gòu)造一個(gè)要被傳遞的參數(shù) //通過(guò)add添加這個(gè)參數(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); //請(qǐng)求httpRequest post.setEntity(httpEntity); //發(fā)送POST請(qǐng)求并獲取響應(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就是通過(guò)上面的方法獲取到。 */ 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é)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。