Swift项目使用Mob分享功能

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 ,判断方法为ShareSDK.isClientInstalled(SSDKPlatformType.typeWechat)

你可能感兴趣的:(Swift项目使用Mob分享功能)