React-Native之微信好友、朋友圈分享、支付

本文主要是介绍React-Native之微信好友、朋友圈分享、支付,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

终于把微信好友分享和朋友圈分享的功能打通了,现在就我的做法,以及遇到的一些坑,写下来供大家参考:

http://yiqizhongchuang.cn/tag/react-native

一、首先我们新建一个RN的项目,写好你的好友分享和朋友圈分享布局,后面我们要调用微信的接口,然后把项目安装到android手机上,后面我们要用签名软件查看签名;

二、去微信的开放平台注册开发者账号(https://open.weixin.qq.com/),然后登陆进去:进入管理中心-移动应用(可以创建10个移动应用),

如下图所示,我的已经有一个了,这个应用的代码在github上(https://github.com/LiuC520/react-native-jifenmao),每天在更新内容,今天把百度地图和微信的分享功能增加了上去。

%e5%be%ae%e4%bf%a11 %e5%be%ae%e4%bf%a12

2.1、然后创建移动应用,输入应用名称和简介,需要准备两张图标,一个是2828像素,仅支持PNG格式,大小不超过300KB;另一个是108108像素,仅支持PNG格式,大小不超过300KB。

wx3

我的图片都是自己用AI和PS做出来的

2.2、下一步,填写应用官网、在android和ios上打钩,android的签名和包名、ios的Bundle ID,

2.2.1、其中Bundle ID在Xcode中查看,点击项目名-General-Bundle Identifier,如下图所示:

%e5%be%ae%e4%bf%a14

Bundle Identifier就是Bundle ID,

2.2.2、 android的包名:打开项目中的android-app-src-main的AndroidManifest.xml的package包名,如下图所示:

%e5%be%ae%e4%bf%a15

2.2.3、android的签名:进入到微信开放平台的资源中心-资源下载-android资源下载-签名生成工具,

%e5%be%ae%e4%bf%a16

安装到手机上,打开软件,输入上面的包名,生成签名,填写到微信开放平台中:

%e5%be%ae%e4%bf%a17-%e4%b8%8b%e5%8d%888-37-12

,然后提交审核。

审核通过后,

%e5%be%ae%e4%bf%a18

三、打开终端,输入 npm install react-native-wechat --save,

3.1、下载后,输入 react-native link,添加依赖

3.2、打开xcode,点击项目名--> Build Phases --> Link Binary With Libraries,点击下面的加号添加下面的依赖:

SystemConfiguration.framework
CoreTelephony.framework
libsqlite3.0
libc++
libz

3.3、然后点击项目名--> info --> URL Types,输入Identifier和URL Schemes(这个就是微信通过的appid),

%e5%be%ae%e4%bf%a19

3.4、对于ios9,进入 > info > Custom iOS Target Properties,添加LSApplicationQueriesSchemes(Array类型),然后增加两个item,值分别为wechat和weixin,如下图所示:

%e5%be%ae%e4%bf%a1103.5、xcode打开项目的AppDelegate.m文件,

- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{  return [RCTLinkingManager application:application openURL:urlsourceApplication:sourceApplication annotation:annotation];
}

3.6、xcode打开项目的AppDelegate.m文件中添加导入文件:

import "RCTLinkingManager.h"

%e5%be%ae%e4%bf%a111

3.7、打开项目--> Build Settings --> Header Search Paths ,双击右侧的值,添加两个路径:

$(SRCROOT)/../node_modules/react-native-wechat/ios

$(SRCROOT)/../node_modules/react-native/Libraries/LinkingIOS

%e5%be%ae%e4%bf%a112

四、android的配置:

4.1、打开 android/settings.gradle添加

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

4.2、打开android/app/build.gradle,在 dependencies 代码块内添加:

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

4.3、打开android-app-src-main-java-com-包名下的MainApplication.java,添加如下代码:

import com.theweflex.react.WeChatPackage;

在getPackages() 方法内添加:  new WeChatPackage(),

%e5%be%ae%e4%bf%a113

如果是react-native link过的话,以上的应该会自动添加的。

4.4:在你的包名下新建一个包名“wxapi”,然后新建一个文件“WXEntryActivity.java”,把下面的代码拷贝进去:

package your.package.wxapi;
import android.app.Activity;
import android.os.Bundle;
import com.theweflex.react.WeChatModule;
public class WXEntryActivity extends Activity{  
@Overrideprotected void onCreate(Bundle savedInstanceState) {    
    super.onCreate(savedInstanceState);    WeChatModule.handleIntent(getIntent());finish();}
}

其中跟上面的代码中的 your.package,是你的包名也就是前面在微信的android里面填写的包名,

4.5、然后在AndroidManifest.xml中的application标签内添加如下的代码:

 activityandroid:name=".wxapi.WXEntryActivity"android:label="@string/app_name"android:exported="true"/>

4.6、如果要混淆的话,需要打开android --> app --> proguard-rules.pro,添加如下代码:

-keep class com.tencent.mm.sdk.** {*;
}

五、打开你的RN项目,在项目里面注册微信的接口:

 componentDidMount (){wechat.registerApp('your appid')}

六、在你的方法里面填写下面的代码:

其中 shareToTimeline是分享到朋友圈的方法,shareToSession 是分享给朋友或者群的方法,

%e5%be%ae%e4%bf%a114

其中title是分享时显示的标题,description是描述的内容体,webpageurl点击后打开的链接,

thumbImage,这个是分享时左侧现实的图片,

imageUrl,这个和webpageurl类似,是分享的图片地址,

videoUrl这是分享的视频地址

musicUrl这是分享的音乐地址

filePath这是分享文件地址,可以分享文件

fileExtension,这个是分享的文件的后缀,如果分享的是doc文档,如:fileExtension:‘.doc’;

此外还有监听的方法:addListener(eventType, listener[, context])

还可以付款,不过要开通,付费的,我这儿没有开通:

pay
try {let result = await WeChat.pay({partnerId: '', // 商家向财付通申请的商家idprepayId: '', // 预支付订单nonceStr: '', // 随机串,防重发timeStamp: '', // 时间戳,防重发package: '', // 商家根据财付通文档填写的数据和签名sign: '' // 商家根据微信开放平台文档对数据做的签名});console.log('Pay for success!');
} catch (error) {console.log('Pay for failure!');
}

七、运行效果图如下:

wechatimg4

%e5%be%ae%e4%bf%a116%e5%be%ae%e4%bf%a115

 

八、注意:填坑:android手机在进行进行操作的时间,如果出现点击图标,打不开微信的好友分组或者朋友圈,一闪而退,需要重启下手机,然后再重新打开。

 

这篇关于React-Native之微信好友、朋友圈分享、支付的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/435194

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni