欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React?Native集成支付寶支付的實現(xiàn)方法

 更新時間:2022年02月18日 14:41:49   作者:xiangzhihong8  
這篇文章主要介紹了React?Native集成支付寶支付的實現(xiàn)現(xiàn),ativeModules是JS代碼調(diào)用原生模塊的橋梁。所以,我們只需要在原生工程中集成支付寶和微信支付的sdk,然后使用NativeModules調(diào)用即可,需要的朋友可以參考下

在RN應用開發(fā)過程中,集成支付寶和微信支付除了直接使用第三方的插件之,比如:react-native-yunpeng-alipay,我們還可以借助RN提供的NativeModules調(diào)用原生模塊來實現(xiàn)支付。NativeModules是JS代碼調(diào)用原生模塊的橋梁。所以,我們只需要在原生工程中集成支付寶和微信支付的sdk,然后使用NativeModules調(diào)用即可。

首先,我們?nèi)ブЦ秾毠倬W(wǎng)下載支付寶SDK,下載對應的Android版本。

然后,將aar文件放入android/app/libs 文件夾下面,沒有的話可以新建一個。

然后,參考原生Android依賴aar包的方式,在android/app/build.gradle文件的dependencies 節(jié)點里面添加如下依賴代碼。

implementation fileTree(dir:"libs",include: ["*.jar","*.aar"])

上面的代碼會自動將libs目錄下的jar和aar添加到工程依賴環(huán)境中。接著,在android/app/src/main/AndroidMainifest.xml中添加以下必要權(quán)限。

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

如果要讓JS能夠調(diào)用原生的代碼,還需要封裝JavaModul和ReactPackage。首先,在android/app/src/main/java/com.xxx下面創(chuàng)建alipay文件包,然后,在alipay文件下新建PayModule.javaPayPackage.java。

PayModule.java代碼如下:

package com.cgv.alipay;

