qq三方登錄
1.前往騰訊開放平臺注冊帳號并創建應用提交審核
1.1 創建應用(帳號的注冊此處不做說明)
1.1
1.2 選擇iOS,并留意APP ID;APP KEY(后面需要用到)
1.2
1.3 填寫相應的信息并保存、提交(一般來說這個審核幾個小時內就會通過)
1.3
1.4 審核通過后->管理中心->點擊已獲取QQ登錄能力的應用->點擊QQ登錄->填寫調試者qq
1.41
1.42
2. 導入SDK:?點我下載?,并進行相關配置
2.1 下載后將TencentOpenAPI.framework和TencentOpenApi_iOS_Bundle.bundle拖入你的項目
2.1
2.2 添加依賴庫
點擊Project navigator 點擊TARGETS -> General -> Linked Frameworks and Libraries->點擊加號添加
2.2
需要添加的依賴庫:
”Security.framework”;“libiconv.tbd”;“SystemConfiguration.framework”;“CoreGraphics.Framework”;“libsqlite3.tbd”;“CoreTelephony.framework”;“libstdc++.tbd”;“libz.tbd”。
2.3 修改配置屬性
點擊Project navigator 點擊TARGETS -> Build Settings ->Linking->Other Linker Flags->點擊加號添加屬性值“-fobjc-arc”
2.3
2.4 添加URL Scheme
點擊Project navigator 點擊TARGETS ->info ->URL type-> 添加URL type
Identifier 填寫:tencentopenapi
URL Scheme填寫: tencent +APP ID(APP ID: 從上文1.2中科獲得)
?? :你的APP ID是1234567 則填入tencent1234567
2.4
2.5 ios9以后,需要添加白名單
在info.plist文件中加入 LSApplicationQueriesSchemes
2.5
2.6 針對iOS9默認使用https,現在先還原成http請求方式
第一步:在plist中添加NSAppTransportSecurity項,此項為NSDictionary
第二步:在NSAppTransportSecurity下添加 NSAllowsArbitraryLoads類型為Boolean,value為YES
2.6
3.代碼區
3.1 在Appdelegate.m中
導入并重寫兩個方法
#import
- (BOOL)application:(UIApplication*)application openURL:(NSURL*)url sourceApplication:(NSString*)sourceApplication annotation:(id)annotation{return[TencentOAuth HandleOpenURL:url];}- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url{return[TencentOAuth HandleOpenURL:url];}
3.2 在ThirdLogin.m(用于封裝三方登錄的類)中
#import"ThirdLogin.h"#import#import"HttpClient.h"#define NAME @"name"#define PICTURE @"picture"#define OPENID @"openId"@interfaceThirdLogin(){? ? TencentOAuth *tencentOAuth;NSArray*permissions;}@property(copy,nonatomic)void(^success)(NSDictionary*result);@property(copy,nonatomic)void(^failure)(NSError*error);@end@implementationThirdLogin#pragma mark--------------------------------------------------------#pragma mark? qq三方登錄// 對外的api: 即點擊qq三方登錄按鈕,調這個方法- (void)qqLoginWithSuccess:(void(^)(NSDictionary*userInfo))success failure:(void(^)(NSError*error))failure {// 成功或失敗的回調block? ? self.success = [successcopy];self.failure = [failurecopy];//? 需要放在主線程中執行? dispatch_async(dispatch_get_main_queue(), ^{? ? ? tencentOAuth=[[TencentOAuth alloc]initWithAppId:@"1105549185"andDelegate:self];//? 設置需要的權限列表,此處盡量使用什么取什么。permissions= [NSArrayarrayWithObjects:kOPEN_PERMISSION_GET_USER_INFO,? ? ? ? ? ? ? ? ? ? ? kOPEN_PERMISSION_GET_SIMPLE_USER_INFO,@"add_t",nil];? ? ? ? [tencentOAuth authorize:permissions];? ? });}- (BOOL)tencentNeedPerformIncrAuth:(TencentOAuth *)tencentOAuth withPermissions:(NSArray*)permissions {returnYES;}#pragma mark -- TencentSessionDelegate//登陸完成調用- (void)tencentDidLogin{if(tencentOAuth.accessToken &&0!= [tencentOAuth.accessToken length]) {//? 記錄登錄用戶的OpenID、Token以及過期時間[tencentOAuth getUserInfo];? ? }else{? ? ? ? [selffailureWith:@"未授權成功"];? ? }}//非網絡錯誤導致登錄失敗:-(void)tencentDidNotLogin:(BOOL)cancelled{if(cancelled){? ? ? ? [selffailureWith:@"用戶取消登錄"];? ? }else{? ? ? ? [selffailureWith:@"登錄失敗"];? ? }}// 網絡錯誤導致登錄失敗:-(void)tencentDidNotNetWork {? ? [selffailureWith:@"網絡錯誤"];}- (void)tencentDidLogout{//? NSLog(@"登出");}-(void)getUserInfoResponse:(APIResponse *)response {NSDictionary*result = [NSDictionarydictionaryWithObjectsAndKeys:[response.jsonResponse objectForKey:@"nickname"], [response.jsonResponse objectForKey:@"figureurl_qq_2"], tencentOAuth.openId, NAME, PICTURE, OPENID,nil];self.success(result);}- (void)failureWith:(NSString*)domin {NSError*error = [NSErrorerrorWithDomain:domin code:0userInfo:nil];self.failure(error);}
補充:
登陸成功的方法里面調用[tencentOAuth getUserInfo];然后系統會調用一個方法(我們需要提前實現)-(void)getUserInfoResponse:(APIResponse*)response{}
在getUserInfoResponse中可以得到所需要的用戶信息
微信三方登錄
1.前往微信開放平臺注冊帳號并創建應用提交審核
在微信開放平臺注冊開發者帳號并創建應用,審核通過后,獲得相應的AppID和AppSecret,基本流程和qq三方登錄類似(這里不做說明)
2. 導入SDK:?點我下載?,并進行相關配置
2.1 下載后將下面文件導入工程目錄中
2.1
2.2 添加依賴庫
2.2
需要添加的依賴庫:
“SystemConfiguration.framework”;“CoreTelephony.framework”;“libsqlite3.0.tbd”;“libstdc++.tbd”;“libz.tbd”;"libWeChatSDK.a"
2.3 添加URL Scheme
點擊Project navigator 點擊TARGETS ->info ->URL type-> 添加URL type
Identifier 填寫:可自定義
URL Scheme填寫: APP ID(APP ID: 從上文1.2中科獲得)
?? :你的APP ID是wx1234567 則填入wx1234567
2.3
2.4 ios9以后,需要添加白名單
在info.plist文件中加入 LSApplicationQueriesSchemes
2.4
2.5 針對iOS9默認使用https,現在先還原成http請求方式
第一步:在plist中添加NSAppTransportSecurity項,此項為NSDictionary
第二步:在NSAppTransportSecurity下添加 NSAllowsArbitraryLoads類型為Boolean,value為YES
need-to-insert-img
2.6
3.代碼區
3.1 在Appdelegate.m中
#import"AppDelegate.h"#import"WXApi.h"#import"ThirdLogin.h"http://? 用于封裝三方登錄的類@interfaceAppDelegate()@end@implementationAppDelegate- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions {//? @"wx1235467" : APP ID[WXApi registerApp:@"wx1235467"withDescription:@"Wechat"];returnYES;}// 這個方法是用于從微信返回第三方App- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url {//? 這里我的代理設置的是ThirdLogin對象,有的直接設self(即AppDelegate)[WXApi handleOpenURL:url delegate:[ThirdLogin shareThirdLogin]];returnYES;}
3.1 在ThirdLogin.m中
#import"ThirdLogin.h"#import"HttpClient.h"#import"WXApi.h"#define NAME @"name"#define PICTURE @"picture"#define OPENID @"openId"@interfaceThirdLogin()@property(copy,nonatomic)void(^success)(NSDictionary*result);@property(copy,nonatomic)void(^failure)(NSError*error);@end#pragma mark--------------------------------------------------------#pragma mark? 微信三方登錄//? 對外的api: 即點擊微信三方登錄按鈕,調這個方法- (void)weixinLoginWithsuccess:(void(^)(NSDictionary*userInfo))success failure:(void(^)(NSError*error))failure {//? 成功或失敗的回調blockself.success = [successcopy];self.failure = [failurecopy];NSString*accessToken = [[NSUserDefaultsstandardUserDefaults] objectForKey:WX_ACCESS_TOKEN];NSString*openID = [[NSUserDefaultsstandardUserDefaults] objectForKey:WX_OPEN_ID];// 如果已經請求過微信授權登錄,那么考慮用已經得到的access_tokenif(accessToken && openID) {? ? ? ? AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];NSString*refreshToken = [[NSUserDefaultsstandardUserDefaults] objectForKey:WX_REFRESH_TOKEN];NSString*refreshUrlStr = [NSStringstringWithFormat:@"%@/oauth2/refresh_token?appid=%@&grant_type=refresh_token&refresh_token=%@", WX_BASE_URL, WXPatient_App_ID, refreshToken];? ? ? ? [manager GET:refreshUrlStr parameters:nilsuccess:^(AFHTTPRequestOperation *operation,idresponseObject) {NSLog(@"請求reAccess的response = %@", responseObject);NSDictionary*refreshDict = [NSDictionarydictionaryWithDictionary:responseObject];NSString*reAccessToken = [refreshDict objectForKey:WX_ACCESS_TOKEN];// 如果reAccessToken為空,說明reAccessToken也過期了,反之則沒有過期if(reAccessToken) {// 更新access_token、refresh_token、open_id[[NSUserDefaultsstandardUserDefaults] setObject:reAccessToken forKey:WX_ACCESS_TOKEN];? ? ? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] setObject:[refreshDict objectForKey:WX_OPEN_ID] forKey:WX_OPEN_ID];? ? ? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] setObject:[refreshDict objectForKey:WX_REFRESH_TOKEN] forKey:WX_REFRESH_TOKEN];? ? ? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] synchronize];// reAccessToken不為空說明未超時,直接執行wechatLoginByRequestForUserInfo方法獲取數據if([selfrespondsToSelector:@selector(wechatGetUserInfo)]) {? ? ? ? ? ? ? ? ? ? [selfwechatGetUserInfo];? ? ? ? ? ? ? ? }? ? ? ? ? ? }else{//? refresh_token失效的后需重新授權[selfwechatLogin];? ? ? ? ? ? }? ? ? ? } failure:^(AFHTTPRequestOperation *operation,NSError*error) {? ? ? ? ? ? [selffailureWith:@"請求失敗"];? ? ? ? }];? ? }else{//? 本地保存的accessToken、openID為空,說明是第一次登陸,或者數據遺失[selfwechatLogin];? ? }}- (void)wechatLogin {if([WXApi isWXAppInstalled]) {? ? ? ? SendAuthReq *req = [[SendAuthReq alloc] init];? ? ? ? req.scope =@"snsapi_userinfo";? ? ? ? req.state =@"App";? ? ? ? [WXApi sendReq:req];? ? }else{//把微信登錄的按鈕隱藏掉。}}- (void)wechatGetUserInfo {? ? AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];NSString*accessToken = [[NSUserDefaultsstandardUserDefaults] objectForKey:WX_ACCESS_TOKEN];NSString*openID = [[NSUserDefaultsstandardUserDefaults] objectForKey:WX_OPEN_ID];NSString*userUrlStr = [NSStringstringWithFormat:@"%@/userinfo?access_token=%@&openid=%@", WX_BASE_URL, accessToken, openID];// 請求用戶數據[manager GET:userUrlStr parameters:nilsuccess:^(AFHTTPRequestOperation *operation,idresponseObject) {NSDictionary*result = [NSDictionarydictionaryWithObjectsAndKeys:responseObject[@"nickname"], responseObject[@"headimgurl"], openID, NAME, PICTURE, OPENID,nil];self.success(result);? ? ? ? ? ? } failure:^(AFHTTPRequestOperation *operation,NSError*error) {? ? ? ? [selffailureWith:@"請求失敗"];? ? }];}/*====================delegate方法=====================*/-(void) onResp:(BaseResp*)resp{? ? SendAuthResp *temp = (SendAuthResp *)resp;? ? AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];NSString*accessUrlStr = [NSStringstringWithFormat:@"%@/oauth2/access_token?appid=%@&secret=%@&code=%@&grant_type=authorization_code", WX_BASE_URL, WXPatient_App_ID, WXPatient_App_Secret, temp.code];? ? [manager GET:accessUrlStr parameters:nilsuccess:^(AFHTTPRequestOperation *operation,idresponseObject) {NSDictionary*accessDict = [NSDictionarydictionaryWithDictionary:responseObject];NSString*accessToken = [accessDict objectForKey:WX_ACCESS_TOKEN];NSString*openID = [accessDict objectForKey:WX_OPEN_ID];NSString*refreshToken = [accessDict objectForKey:WX_REFRESH_TOKEN];// 本地持久化,以便access_token的使用、刷新或者持續if(accessToken && ![accessToken isEqualToString:@""] && openID && ![openID isEqualToString:@""]) {? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] setObject:accessToken forKey:WX_ACCESS_TOKEN];? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] setObject:openID forKey:WX_OPEN_ID];? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] setObject:refreshToken forKey:WX_REFRESH_TOKEN];? ? ? ? ? ? [[NSUserDefaultsstandardUserDefaults] synchronize];// 命令直接同步到文件里,來避免數據的丟失}? ? ? ? [selfwechatGetUserInfo];? ? } failure:^(AFHTTPRequestOperation *operation,NSError*error) {? ? ? ? [selffailureWith:@"請求失敗"];? ? }];}
補充:
? ? access_token? 接口調用憑證
? ? refresh_token? 用戶刷新access_token
? ? openid 授權用戶唯一標識
access_token有效期為2小時,當再次登陸時通過refresh_token進行刷新,有兩種情況:
access_token未超時,access_token不會改變,但超時時間會刷新,相當于續期access_token。
超時,那么會獲取一個新的access_token,新的超時時間;
注:refresh_token擁有有效期:30天
Comments
如有錯誤,望指正
小禮物走一走,來簡書關注我
贊賞支持
? 著作權歸作者所有
寫了 14452 字,被 34 人關注,獲得了 84 個喜歡
被以下專題收入,發現更多相似內容
ios開發整理
注意:代碼自己動手寫,不要復制! GitHub 一、接入微信第三方登錄準備工作。 移動應用微信登錄是基于OAuth2.0協議標準構建的微信OAuth2.0授權登錄系統。 在進行微信OAuth2.0授權登錄接入之前,在微信開放平臺注冊開發者帳號,并擁有一個已審核通過的移動應用...
?大沖哥
iOS -第三方登錄(SSO授權)原生接入(微博,QQ,微信)
原文網址:http://www.lxweimin.com/p/7e3c5fc31708 0.demo說明別的先不說demo地址如下1.demo下載下來以后,請在WTThirdPartyLoginManager里面將自己的個平臺的app key寫上去.2.URL Schemes...
?楓之葉_小乙哥
Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智能路由,微代理,控制總線)。分布式系統的協調導致了樣板模式, 使用Spring Cloud開發人員可以快速地支持實現這些模式的服務和應用程序。他們將在任何分布式...
?卡卡羅2017
# 一度蜜v3.0協議 --- # 交互協議 [TOC] ## 協議說明 ### 請求參數 下表列出了v3.0版協議需要的內置請求參數,對于必選的參數在所有請求中都需要填寫 | 名稱 | 必選 | 類型 | 說明 | |---...
?c5e350bc5b40
如何使用 OAuth 2.0 將 LinkedIn 集成入 iOS 應用
作者:Gabriel Theodoropoulos,原文鏈接,原文日期:2016-1-3譯者:小鐵匠Linus;校對:千葉知風;定稿:小鍋 從很久以前開始,社交網絡就成為了我們每天生活的一部分了。同時,社交網絡也是我們程序員生活的一部分,絕大多數的應用都對進行了集成,用于接...
?梁杰_numbbbbb
文/安羽心理咨詢 有些家長家里不管家里是否有財有勢,還是沒錢沒勢,總是想辦法幫助孩子擺平所有的事情,滿足孩子所有的要求,為孩子安排好一切,甚至可能現在大部分的努力都是為了讓孩子以后可以生活得更好。 但是卻發現孩子漸漸的不跟父母溝通了,孩子只會在想要東西的時候才會跟父母提要求...
?安羽心理
好吧,第一次撞車,把整塊保險杠都掀了下來。 以后還是開慢點吧,別讓關心變成擔心。
?meet_again
開年新讀了四本書:《我不是潘金蓮》、《怦然心動》、《月亮與六便士》和《二十年目睹之怪現狀》,都是值得推薦的好書。 聊聊《怦然心動》吧。讀的是中文電子版,書的封面上寫著一句:“你從未忘記過你的初戀。”用初戀情結進行兜售,其實是一個關于成長的美麗故事,所以這本書適宜的年齡跨度很...
?好報非非
父親這一輩,兄妹三人,父親老大,兩個姑姑是他的妹妹。 大姑叫花彩芹,中等身材,長相漂亮,在農村,屬于能干聰明型的女子。 大姑是什么時候出嫁的,我沒記憶,只知道所嫁之家,離我家不遠,在長安東大鄉郭灣村,家庭殷實,生活富足,在困難時期,令人羨慕,村里人都說我...
?花智勇