iOS中OAuth授权获取Access_Tolen
在所有快速登录中差不多采用同样的授权方式获取access_Token
(Oauth2.0
授权获取Access_Token
),今天以新浪微博获取Access_Token
:
1 成为为微博开发者
首先登录微博开放平台
http://open.weibo.com
先注册成为开发者,验证邮箱之后.
2 创建应用
点击
微链接-移动应用-立即接入-继续创建
.创建应用名称(最好和你工程名称相同).
创建完成之后
基本应用信息
系统自动为该应用生成的APPKey
和APPSecret
.并在应用信息的
高级信息
,设置授权回调页
地址Redirect_URI
.(随便填写,可以写百度"https://www.baidu.com")由于这里是手机客户端,而不是web应用,因此创建应用的时候,
Redirect_URI
可以随便写,但必须全局都使用同一个地址Redirect_URI
.取消授权回调页
也是随便填写.3 显示登录页面,请求用户授权:
点击文档-微博登陆-授权机制-接口;
-
2.必传参数
- client_id 申请应用时分配的AppKey
- redirect_uri 授权回调地址
3.完整的请求路径:https://api.weibo.com/oauth2/authorize?client_id=4067793982&redirect_uri=http://www.baidu.com
4.用户输入账号密码,授权成功后
1.会自动定位到回调地址
2.新浪会在回调地址的后面拼接一个code参数 (将来要利用code参数向新浪服务器换取一个access_token)
这个code可以在webView的代理方法中拿到.5.利用code参数向新浪服务器换取一个access_token
具体实现代码如下:
// "access_token" = "2.00vWf4GE3CDS8E082f1f060fSdU2jD"
// 一个accessToken对应着 1个用户 + 1个应用
#import "HWOAuthViewController.h"
#import "AFNetworking.h"
#import "HWTabBarController.h"
@interface HWOAuthViewController () <UIWebViewDelegate>
@property (weak, nonatomic) IBOutlet UIWebView *webView;
@end
@implementation HWOAuthViewController
- (void)viewDidLoad {
[super viewDidLoad];
NSURL *url = [NSURL URLWithString:@"https://api.weibo.com/oauth2/authorize?client_id=1281603749&redirect_uri=https://www.baidu.com"];
NSURLRequest *request = [NSURLRequest requestWithURL:url];
[self.webView loadRequest:request];
}
#pragma mark - <UIWebViewDelegate>
/**
* 每当webView想发送请求之前都会调用(能在这个方法中拦截webView的所有请求)
*
* @param request webView想发送的请求
*
* @return YES : 允许加载这个请求, NO : 禁止加载这个请求
*/
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
// 1.URL字符串
NSString *url = request.URL.absoluteString;
// 2.查找URL中是否有"code="
NSRange range = [url rangeOfString:@"code="];
if (range.length) { // 已经找到code=
// 3.截取code
NSString *code = [url substringFromIndex:range.location + range.length];
// 4.利用code换取access_token
[self accessTokenWithCode:code];
return NO;
}
return YES;
}
/**
* 利用code换取access_token
*/
- (void)accessTokenWithCode:(NSString *)code
{
// URL : https://api.weibo.com/oauth2/access_token
// 请求方式 : POST
/*请求参数
client_id 申请应用时分配的AppKey。
client_secret 申请应用时分配的AppSecret。
grant_type 请求的类型,填写authorization_code
code 调用authorize获得的code值。
redirect_uri 回调地址,需需与注册应用里的回调地址一致。
*/
/*返回结果
{
"access_token": "ACCESS_TOKEN",
"expires_in": 1234,
"remind_in":"798114",
"uid":"12341234"
}
*/
// 1.创建一个请求管理者
AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
// 2.拼接请求参数
NSMutableDictionary *params = [NSMutableDictionary dictionary];
params[@"client_id"] = @"1281603749";
params[@"client_secret"] = @"443af14f07509433acef44d9fc158e53";
params[@"grant_type"] = @"authorization_code";
params[@"code"] = code;
params[@"redirect_uri"] = @"https://www.baidu.com";
// 3.发送一个POST请求
[mgr POST:@"https://api.weibo.com/oauth2/access_token" parameters:params
success:^(AFHTTPRequestOperation *operation, NSDictionary *responseObject) {
// 沙盒路径
NSString *doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
NSString *path = [doc stringByAppendingPathComponent:@"account.plist"];
// 将服务器返回的字典(JSON)数据存储起来
[responseObject writeToFile:path atomically:YES];
// 切换到主控制器(获取到之后要跳转页面)
[UIApplication sharedApplication].keyWindow.rootViewController = [[HWTabBarController alloc] init];
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
HWLog(@"请求失败 - %@", error);
}];
}
@end