ios 三方登錄(qq、微信)

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

如有錯誤,望指正

小禮物走一走,來簡書關注我

贊賞支持

?ios隨筆

? 著作權歸作者所有

舉報文章

關注fjytqiu

寫了 14452 字,被 34 人關注,獲得了 84 個喜歡

喜歡


13

更多分享

被以下專題收入,發現更多相似內容

收入我的專題

ios開發整理

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為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智能路由,微代理,控制總線)。分布式系統的協調導致了樣板模式, 使用Spring Cloud開發人員可以快速地支持實現這些模式的服務和應用程序。他們將在任何分布式...

?卡卡羅2017

無標題文章

# 一度蜜v3.0協議 --- # 交互協議 [TOC] ## 協議說明 ### 請求參數 下表列出了v3.0版協議需要的內置請求參數,對于必選的參數在所有請求中都需要填寫 | 名稱 | 必選 | 類型 | 說明 | |---...

?c5e350bc5b40

如何使用 OAuth 2.0 將 LinkedIn 集成入 iOS 應用

作者:Gabriel Theodoropoulos,原文鏈接,原文日期:2016-1-3譯者:小鐵匠Linus;校對:千葉知風;定稿:小鍋 從很久以前開始,社交網絡就成為了我們每天生活的一部分了。同時,社交網絡也是我們程序員生活的一部分,絕大多數的應用都對進行了集成,用于接...

?梁杰_numbbbbb

孩子處在叛逆期怎么辦?

文/安羽心理咨詢 有些家長家里不管家里是否有財有勢,還是沒錢沒勢,總是想辦法幫助孩子擺平所有的事情,滿足孩子所有的要求,為孩子安排好一切,甚至可能現在大部分的努力都是為了讓孩子以后可以生活得更好。 但是卻發現孩子漸漸的不跟父母溝通了,孩子只會在想要東西的時候才會跟父母提要求...

?安羽心理

2017-05-25

好吧,第一次撞車,把整塊保險杠都掀了下來。 以后還是開慢點吧,別讓關心變成擔心。

?meet_again

《怦然心動》,總有細節令你心動

開年新讀了四本書:《我不是潘金蓮》、《怦然心動》、《月亮與六便士》和《二十年目睹之怪現狀》,都是值得推薦的好書。 聊聊《怦然心動》吧。讀的是中文電子版,書的封面上寫著一句:“你從未忘記過你的初戀。”用初戀情結進行兜售,其實是一個關于成長的美麗故事,所以這本書適宜的年齡跨度很...

?好報非非

大姑二姑

父親這一輩,兄妹三人,父親老大,兩個姑姑是他的妹妹。 大姑叫花彩芹,中等身材,長相漂亮,在農村,屬于能干聰明型的女子。 大姑是什么時候出嫁的,我沒記憶,只知道所嫁之家,離我家不遠,在長安東大鄉郭灣村,家庭殷實,生活富足,在困難時期,令人羨慕,村里人都說我...

?花智勇

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,517評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,087評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,521評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,493評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,207評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,603評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,624評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,813評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,364評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,110評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,305評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,874評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,532評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,953評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,209評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,033評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,268評論 2 375

推薦閱讀更多精彩內容