本文内容为集成微信和QQ分享
准备工作
- 友盟、QQ互联、微信开放平台,创建应用。
-
下载友盟sdk,如下图
image.png
image
好的,现在开始干活~~~
集成ios端
-
将下载好的友盟sdk文件目录下,iOS和React-Native目录下所有的.h和.m文件,以及和iOS相关的静态包和.framework,都拖到xcode里面。
image -
然后看到是这个样子
image -
Other Linker Flags加入-ObjC ,-ObjC属于链接库必备参数。
image - Linked Frameworks and Libraries 添加依赖库
libsqlite3.tbd
CoreGraphics.framework
SystemConfiguration.framework
CoreTelephony.framework
libc++.tbd
libz.tbd
-
info.plist添加白名单
image
<key>LSApplicationQueriesSchemes</key>
<array>
<!-- 微信 URL Scheme 白名单-->
<string>wechat</string>
<string>weixin</string>
<!-- QQ、Qzone URL Scheme 白名单-->
<string>mqqapi</string>
<string>mqq</string>
<string>mqqOpensdkSSoLogin</string>
<string>mqqconnect</string>
<string>mqqopensdkdataline</string>
<string>mqqopensdkgrouptribeshare</string>
<string>mqqopensdkfriend</string>
<string>mqqopensdkapi</string>
<string>mqqopensdkapiV2</string>
<string>mqqopensdkapiV3</string>
<string>mqqopensdkapiV4</string>
<string>mqzoneopensdk</string>
<string>wtloginmqq</string>
<string>wtloginmqq2</string>
<string>mqqwpa</string>
<string>mqzone</string>
<string>mqzonev2</string>
<string>mqzoneshare</string>
<string>wtloginqzone</string>
<string>mqzonewx</string>
<string>mqzoneopensdkapiV2</string>
<string>mqzoneopensdkapi19</string>
<string>mqzoneopensdkapi</string>
<string>mqqbrowser</string>
<string>mttbrowser</string>
<string>tim</string>
<string>timapi</string>
<string>timopensdkfriend</string>
<string>timwpa</string>
<string>timgamebindinggroup</string>
<string>timapiwallet</string>
<string>timOpensdkSSoLogin</string>
<string>wtlogintim</string>
<string>timopensdkgrouptribeshare</string>
<string>timopensdkapiV4</string>
<string>timgamebindinggroup</string>
<string>timopensdkdataline</string>
<string>wtlogintimV1</string>
<string>timapiV1</string>
</array>
-
配置URL Scheme。(注意填写准备好的AppKey)
image - AppDelegate.m中初始化sdk
//友盟分享
#import "RNUMConfigure.h"
#import
- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions
{
/**
* RN
*/
NSURL*jsCodeLocation;
jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
RCTRootView*rootView = [[RCTRootViewalloc]initWithBundleURL:jsCodeLocation
moduleName:@"wms"
initialProperties:nil
launchOptions:launchOptions];
rootView.backgroundColor= [UIColorblackColor];
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
UIViewController *rootViewController = [UIViewController new];
rootViewController.view= rootView;
self.window.rootViewController= rootViewController;
[self.window makeKeyAndVisible];
/**
* 友盟分享
*/
//打开调试日志
[UMConfigure setLogEnabled:YES];
//设置友盟appkey
[RNUMConfigure initWithAppkey:@"5ca8498b61f564cf4d00127b" channel:@"App Store"];
//关闭强制验证https,可允许http图片分享,但需要在info.plist设置安全域名
[UMSocialGlobal shareInstance].isUsingHttpsWhenShareContent = NO;
//设置微信的appKey和appSecret
[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:@"wx179afsafasw23b54ae" appSecret:@"5a4142fsdsfswe9a40e93fc" redirectURL:nil];
//设置分享到QQ互联的appID
[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_QQ appKey:@"101568934"/*设置QQ平台的appID*/ appSecret:nil redirectURL:@"http://mobile.umeng.com/social"];
return YES;
}
#pragma mark - Share
//#define __IPHONE_10_0 100000
#if __IPHONE_OS_VERSION_MAX_ALLOWED >100000
- (BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary *)options
{
//6.3的新的API调用,是为了兼容国外平台(例如:新版facebookSDK,VK等)的调用[如果用6.2的api调用会没有回调],对国内平台没有影响。
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url options:options];
if(!result) {
// 其他如支付等SDK的回调
}
returnresult;
}
#endif
- (BOOL)application:(UIApplication*)application openURL:(NSURL*)url sourceApplication:(NSString*)sourceApplication annotation:(id)annotation
{
//6.3的新的API调用,是为了兼容国外平台(例如:新版facebookSDK,VK等)的调用[如果用6.2的api调用会没有回调],对国内平台没有影响
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
if(!result) {
// 其他如支付等SDK的回调
}
returnresult;
}
- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url
{
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
if(!result) {
// 其他如支付等SDK的回调
}
return result;
}
集成android工程
-
android/app目录下新建libs目录,将下载目录的Android中的所有jar包拷贝至libs
如下图
image -
将下载文件的ReactNative目录中所有跟android相关的java文件拷贝至目标项目包下,修改对应包名。
image - 创建WXEntryActivity.java
package com.wms.umeng.wxapi;
import android.content.Intent;
import com.umeng.socialize.UMShareAPI;
import com.umeng.socialize.weixin.view.WXCallbackActivity;
public class WXEntryActivity extends WXCallbackActivity {
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
UMShareAPI.get(this).onActivityResult(requestCode, resultCode, data);
}
}
-
本示例只集成分享,所以DplusReactPackage.java可以注释PushModule和AnalyticsModule。注释掉的模块是推送和统计。
image - MainActivity.java初始化sdk
/**
* ummengshare sdk初始化
*/
ShareModule.initSocialSDK(this);
/**
* umengshare 回调
*/
@Override
public void onActivityResult(int requestCode,int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
UMShareAPI.get(this).onActivityResult(requestCode, resultCode, data);
}
image
- MainApplication.java配置
加载包 new DplusReactPackage()
image
- 配置
@Override
public void onCreate() {
super.onCreate();
SoLoader.init(this,/* native exopackage */ false);
/**
* 应用升级
*/
Bugly.init(getApplicationContext(),"612d4cb76b",true);
/**
* 友盟分享
* RNUMConfture.init接口一共五个参数,
* 其中第一个参数为Context,
* 第二个参数为友盟Appkey,
* 第三个参数为channel,
* 第四个参数为应用类型(手机或平板),
* 第五个参数为push的secret(如果没有使用push,可以为空)。
*/
UMConfigure.setLogEnabled(true);
RNUMConfigure.init(this,"5ca849d5570df31fb2001394","Umeng", UMConfigure.DEVICE_TYPE_PHONE,
"");
}
// 友盟分享:配置平台key、secret信息
{
PlatformConfig.setWeixin("wxxxxxxx","5a4142ff9xxxxxxxx93fc");
PlatformConfig.setQQZone("101568934","e912c0ffb846b50f3d2b42fc15b04cfc");
}
image
- 权限
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
- AndroidManifest.xml添加activity
<activity android:name=".umeng.wxapi.WXEntryActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="true" android:theme="@android:style/Theme.Translucent.NoTitleBar" />
image
- 添加res文件到android studio
image
React-Native端应用
-
将ShareUtil.js拖入rn目录
image - 导包
import ShareUtile from '../../3rd/UMShare/ShareUtil'
- 使用
img 为图片地址,可以为链接,本地地址以及res图片(如果使用res,请使用如下写法:res/icon.png)
url 为分享链接,可以为空
title 为分享链接的标题
list 为分享平台数组,如:var list = [0,1,2]
callback中code为错误码,当为0时,标记成功。message为错误信息
ShareUtile.share(text,img,url,title,platform,(code,message) =>{
this.setState({result:message});
});
-
ShareUtil.js引用的模块api参考
image -
或者
image over!集成好了就去体验吧。