#iOS开发笔记#OAuth2Client refresh token 失败的原因

本文记录了在使用OAuth2Client(版本1.2.8)进行iOS开发时遇到的refresh token失效问题。当超过expire time后,library未能自动刷新token。通过Wireshark监控发现,问题出在NXOAuth2Connection.m的-createConnection方法。在expire时间前10秒或后10秒发送请求均正常,但在10秒内则导致失败,且无错误修正机制。解决方案是将刷新时间提前10秒,确保refresh token的成功执行。经测试,修改后问题得到解决。
摘要由CSDN通过智能技术生成

截至2015年1月27日,所采用版本为1.2.8,源地址:https://github.com/nxtbgthng/OAuth2Client

开源OAuth2.0 在ios上面的library OAuth2Client不算是一个好用的库,很多东西需要手工改,不过还好它底层的东西写的不错,给自己减轻了工作量。


但在最近测试refresh token的时候,却出现了一个让人非常抓狂的问题,就是有时候无法自动refresh token。


As we all know,从服务器获取token的时候,除了拿到一个access token之外,还会拿到refresh token和expire time。意思是如果超过了expire time,就用refresh token重新去获取token。但是问题就出来在,我第一次测试的时候,用虚拟机,wireshark监控,非常满意,超过expire time之后的第一次网络请求,它会自动先请求一次token。可是后来在真机上测试,加了一个每10秒上传一次位置的功能(同样需要token),却出现了问题,不能自动refresh。


后来再次在虚拟机上测试时,也是时好时坏,有时候能refresh,有时候却压根没有。后来自己排查,发现问题出现在OAuth2Client - Connection - NXOAuth2Connection.m中的-createConnection方法,原文如下:

- (NSURLConnection *)createConnection;
{
    // if 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值