美文网首页
Swift项目使用Mob分享功能

Swift项目使用Mob分享功能

作者: Boxzhi | 来源:发表于2018-10-16 18:39 被阅读76次

    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)

    相关文章

      网友评论

          本文标题:Swift项目使用Mob分享功能

          本文链接:https://www.haomeiwen.com/subject/mwahzftx.html