超详细React Native实现微信好友/朋友圈分享功能-Android/iOS双平台通用

(一)前言

本文主要会涉及到以下内容:

微信开发者应用申请审核

安装配置微信分享库

微信好友/朋友圈功能实现

(二)应用申请审核

首先大家需要去微信开发平台去注册账号并且创建一个移动应用。(地址:https://open.weixin.qq.com)


开始创建移动应用,填写应用名称,应用名称以及中英文的信息,移动应用图标分别为28x28何108x108的png格式图标。

然后下一步填写iOS项目的bundle ID以及android项目的包名和应用签名。请注意应用签名获取需要安装一下获取签名信息的APK包,同时你的android应用也需要打包以后安装在手机上面,这样再去获取。具体获取方式见下面的图

下载获取第三方应用的签名信息apk

下载安装上面的签名信息包apk,然后在上面输入android项目的包名,点击获取签名信息

android项目的包名路径:android/app/build.gradle中的applicationId标签数据。

把上面的签名信息填写到下面的网页上面,点击提交审核即可。然后就是等待吧,官方说是7个工作日,不过一般也就是几个小时就可以通过审核了吧。

(三)安装配置微信分享库

github上面已经有封装微信分享的原生SDK库了,大家可以进行去下载安装,然后RN端就可以进行调用使用了。具体项目地址:https://github.com/weflex/react-native-wechat不过该库不仅支持微信分享,还支持微信登录,收藏以及微信支付的。但是登录,支付之类的功能需要开通开发者认证权限,那是需要300元一年的啦~

3.1.库安装方法:npm install react-native-wechat --save

3.2.Android版本安装配置方法

①.在android/settings.gradle文件中添加如下代码:

include':RCTWeChat'

project(':RCTWeChat').projectDir =newFile(rootProject.projectDir,'../node_modules/react-native-wechat/android')

②.在android/app/build.gradle文件中的dependencies标签中添加模块依赖

...

dependencies {

...

compile project(':RCTWeChat')// Add this line only.

}

③.在MainActivity.java文件中添加如下代码

importcom.theweflex.react.WeChatPackage;// Add this line before public class MainActivity

...

/**

* A list of packages used by the app. If the app uses additional views

* or modules besides the default ones, add more packages here.

*/

@Override

protectedList getPackages() {

returnArrays.asList(

newMainReactPackage()

,newWeChatPackage()// Add this line

);

}

④.在android项目中创建wxapi包名,在该包名底下创建WXEntryActivity.java类,该类用于去微信获取请求以及响应。

packageyour.package.wxapi;

importandroid.app.Activity;

importandroid.os.Bundle;

importcom.theweflex.react.WeChatModule;

publicclassWXEntryActivityextendsActivity{

@Override

protectedvoidonCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

WeChatModule.handleIntent(getIntent());

finish();

}

}

⑤.在AndroidManifest.xml文件中添加刚刚创建的Actiivty的配置

...

...

android:name=".wxapi.WXEntryActivity"

android:label="@string/app_name"

android:exported="true"

/>

⑥.混淆设置,在proguard-rules.pro中添加如下代码,当然如果不混淆就不安全啦

-keepclasscom.tencent.mm.sdk.** {

*;

}

3.3.iOS版本安装配置方法

①.我们之前已经执行过npm安装微信库了,接下来我们有两种方法进行链接第一种就是直接通过rnpm link,如下:

当然如果大家这种方案没有成功链接的话,可以采用手动方式了,具体教程请点击进入

②.接下来在xcode中添加部分库依赖(Link Binary With Libraries):

SystemConfiguration.framework

CoreTelephony.framework

libsqlite3.0

libc++

libz

③.选中Targets-info配置中URL Schema中配置刚申请下来的appid

④.为了iOS9.0的支持,在Targets-info中的Custom iOS Traget Properties标签中添加LSApplicationQueriesSchemes字段,值分别为wechat和weixin

⑤.接下来需要在APPDelete.m文件中做一下Linking的处理配置(具体有关Linking的配置请点击查看)

- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url

sourceApplication:(NSString *)sourceApplication annotation:(id)annotation

{

return[RCTLinkingManager application:application openURL:url

sourceApplication:sourceApplication annotation:annotation];

}

(四)微信好友/朋友圈分享实例

