客户端登录添加token机制

       手机APP登录的时候发送用户名和密码到服务器,服务器验证用户名和密码,
如果成功,以某种方式比如随机生成32位的字符串作为token,存储到服务器中(创建Table),
并返回token到客户端,以后客户端再请求时,验证该token就可以了。将客户端保存的token与服务器存储的token比对,然后服务器端验证token,成功返回所需要的结果,失败返回错误信息,让其重新登录。

其中服务器上token设置一个有效期,每次客户端请求的时候都验证token和有效期。

这里,保存在客户端的token存在哪里?

本人分析了android存储数据的五种方式,

有两种可选:

1、使用sharedPreferences存储token。sharedPreferences可用于保存少量数据,应用程序的各种配置信息以及口令密码等,而且我们的用户名也保存在这里(本项目使用)。

2、sqlite。需要创建数据库、表等。

最终选择了方法1。

就本项目来说,在登录的相关部分加上

String jsonDatas =  msg.obj.toString().trim();	
Gson gson = USAUtil.getGson();
TokenUtils accesstoken = gson.fromJson(jsonDatas,TokenUtils.class );
用于解析token,其中TokenUtils是set、get方法的工具类。

然后再保存token到sharedPreferences就可以了,

saveAccessToken(XXX.this, accesstoken.getToken());
具体的实现就不多说了。
如何有什么不合理的地方,还请指出!



  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值