ios配置QQSdk,本文只講解配置的核心部分,包括登錄和分享琅摩,詳細(xì)方法請看官網(wǎng)
1.配置Xcode項(xiàng)目
1.1配置Associated Domains铁孵,不要前面的https://,后面到com就行不用斜杠/
image.png
1.2配置文件apple-app-site-association
1.2.1details中配置數(shù)組是為了配置多個app房资,從而多個app可以使用一個文件即可蜕劝;
1.2.2其中paths為可以打開app的路徑,配置格式如下轰异,因?yàn)閝q回調(diào)app的時候路徑就是這樣岖沛,這樣配置只有鏈接為:https://Associated Domains/qq_conn/你的qq appid/...的時候才能打開app;
1.2.3 該文件放到服務(wù)器(Associated Domains)的根目錄下或者根目錄的.well-known目錄下搭独,配置成功在瀏覽器輸入https://Associated Domains/apple-app-site-association可以下載該文件
(可參考微信配置:https://help.wechat.com/apple-app-site-association)
{
"applinks": {
"apps": [],
"details": [{
"appID": "team id.bundle id",
"paths": ["/qq_conn/你的qq appid/*"]
}]
}
}
1.3qq互聯(lián)應(yīng)用配置,universal link 只需為你xcode里面配置的Associated Domains,因?yàn)閝q回調(diào)到qq的時候會自動帶上路徑:/qq_conn/你的qq appid/
image.png
1.4xcode項(xiàng)目導(dǎo)入qqSDK婴削,具體步驟看官方即可,注意:
1.4.1導(dǎo)入頭文件的時候只能導(dǎo)入戳稽,否則會報(bào)錯:
#import <TencentOpenAPI/TencentOpenApiUmbrellaHeader.h>
1.4.2注冊app
self.oauth = [[TencentOAuth alloc] initWithAppId:kQQAppid andUniversalLink:@"https://Associated Domains/qq_conn/你的qq appid" andDelegate:self];
1.4.3發(fā)起授權(quán)登錄和分享
// 登錄
if ([TencentOAuth iphoneQQInstalled]) {
NSArray *permissions = [NSArray arrayWithObjects:
kOPEN_PERMISSION_GET_USER_INFO,
kOPEN_PERMISSION_GET_SIMPLE_USER_INFO,
kOPEN_PERMISSION_ADD_ALBUM,
nil];
[self.oauth authorize:permissions];
}
// 分享
QQApiTextObject *txtObj = [QQApiTextObject objectWithText:text];
SendMessageToQQReq *req = [SendMessageToQQReq reqWithContent:txtObj];
//將內(nèi)容分享到
if (type == 0) {
QQApiSendResultCode sent = [QQApiInterface sendReq:req];
}
else
{
[txtObj setCflag:kQQAPICtrlFlagQZoneShareOnStart];
QQApiSendResultCode sent = [QQApiInterface SendReqToQZone:req];
}
1.4.4處理回調(diào)
//需要在appDelegate.m文件中實(shí)現(xiàn)如下:
// Universal Links打開app
-(BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void(^)(NSArray<id<UIUserActivityRestoring>> * __nullable restorableObjects))restorationHandler API_AVAILABLE(ios(8.0))
{
// qqsdk配置回調(diào)
if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
if ([TencentOAuth CanHandleUniversalLink:userActivity.webpageURL]) {
// qq分享
BOOL flag = [QQApiInterface handleOpenUniversallink:url delegate:self];
if (!flag) {
// qq登錄
return [TencentOAuth HandleUniversalLink:url];
}
return flag;
}
}
// 微信sdk回調(diào) 如果還有其他的需要加入判斷
/**
if ([userActivity.activityType isEqualToString:NSUserActivityTypeBrowsingWeb]) {
if ([userActivity.webpageURL.description containsString:WeChatAPPKEY]) {
return [WXApi handleOpenUniversalLink:userActivity delegate:self];
}
}
*/
return [WXApi handleOpenUniversalLink:userActivity delegate:self];
}
// ios9以后調(diào)用
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options NS_AVAILABLE_IOS(9_0){
if ([TencentOAuth CanHandleOpenURL:url]) {
// qq登錄
return [TencentOAuth HandleOpenURL:url] ;
}
else if ([url.absoluteString rangeOfString:@"response_from_qq"].location != NSNotFound) {
// qq分享
return [QQApiInterface handleOpenURL:url delegate:[DJQQManager manager]];
}
// 微信登錄
// else if ([url.host isEqualToString:@"oauth"]) {
return [WXApi handleOpenURL:url delegate:self];
// }
return true;
}
// 分享回調(diào)
#pragma mark - QQApiInterfaceDelegate
-(void)onResp:(QQBaseResp *)resp
{
if (resp.type == ESENDMESSAGETOQQRESPTYPE) { // 分享
if ([resp isKindOfClass:[SendMessageToQQResp class]]) {
SendMessageToQQResp *response = (SendMessageToQQResp *)resp;;
if ([response.result isEqualToString:@"0"]) {
NSLog(@"分享成功");
[self showToast:@"分享成功"];
} else {
NSLog(@"分享失敗");
[self showToast:@"分享失敗"];
}
}
}
}
// 授權(quán)登錄回調(diào)
#pragma mark - TencentSessionDelegate
/**
* 登錄成功后的回調(diào)
*/
- (void)tencentDidLogin
{
if (self.oauth.accessToken.length > 0) {
// 獲取用戶信息
[self.oauth getUserInfo];
} else {
NSLog(@"登錄不成功 沒有獲取accesstoken");
}
}