【iOS】項(xiàng)目中集成QQ登錄與分享

QQ

前言

在很多項(xiàng)目中都會(huì)使用第三方登錄,登錄方式大致都是QQ、微信、微博這三個(gè)爸爸。下面的文章將會(huì)簡(jiǎn)單介紹一下個(gè)人在項(xiàng)目中集成QQ登錄與分享功能的流程以及在過(guò)程中遇到的問(wèn)題。

準(zhǔn)備工作

  1. 首先需要在騰訊開放平臺(tái)申請(qǐng)成為應(yīng)用開發(fā)者。
    我注冊(cè)的是個(gè)人開發(fā)者,需要提交的材料包括姓名、手機(jī)號(hào)、身份證號(hào)、郵箱、居住地址,最重要的是個(gè)人手持身份證的照片(大小限制在2M以內(nèi))
  2. 下載SDK
    SDK

    iOS SDK包中帶有兩個(gè)文件:
    TencentOpenAPI.framework打包了iOS SDK的頭文件定義和具體實(shí)現(xiàn)。
    TencentOpenApi_iOS_Bundle.bundle 打包了iOS SDK需要的資源文件。
SDK中文件

SDK環(huán)境搭建

開發(fā)時(shí),我使用的是Xcode 8以及iOS 8+環(huán)境。

  1. TencentOpenAPI.frameworkTencentOpenApi_iOS_Bundle.bundle拖入到工程
  2. 添加依賴庫(kù)
添加依賴庫(kù)
  1. 關(guān)聯(lián)TencentOpenApi_iOS_Bundle.bundle文件
關(guān)聯(lián)Bundle文件
  1. 在工程配置中的“Build Settings”一欄中找到“Linking”配置區(qū),給“Other Linker Flags”配置項(xiàng)添加屬性值“-fobjc-arc”。
修改必要屬性
  1. 配置URL Scheme
配置URL Scheme
  1. 在iOS9.0以后,需要添加白名單
    在info.plist文件中加入 LSApplicationQueriesSchemes。SDK中demo下有該字段,可以去復(fù)制。
白名單

接入代碼

AppDelegate中代碼

  1. 引入頭文件并遵循代理
頭文件和代理
  1. 處理跳轉(zhuǎn)請(qǐng)求
處理跳轉(zhuǎn)請(qǐng)求

ViewController.m中代碼

  1. QQ登錄
    // appID是在騰訊開放平臺(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方法中編寫下述代碼:
    - (void)tencentDidLogin {
    // 判斷是否獲取到Access Token憑證,用于后續(xù)訪問(wèn)各開發(fā)接口,例如:發(fā)表說(shuō)說(shuō)到QQ空間、獲取用戶QQ控件相冊(cè)列表等
    if (_loginOAuth.accessToken) {
    // 獲取用戶信息
    [_loginOAuth getUserInfo];
    }
    }
    接下來(lái),在getUserInfoResponse:方法中獲取用戶信息:
    - (void)getUserInfoResponse:(APIResponse *)response {
    NSLog(@"用戶信息:%@",response);
    }

  2. 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:@"很好用的喲我開發(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。

如有不正,感謝指出。
感謝開源!??!

引用文檔

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容