上面我们已经把基本安装配置已经讲解完成了,下面我们通过实例来进行演示一下,主要演示分享到好友/朋友圈的链接以及文本,关于更多的分享实例例如文件,图片,视频,语言等等可以查看项目的说明文件即可。

分享实例步骤:

注册应用

本文/朋友圈分享

Android测试应用需要打包测试

iOS版本直接测试即可,代码和下面一样

让我们来看一下实例代码,今天主要演示好友文本/链接以及朋友圈文本/链接分享:

/**

* Sample React Native App

*https://github.com/facebook/react-native

* @flow

*/

importReact, { Component } from'react';

import{

AppRegistry,

StyleSheet,

Text,

View,

TouchableHighlight,

ToastAndroid,

} from'react-native';

var WeChat=require('react-native-wechat');

//import fs from 'react-native-fs';

classCustomButtonextendsComponent {

render() {

return(

style={styles.button}

underlayColor="#a5a5a5"

onPress={this.props.onPress}>

{this.props.text}

);

}

}

classRNWeChatDemoextendsComponent {

constructor(props) {

super(props);

//应用注册

WeChat.registerApp('wx8d560da3ba038e7e');

}

render() {

return(

微信好友/朋友圈分享实例

onPress={() => {

WeChat.isWXAppInstalled()

.then((isInstalled) => {

if(isInstalled) {

WeChat.shareToSession({type:'text', description:'测试微信好友分享文本'})

.catch((error) => {

ToastShort(error.message);

});

}else{

ToastShort('没有安装微信软件,请您安装微信之后再试');

}

});

}}

/>

onPress={() => {

WeChat.isWXAppInstalled()

.then((isInstalled) => {

if(isInstalled) {

WeChat.shareToSession({

title:'微信好友测试链接',

description:'分享自:江清清的技术专栏(www.lcode.org)',

thumbImage:'http://mta.zttit.com:8080/images/ZTT_1404756641470_image.jpg',

type:'news',

webpageUrl:'http://www.lcode.org'

})

.catch((error) => {

ToastShort(error.message);

});

}else{

ToastShort('没有安装微信软件,请您安装微信之后再试');

}

});

}}

/>

onPress={() => {

WeChat.isWXAppInstalled()

.then((isInstalled) => {

if(isInstalled) {

WeChat.shareToTimeline({type:'text', description:'测试微信朋友圈分享文本'})

.catch((error) => {

ToastShort(error.message);

});

}else{

ToastShort('没有安装微信软件,请您安装微信之后再试');

}

});

}}

/>

onPress={() => {

WeChat.isWXAppInstalled()

.then((isInstalled) => {

if(isInstalled) {

WeChat.shareToTimeline({

title:'微信朋友圈测试链接',

description:'分享自:江清清的技术专栏(www.lcode.org)',

thumbImage:'http://mta.zttit.com:8080/images/ZTT_1404756641470_image.jpg',

type:'news',

webpageUrl:'http://www.lcode.org'

})

.catch((error) => {

ToastShort(error.message);

});

}else{

ToastShort('没有安装微信软件,请您安装微信之后再试');

}

});

}}

/>

);

}

}

const styles = StyleSheet.create({

welcome: {

fontSize:20,

textAlign:'center',

margin:10,

},

button: {

margin:5,

backgroundColor:'white',

padding:15,

borderBottomWidth: StyleSheet.hairlineWidth,

borderBottomColor:'#cdcdcd',

},

});

AppRegistry.registerComponent('RNWeChatDemo', () => RNWeChatDemo);

运行效果:

(五)最后总结

今天带着大家从最基本开始一起来实现一下微信分享功能,当然除了分享文本和链接以外,还可以分享语音,视频,图片,文件等等。这些相关的使用API可以参考上面WeChat库中的文档即可。

刚创建的React Native交流6群:426762904,欢迎各位大牛,React Native技术爱好者加入交流!同时博客右侧欢迎微信扫描关注订阅号,移动技术干货,精彩文章技术推送!

本文章实例项目地址:https://github.com/leechuanjun/TLReactNativeProject/tree/dev-1.1.0-combat

来源:超详细React Native实现微信好友/朋友圈分享功能-Android/iOS双平台通用-江清清的技术专栏

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容