1. 去各平台申请账号并创建应用
- 去Mob官网,登录->进入后台->添加应用,在“设置”处拿到刚添加应用的App_key和App_Secret
- 常用的平台有QQ、微信、新浪微博
- 创建好应用后拿到等相关ID、key或Secret(QQ为App_id和App_key、微博为App_key和App_Secret、微信需等待审核后才能拿到App_id和App_Secret)
2. 通过下载拖入或CocoaPods集成MobShareSDK
- 我用的是CocoaPods方式导入,因分享UI自己写,所以只需导入以下几个
pod 'mob_sharesdk'
pod 'mob_sharesdk/ShareSDKPlatforms/QQ'
pod 'mob_sharesdk/ShareSDKPlatforms/SinaWeibo'
pod 'mob_sharesdk/ShareSDKPlatforms/WeChat'
3. 添加Scheme白名单
4. 设置ShareSDK的Appkey并初始化对应的第三方社交平台
- 在项目工程的Info.plist 中如图增加 MOBAppkey 和 MOBAppSecret 两个字段,并将步骤1中拿到的App_key和App_Secret填入
5. 创建桥接文件并导入相关文件
-
新建Header File,并建立桥接:
-
建立桥接(重要:这个桥接文件中写入OC代码的头文件之后,Swift代码就可以调用OC的代码了,放大可看大图步骤):
-
打开桥接文件(ShareSDK-Bridging-Header.h)导入OC文件头
6. 注册Mob分享
- 在
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool
中添加以下代码:
ShareSDK.registerActivePlatforms([SSDKPlatformType.typeSinaWeibo.rawValue, SSDKPlatformType.typeQQ.rawValue], onImport: { (platformType) in
switch platformType {
case .typeSinaWeibo:
ShareSDKConnector.connectWeibo(WeiboSDK.self)
case .typeQQ:
ShareSDKConnector.connectQQ(QQApiInterface.self, tencentOAuthClass: TencentOAuth.self)
// case .typeWechat:
// ShareSDKConnector.connectWeChat(WXApi.self)
default:
break
}
}) { (platformType, appInfo) in
switch platformType {
case .typeSinaWeibo:
//设置新浪微博应用信息,其中authType设置为使用SSO+Web形式授权
appInfo?.ssdkSetupSinaWeibo(byAppKey: ExamConfig.WB_APP_KEY, appSecret: ExamConfig.WB_APP_Secret, redirectUri: "http://www.kaoyanvip.cn/", authType: SSDKAuthTypeBoth)
case .typeQQ:
appInfo?.ssdkSetupQQ(byAppId: ExamConfig.QQ_APP_ID, appKey: ExamConfig.QQ_APP_KEY, authType: SSDKAuthTypeSSO)
// case .typeWechat:
// appInfo?.ssdkSetupWeChat(byAppId: <#T##String!#>, appSecret: <#T##String!#>)
default:
break
}
}
7. 分享跳转
- 在分享点击事件中添加以下代码:
/// 分享参数、type代表分享内容的类型
let shareParameters = NSMutableDictionary()
shareParameters.ssdkSetupShareParams(byText: nil, images: shareImage, url: nil, title: nil, type: .image)
ShareSDK.share(platformType, parameters: shareParameters) { (state, userData, contentEntity, error) in
switch state {
case .success:
HZToast.showSuccess("分享成功~")
case .fail:
HZToast.showError("分享失败:\(String(describing: error))")
default:
break
}
}
8. 添加URL Types
- 支持微信所需的相关配置及代码 在微信开放平台注册应用并取得应用的AppID,然后打开下图位置,在URL Types中添加微信AppID
- 支持QQ所需的相关配置及代码 登录腾讯开放平台(http://open.qq.com/ )注册成为开发者并登记应用取得AppId,然后打开下图位置,在URL Types中添加QQ的AppID,其格式为:”QQ” + AppId的16进制(如果appId转换的16进制数不够8位则在前面补0,如转换的是:5FB8B52,则最终填入为:QQ05FB8B52 注意:转换后的字母要大写) 转换16进制的方法:echo ‘ibase=10;obase=16;801312852′|bc,其中801312852为QQ的AppID,见下图
-
配置新浪微博、Facebook的SSO 登录新浪微博和facebook的开放平台,获取AppID 。新浪微博的url scheme的设置格式为wb+Appkey(这个appkey是在微博上注册应用得到的appkey)
注意:判断微信、QQ等软件客户端是否安装,需导入pod 'mob_sharesdk/ShareSDKExtension'
- 使用方法为:在桥接文件引入
#import <ShareSDKExtension/ShareSDK+Extension.h>
,判断方法为ShareSDK.isClientInstalled(SSDKPlatformType.typeWechat)
网友评论