React native微信分享插件

今天在项目中修改之前微信分享调用微信后闪退的bug。上一个项目做微信分享的时候没有遇到这个问题。

开源项目地址:https://github.com/reactnativecn/react-native-wx

还有另一个微信插件没有测试过,有兴趣的同学可以试试react-native-wechat

  • 使用方法(使用之前请确保在微信开放平台注册了账号并且创建App并通过审核。没有审核情况下没有试过,不知道能不能成功)

注意事项:react-native >0.17

  1. 安装

        npm install react-native-wx --save
    
  2. 配置(Android)

    //  项目下  android/settings.gradle 添加以下配置 
        
    include ':react-native-wx'
    project(':react-native-wx').projectDir = new File(settingsDir, '../node_modules/react-native-wx/android')
    
```js
//  项目下  android/app/build.gradle 添加以下配置 
    
dependencies {
    ...
    compile project(':react-native-wx')
}
```

``` android/app/src/main/java/<你的包名>/MainActivity.java``` 添加引入的包名```import cn.reactnative.modules.wx.WeChatPackage;```


```java
//MainActivity.java根据版本不同添加
//.addPackage(new WeChatPackage())

,new WeChatPackage()

```

3.添加微信分享APP_ID配置信息

```js
//项目下  android/app/build.gradle 添加以下配置 

android {
...
...
defaultConfig {
manifestPlaceholders = [
...
WX_APPID: "XXXXXX",//添加的配置微信APP_ID

    ]
}

```

如果react-native版本<0.18.0,确保你的MainActivity.java中有onActivityResult的实现:

private ReactInstanceManager mReactInstanceManager;
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data){
    super.onActivityResult(requestCode, resultCode, data);
    mReactInstanceManager.onActivityResult(requestCode, resultCode, data);
}

在你的包名相应目录下新建一个wxapi目录,并在该wxapi目录下新增一个WXEntryActivity类,该类继承自Activity(例如应用程序的包名为net.sourceforge.simcpux,则新添加的类的包名为net.sourceforge.simcpux.wxapi

package net.sourceforge.simcpux.wxapi; // net.sourceforge.simcpux处为你的包名

import android.app.Activity;
import android.os.Bundle;

import cn.reactnative.modules.wx.WeChatModule;

public class WXEntryActivity extends Activity{
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        WeChatModule.handleIntent(getIntent());
        finish();
    }
}
        
note:Android还需要对keystore文件进行md5签名之后,在开放平台的应用设置中设置相应签名才可以成功使用,具体方法见开放平台说明

签名必须要填对不正确的话分享不成功。

附上微信android签名的获取方式的一种:签名请使用该工具点我下载

注意事项

关于微信失败错误

1.分享闪退(确定Android的证书签名填写无误)。
2.尝试删除微信重新安装。(不要问我为什么,我也不知道,返回的错误码:-6)

其他错误

    //node_modules/react-native-wx/android/src/main/java/cn/reactnative/modules/wx/WeChatModule.java
 private String _getErrorMsg(int errCode) {
        Log.e("errCode",""+errCode);//添加打印信息查看错误码
        ....
    }

如何使用

引入包

import * as WechatAPI from 'react-native-wx';

API

WechatAPI.isWXAppInstalled()

返回一个Promise对象

WechatAPI.isWXAppSupportApi()

返回一个Promise对象

WechatAPI.login(config)

// 登录参数 
config : {  
    scope: 权限设置, // 默认 'snsapi_userinfo'
}

返回一个Promise对象。成功时的回调为一个类似这样的对象:

{
    "code": "",
    "appid": "",
    "lang": "",
    "country": "",
}

WechatAPI.shareToTimeline(data)

分享到朋友圈

WechatAPI.shareToSession(data)

分享到好友

// 分享文字
{   
    type: 'text', 
    text: 文字内容,
}
// 分享图片
{   
    type: 'image',
    imageUrl: 图片地址,
    title : 标题,
    description : 描述,
}
// 分享网页
{   
    type: 'news',
    title : 标题,
    description : 描述,   
    webpageUrl : 链接地址,
    imageUrl: 缩略图地址,  //缩略图的大小作了限制,大小不能超过32K。
}

WechatAPI.pay(data)

// 登录参数 
data : {    
    partnerId: "",
    prepayId: "",
    nonceStr: "",
    timeStamp: "",
    package: "",
    sign: "",
}

返回一个Promise对象。成功时的回调为一个类似这样的对象:

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

推荐阅读更多精彩内容