android登录Web以及登录保持,cookie管理相关

对于登录功能本身没有任何特别,使用httpclient向服务器post用户名密码即可。
但是为了保持登录的状态(在各个Activity之间切换时要让网站知道用户一直是处于登录的状态)就需要进行cookie的读写。


httpclient相当强大,读写cookie非常容易:
CookieStore cookies=((AbstractHttpClient)client).getCookieStore();//读cookie
((AbstractHttpClient) client).setCookieStore(cookies);//写cookie


另外的一个问题是,为了在各个activity之间使用一个共通的cookie,需要一个全局变量来解决问题。对于java来说,可以使用静态类,但是对于android来说,更符合android结


构的作法是使用拥有这些activity的application类:
首先声明一个application类用来存取cookie:
public class myApp extends Application {


    private CookieStore cookies;   
    public CookieStore getCookie(){    
        return cookies;
    }
    public void setCookie(CookieStore cks){
        cookies = cks;
    }
}
另外,要在AndroidManifest.xml文件中将上面声明的这个类绑定到包含所有activity的application上,方法是为application标签加 android:name=".myApp"
这样就可以在Activity中使用这个“全局变量”了:
//设置cookie
myApp appCookie = ((myApp)getApplication());    
appCookie.setCookie(cookies);
//读取cookie
myApp appCookie = ((myApp)getApplicationContext());
cookies = appCookie.getCookie();


经过以上的步骤,android程序完成一个Web登录后就可以保持登录的状态了。


ps.
从一个httpclient取得statuscode的方法:
HttpResponse response = client.execute(mypost);
int statuscode = response.getStatusLine().getStatusCode();
 
 
 

做的一个是要登录自己的图书馆账号,用于查看自己所借阅的书籍,

看了一下图书馆的代码,发现是POST用户名和密码,

而在代码实现主要有两个难点:一、保存账号密码 二、保存Cookie

那么 ,第一个可以使用之前提到过的Sharedpreference ,每次就直接从sharedpreference里获取账号名和密码就可以了,不需要每次都输入

 

第二个怎么获得服务器的cookie呢,知道这次的session id

通过Httpclient 中的getcookiestore

 
List<Cookie> cookies = httpclient.getCookieStore().getCookies();    
if (cookies.isEmpty()) {    
Log.i(TAG, "-------Cookie NONE---------");    
} else {                   
for (int i = 0; i < cookies.size(); i ) {    
//保存cookie     
cookie = cookies.get(i);    
Log.d(TAG, cookies.get(i).getName() "=" cookies.get(i).getValue() );    

 


获得了session id后,怎么再添加到我们的POST或者GET请求里面呢,

 
HttpPost httpPost = new HttpPost(访问地址);  
httpPost.setHeader("Cookie", "JSESSIONID=" + 我们在静态变量里存放的SessionId);  
HttpResponse httpResponse = httpclient.execute(httpPost); 
 


 

 
HttpGet request = new HttpGet(url+"?"+Params);  
        request.setHeader("Cookie",Sessionid); 
 

  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
根据提供的引用内容,uni-app是一个使用Vue.js开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、AndroidWeb以及各种小程序等多个平台\[3\]。在uni-app中,可以通过调用uni.login()获取登录用户的code,然后将code作为参数传递给后端接口,以获取SessionKey和OpenId进行存储\[1\]。对于抖音登录cookie的获取,需要调用抖音的登录接口,并将获取到的用户信息和存储的OpenId作为参数传递给后端自己编写的登录接口,以获取cookie等信息完成登录\[1\]。请注意,具体的实现细节可能需要根据抖音的开发文档和后端接口的要求进行调整。 #### 引用[.reference_title] - *1* [uni-app授权登录,获取用户信息及用户手机号](https://blog.csdn.net/iblackboy/article/details/121854513)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Uniapp uni-app学习与快速上手](https://blog.csdn.net/Beatingworldline/article/details/131225898)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值