首页 > 技术文章 > Unity接入友盟分享遇到的坑

ikay 2018-09-13 19:05 原文

  最近项目接了一下友盟分享的SDK,中间遇到了几个坑,写下几条注意事项记录一下。

  接入之前需要准备友盟开发者账号,相应平台开发者账号(微信、QQ、新浪微博)等...

 

安卓端:

  1、确保 AndroidManifest.xml 中声名了相应权限(网络权限、获取已安装应用等)一般平台官方文档会写明所需权限

  2、在 AndroidManifest.xml 内声明相应Activity,例如微信分享(xxx.wxapi.WXEntryActivity,xxx为apk完整包名),QQ授权(com.tencent.tauth.AuthActivity)等,并确保声明无误

  3、在调用分享之前,必须初始化平台参数,友盟AppID,以及对于平台appid,AppSecret等参数,每个平台参数不一致,查看官方文档确定,可以直接把参数放在 xml 的 meta-data 上 Application 启动后的 onCreate 方法中进行初始化,具体逻辑根据项目来确定。 

 1 @Override
 2     public void onCreate() {
 3         super.onCreate();
 4         UMConfigure.init(this,"5a12384aa40fa3551f0001d1","umeng",UMConfigure.DEVICE_TYPE_PHONE,"");
 5         PlatformConfig.setWeixin("wxdc1e388c3822c80b", "3baf1193c85774b3fd9d18447d76cab0");
 6         //豆瓣RENREN平台目前只能在服务器端配置
 7         PlatformConfig.setSinaWeibo("3921700954", "04b48b094faeb16683c32669824ebdad","http://sns.whalecloud.com");
 8         PlatformConfig.setYixin("yxc0614e80c9304c11b0391514d09f13bf");
 9         PlatformConfig.setQQZone("100424468", "c7394704798a158208a74ab60104f0ba");
10         PlatformConfig.setTwitter("3aIN7fuF685MuZ7jtXkQxalyi", "MK6FEYG63eWcpDFgRYw4w9puJhzDl0tyuqWjZ3M7XJuuG7mMbO");
11         PlatformConfig.setAlipay("2015111700822536");
12         PlatformConfig.setLaiwang("laiwangd497e70d4", "d497e70d4c3e4efeab1381476bac4c5e");
13         PlatformConfig.setPinterest("1439206");
14         PlatformConfig.setKakao("e4f60e065048eb031e235c806b31c70f");
15         PlatformConfig.setDing("dingoalmlnohc0wggfedpk");
16         PlatformConfig.setVKontakte("5764965","5My6SNliAaLxEm3Lyd9J");
17         PlatformConfig.setDropbox("oz8v5apet3arcdy","h7p2pjbzkkxt02a");
18         PlatformConfig.setYnote("9c82bf470cba7bd2f1819b0ee26f86c6ce670e9b");
19     }
初始化

  或许你在一切都准备好之后,兴致冲冲的打包,安装,点击分享,QQ好友,成功。QQ空间,成功。感觉完成了重要使命,hahaha。然后点击微信,没反应(或者闪一下),what??? 一顿调试之后,无果,fuck!!!   按下面步骤查一下吧:

    (1)  查看微信后台包名是否和应用包名一致(微信开放平台  ==》 管理中心   ==》 点击查看  ==》 开发信息  ),包括appid,AppSecret 等。

    (2)  下载工具 (传送门)安装到手机,查看一下打包到手机的apk签名是不是和后台一致,不一致就更换相应签名证书,或者更改后台信息。

    (3)  如果只能正确分享,收不到回调,查看 WXEntryActivity 再三查看配置的是不是正确吧。

1  <activity
2             android:name=".wxapi.WXEntryActivity"
3             android:configChanges="keyboardHidden|orientation|screenSize"
4             android:exported="true"
5             android:theme="@android:style/Theme.Translucent.NoTitleBar" />
微信回调

 

