前言
在很多項(xiàng)目中都會(huì)使用第三方登錄,登錄方式大致都是QQ、微信、微博這三個(gè)爸爸。下面的文章將會(huì)簡(jiǎn)單介紹一下個(gè)人在項(xiàng)目中集成QQ登錄與分享功能的流程以及在過(guò)程中遇到的問(wèn)題。
準(zhǔn)備工作
- 首先需要在騰訊開(kāi)放平臺(tái)申請(qǐng)成為應(yīng)用開(kāi)發(fā)者。
我注冊(cè)的是個(gè)人開(kāi)發(fā)者,需要提交的材料包括姓名、手機(jī)號(hào)、身份證號(hào)、郵箱、居住地址,最重要的是個(gè)人手持身份證的照片(大小限制在2M以內(nèi)) - 下載SDK
SDK
iOS SDK包中帶有兩個(gè)文件:
TencentOpenAPI.framework打包了iOS SDK的頭文件定義和具體實(shí)現(xiàn)。
TencentOpenApi_iOS_Bundle.bundle 打包了iOS SDK需要的資源文件。
SDK環(huán)境搭建
開(kāi)發(fā)時(shí),我使用的是Xcode 8以及iOS 8+環(huán)境。
- 將TencentOpenAPI.framework和TencentOpenApi_iOS_Bundle.bundle拖入到工程
- 添加依賴庫(kù)
- 關(guān)聯(lián)TencentOpenApi_iOS_Bundle.bundle文件
- 在工程配置中的“Build Settings”一欄中找到“Linking”配置區(qū),給“Other Linker Flags”配置項(xiàng)添加屬性值“-fobjc-arc”。
- 配置URL Scheme
- 在iOS9.0以后,需要添加白名單
在info.plist文件中加入 LSApplicationQueriesSchemes。SDK中demo下有該字段,可以去復(fù)制。
接入代碼
AppDelegate中代碼
- 引入頭文件并遵循代理
- 處理跳轉(zhuǎn)請(qǐng)求
ViewController.m中代碼
-
QQ登錄
// appID是在騰訊開(kāi)放平臺(tái)創(chuàng)建應(yīng)用所分配的
TencentOAuth loginOAuth = [[TencentOAuth alloc] initWithAppId:appID andDelegate:self];
NSArray permissions = @[kOPEN_PERMISSION_GET_SIMPLE_USER_INFO, kOPEN_PERMISSION_ADD_SHARE, kOPEN_PERMISSION_GET_INFO, kOPEN_PERMISSION_GET_USER_INFO];
[loginOAuth authorize:permissions];
permissions
是請(qǐng)求權(quán)限類型數(shù)組,權(quán)限內(nèi)容如下圖:
權(quán)限
請(qǐng)求登錄后,會(huì)跳轉(zhuǎn)到手機(jī)QQ獲取權(quán)限,之后可以在回調(diào)代理中處理登錄狀態(tài)
/
* 登錄成功后的回調(diào)
*/
- (void)tencentDidLogin;/** * 登錄失敗后的回調(diào) * \param cancelled 代表用戶是否主動(dòng)退出登錄 */ - (void)tencentDidNotLogin:(BOOL)cancelled; /** * 登錄時(shí)網(wǎng)絡(luò)有問(wèn)題的回調(diào) */ - (void)tencentDidNotNetWork;
QQ登錄成功后,如果想要獲取QQ用戶信息,則可在
tencentDidLogin
方法中編寫(xiě)下述代碼:
- (void)tencentDidLogin {
// 判斷是否獲取到Access Token憑證,用于后續(xù)訪問(wèn)各開(kāi)發(fā)接口,例如:發(fā)表說(shuō)說(shuō)到QQ空間、獲取用戶QQ控件相冊(cè)列表等
if (_loginOAuth.accessToken) {
// 獲取用戶信息
[_loginOAuth getUserInfo];
}
}
接下來(lái),在getUserInfoResponse:
方法中獲取用戶信息:
- (void)getUserInfoResponse:(APIResponse *)response {
NSLog(@"用戶信息:%@",response);
} QQ分享
QQ分享可以分享給好友,也可以分享到QQ空間。
- 分享URL給好友
// 初始化授權(quán)登錄對(duì)象
_oauth = [[TencentOAuth alloc] initWithAppId:appid andDelegate:self];
QQApiURLObject *urlObject = [QQApiURLObject objectWithURL:[NSURL URLWithString:@"https://itunes.apple.com/cn/app/id1223932262?mt=8"] title:@"團(tuán)組發(fā)票管理" description:@"很好用的喲我開(kāi)發(fā)的喲哈哈哈哈" previewImageData:UIImageJPEGRepresentation([UIImage imageNamed:@"test"], 1) targetContentType:QQApiURLTargetTypeNews];
SendMessageToQQReq *req = [SendMessageToQQReq reqWithContent:urlObject];
// 分享給好友
[QQApiInterface sendReq:req]; - 分享到QQ空間
_oauth = [[TencentOAuth alloc] initWithAppId:appid andDelegate:self];
QQApiTextObject *txtObj = [QQApiTextObject objectWithText:@"這是一段文字喲"];
SendMessageToQQReq *req = [SendMessageToQQReq reqWithContent:txtObj];
//將內(nèi)容分享到qq
QQApiSendResultCode sent = [QQApiInterface SendReqToQZone:req];
其他功能
SDK中還可以實(shí)現(xiàn)其他功能,在這里不一一詳述,有需求大家可以仔細(xì)閱讀文檔,或者查看官方Demo中的API。
如有不正,感謝指出。
感謝開(kāi)源?。。?/strong>