public class PayModule extends ReactContextBaseJavaModule {
    private final ReactApplicationContext reactContext;
    public PayModule(ReactApplicationContext reactContext) {
        super(reactContext);
        this.reactContext = reactContext;
    }
    @Override
    public String getName() {
        return "PayModule";
    @ReactMethod
    public void setAlipayScheme(String scheme){
    public void setAlipaySandbox(Boolean isSandbox) {
        if (isSandbox) {
            EnvUtils.setEnv(EnvUtils.EnvEnum.SANDBOX);
        } else {
            EnvUtils.setEnv(EnvUtils.EnvEnum.ONLINE);
        }
    public void alipay(final String orderInfo, final Callback promise) {
        Runnable payRunnable = new Runnable() {
            @Override
            public void run() {
                PayTask alipay = new PayTask(getCurrentActivity());
                Map<String, String> result = alipay.payV2(orderInfo, true);
                WritableMap map = Arguments.createMap();
                map.putString("memo", result.get("memo"));
                map.putString("result", result.get("result"));
                map.putString("resultStatus", result.get("resultStatus"));
                promise.invoke(map);
            }
        };
        // 異步調(diào)用
        Thread payThread = new Thread(payRunnable);
        payThread.start();
}

PayPackage.java的代碼如下:

package com.cgv.alipay;

public class PayPackage implements ReactPackage {
    @Override
    public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
        List<NativeModule> modules = new ArrayList<>();
        modules.add(new PayModule(reactContext));
        return modules;
    }
    /**
    * 早期版本的RN如果有報錯取消下面注釋即可
    */
    // @override
    public List<Class<? extends JavaScriptModule>> createJSModules() {
        return Collections.emptyList();
    public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
}

接下來,在MainApplication.java中的getPackages()方法注冊上面的模塊即可。

public class MainApplication extends Application implements ReactApplication {
  private final ReactNativeHost mReactNativeHost =
      new ReactNativeHost(this) {
        @Override
        public boolean getUseDeveloperSupport() {
          return BuildConfig.DEBUG;
        }
        protected List<ReactPackage> getPackages() {
          @SuppressWarnings("UnnecessaryLocalVariable")
          List<ReactPackage> packages = new PackageList(this).getPackages();
          // Packages that cannot be autolinked yet can be added manually here, for example:
           packages.add(new PayPackage());
   
          return packages;
        protected String getJSMainModuleName() {
          return "index";
      };
 
    ...//省略其他代碼
}

接下來,我們只需要在React Native中使用NativeModules調(diào)用Android喚起支付即可。首先,導出PayModule。

import 
{ 
    NativeModules 
    
} 
from 'react-native';
export default NativeModules.PayModule;

然后,在需要支付的地方調(diào)用使用ReactMethod注解的方法即可,如下所示。

import PayModule from './Alipay';
 /**
  * 喚起支付寶app支付
  * @param {*} payStr 為后端接口返回的支付參數(shù)
  */
const aliPayAction = async payStr => {
    PayModule.alipay(payStr, res => {
        const { resultStatus } = res;
        const resObj = {
            '6001': '支付取消',
            '6002': '網(wǎng)絡連接出錯',
            '4000': '支付失敗',
            '5000': '重復請求'
        };
        if (resultStatus === '9000') {
            // 支付成功處理
            ....
        } else {
            // 支付失敗處理
            .......
        }
    });
};

對于iOS來說,集成支付寶支付也可以參考這種方式來實現(xiàn)。

到此這篇關(guān)于React Native集成支付寶支付的文章就介紹到這了,更多相關(guān)React Native支付寶支付內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 手把手教你從零開始react+antd搭建項目

    手把手教你從零開始react+antd搭建項目

    本文將從最基礎的項目搭建開始講起,做一個基于react和antd的后臺管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 詳解React之父子組件傳遞和其它一些要點

    詳解React之父子組件傳遞和其它一些要點

    這篇文章主要介紹了詳解React之父子組件傳遞和其它一些要點,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • React中props使用介紹

    React中props使用介紹

    props是組件(包括函數(shù)組件和class組件)間的內(nèi)置屬性,用其可以傳遞數(shù)據(jù)給子節(jié)點,props用來傳遞參數(shù)。組件實例化過程中,你可以向其中傳遞一個參數(shù),這個參數(shù)會在實例化過程中被引用
    2022-12-12
  • react項目中使用插件配置路由的方法

    react項目中使用插件配置路由的方法

    這篇文章主要介紹了react項目中使用插件配置路由的相關(guān)知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • React-router中結(jié)合webpack實現(xiàn)按需加載實例

    React-router中結(jié)合webpack實現(xiàn)按需加載實例

    本篇文章主要介紹了React-router中結(jié)合webpack實現(xiàn)按需加載實例,非常具有實用價值,需要的朋友可以參考下
    2017-05-05
  • React特征學習Form數(shù)據(jù)管理示例詳解

    React特征學習Form數(shù)據(jù)管理示例詳解

    這篇文章主要為大家介紹了React特征學習Form數(shù)據(jù)管理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • 一文帶你掌握React類式組件中setState的應用

    一文帶你掌握React類式組件中setState的應用

    這篇文章主要為大家詳細介紹了介紹了React類式組件中setState的三種寫法以及簡單討論下setState?到底是同步的還是異步的,感興趣的可以了解下
    2024-02-02
  • react?hooks?d3實現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解

    react?hooks?d3實現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解

    這篇文章主要為大家介紹了react?hooks?d3實現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • React Native項目中使用Lottie動畫的方法

    React Native項目中使用Lottie動畫的方法

    這篇文章主要介紹了React Native 實現(xiàn)Lottie動畫的相關(guān)知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • hooks中useEffect()使用案例詳解

    hooks中useEffect()使用案例詳解

    這篇文章主要介紹了hooks中useEffect()使用總結(jié),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09

最新評論