苹果端:

  1、Unity3D导出到Xcode,打开 Info.plist 文件,或者 Info 里设置 URL Types 设置相应平台所需appid,具体设置规则查看官方文档。

  2、Info.plist 里设置SSO白名单,不然无法进行应用间跳转,同样规则看文档

  1 <key>LSApplicationQueriesSchemes</key>
  2 <array>
  3     <!-- 微信 URL Scheme 白名单-->
  4     <string>wechat</string>
  5     <string>weixin</string>
  6 
  7     <!-- 新浪微博 URL Scheme 白名单-->
  8     <string>sinaweibohd</string>
  9     <string>sinaweibo</string>
 10     <string>sinaweibosso</string>
 11     <string>weibosdk</string>
 12     <string>weibosdk2.5</string>
 13 
 14     <!-- QQ、Qzone URL Scheme 白名单-->
 15     <string>mqqapi</string>
 16     <string>mqq</string>
 17     <string>mqqOpensdkSSoLogin</string>
 18     <string>mqqconnect</string>
 19     <string>mqqopensdkdataline</string>
 20     <string>mqqopensdkgrouptribeshare</string>
 21     <string>mqqopensdkfriend</string>
 22     <string>mqqopensdkapi</string>
 23     <string>mqqopensdkapiV2</string>
 24     <string>mqqopensdkapiV3</string>
 25     <string>mqqopensdkapiV4</string>
 26     <string>mqzoneopensdk</string>
 27     <string>wtloginmqq</string>
 28     <string>wtloginmqq2</string>
 29     <string>mqqwpa</string>
 30     <string>mqzone</string>
 31     <string>mqzonev2</string>
 32     <string>mqzoneshare</string>
 33     <string>wtloginqzone</string>
 34     <string>mqzonewx</string>
 35     <string>mqzoneopensdkapiV2</string>
 36     <string>mqzoneopensdkapi19</string>
 37     <string>mqzoneopensdkapi</string>
 38     <string>mqqbrowser</string>
 39     <string>mttbrowser</string>
 40     <string>tim</string>
 41     <string>timapi</string>
 42     <string>timopensdkfriend</string>
 43     <string>timwpa</string>
 44     <string>timgamebindinggroup</string>
 45     <string>timapiwallet</string>
 46     <string>timOpensdkSSoLogin</string>
 47     <string>wtlogintim</string>
 48     <string>timopensdkgrouptribeshare</string>
 49     <string>timopensdkapiV4</string>
 50     <string>timgamebindinggroup</string>
 51     <string>timopensdkdataline</string>
 52     <string>wtlogintimV1</string>
 53     <string>timapiV1</string>
 54 
 55     <!-- 支付宝 URL Scheme 白名单-->
 56     <string>alipay</string>
 57     <string>alipayshare</string>
 58 
 59     <!-- 钉钉 URL Scheme 白名单-->
 60       <string>dingtalk</string>
 61       <string>dingtalk-open</string>
 62 
 63     <!--Linkedin URL Scheme 白名单-->
 64     <string>linkedin</string>
 65     <string>linkedin-sdk2</string>
 66     <string>linkedin-sdk</string>
 67 
 68     <!-- 点点虫 URL Scheme 白名单-->
 69     <string>laiwangsso</string>
 70 
 71     <!-- 易信 URL Scheme 白名单-->
 72     <string>yixin</string>
 73     <string>yixinopenapi</string>
 74 
 75     <!-- instagram URL Scheme 白名单-->
 76     <string>instagram</string>
 77 
 78     <!-- whatsapp URL Scheme 白名单-->
 79     <string>whatsapp</string>
 80 
 81     <!-- line URL Scheme 白名单-->
 82     <string>line</string>
 83 
 84     <!-- Facebook URL Scheme 白名单-->
 85     <string>fbapi</string>
 86     <string>fb-messenger-api</string>
 87     <string>fb-messenger-share-api</string>
 88     <string>fbauth2</string>
 89     <string>fbshareextension</string>
 90 
 91     <!-- Kakao URL Scheme 白名单-->  
 92     <!-- 注:以下第一个参数需替换为自己的kakao appkey--> 
 93     <!-- 格式为 kakao + "kakao appkey"-->    
 94     <string>kakaofa63a0b2356e923f3edd6512d531f546</string>
 95     <string>kakaokompassauth</string>
 96     <string>storykompassauth</string>
 97     <string>kakaolink</string>
 98     <string>kakaotalk-4.5.0</string>
 99     <string>kakaostory-2.9.0</string>
100 
101    <!-- pinterest URL Scheme 白名单-->  
102     <string>pinterestsdk.v1</string>
103 
104    <!-- Tumblr URL Scheme 白名单-->  
105     <string>tumblr</string>
106 
107    <!-- 印象笔记 -->
108     <string>evernote</string>
109     <string>en</string>
110     <string>enx</string>
111     <string>evernotecid</string>
112     <string>evernotemsg</string>
113 
114    <!-- 有道云笔记-->
115     <string>youdaonote</string>
116     <string>ynotedictfav</string>
117     <string>com.youdao.note.todayViewNote</string>
118     <string>ynotesharesdk</string>
119 
120    <!-- Google+-->
121     <string>gplus</string>
122 
123    <!-- Pocket-->
124     <string>pocket</string>
125     <string>readitlater</string>
126     <string>pocket-oauth-v1</string>
127     <string>fb131450656879143</string>
128     <string>en-readitlater-5776</string>
129     <string>com.ideashower.ReadItLaterPro3</string>
130     <string>com.ideashower.ReadItLaterPro</string>
131     <string>com.ideashower.ReadItLaterProAlpha</string>
132     <string>com.ideashower.ReadItLaterProEnterprise</string>
133 
134    <!-- VKontakte-->
135     <string>vk</string>
136     <string>vk-share</string>
137     <string>vkauthorize</string>
138 
139    <!-- Twitter-->
140     <string>twitter</string>
141     <string>twitterauth</string>
142 </array>
SSO白名单

  3、其他权限,比如相册访问等,添加相应权限

  4、Build Settings 里设置 Other Linker Flags 添加 -ObjC (注意大小写)

  5、调用分享之前在代码中初始化平台appid,AppSecret 等参数,初始化位置根据项目要求调整

  6、在 UnityAppContriller 中设置回调

1 - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
2 {
3     BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
4     if (!result) {
5         // 其他如支付等SDK的回调
6     }
7     return result;
8 }
分享回调

  或者添加自定义脚本

#import "UnityAppController.h"
#import <UMShare/UMShare.h>

@interface AppControllerWithShare : UnityAppController
    
@end

IMPL_APP_CONTROLLER_SUBCLASS (AppControllerWithShare)


@implementation AppControllerWithShare

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options
{
    //6.3的新的API调用,是为了兼容国外平台(例如:新版facebookSDK,VK等)的调用[如果用6.2的api调用会没有回调],对国内平台没有影响
    BOOL result = [[UMSocialManager defaultManager]  handleOpenURL:url options:options];
    if (!result) {
        // 其他如支付等SDK的回调
    }
    return result;
}


- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
{
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
        // 其他如支付等SDK的回调
    }
    return result;
}

@end
自定义回调

  IMPL_APP_CONTROLLER_SUBCLASS (AppControllerWithShare)  

  此行作用就是把 AppControllerWithShare 作为启动入口

  

 

推荐阅读