首頁 > 軟體

React Native整合支付寶支付的實現方法

2022-02-18 16:00:55

在RN應用開發過程中,整合支付寶和微信支付除了直接使用第三方的外掛之,比如:react-native-yunpeng-alipay,我們還可以藉助RN提供的NativeModules呼叫原生模組來實現支付。NativeModules是JS程式碼呼叫原生模組的橋樑。所以,我們只需要在原生工程中整合支付寶和微信支付的sdk,然後使用NativeModules呼叫即可。

首先,我們去支付寶官網下載支付寶SDK,下載對應的Android版本。

然後,將aar檔案放入android/app/libs 資料夾下面,沒有的話可以新建一個。

然後,參考原生Android依賴aar包的方式,在android/app/build.gradle檔案的dependencies 節點裡面新增如下依賴程式碼。

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

上面的程式碼會自動將libs目錄下的jar和aar新增到工程依賴環境中。接著,在android/app/src/main/AndroidMainifest.xml中新增以下必要許可權。

<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能夠呼叫原生的程式碼,還需要封裝JavaModul和ReactPackage。首先,在android/app/src/main/java/com.xxx下面建立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);
            }
        };
        // 非同步呼叫
        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呼叫Android喚起支付即可。首先,匯出PayModule。

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

然後,在需要支付的地方呼叫使用ReactMethod註解的方法即可,如下所示。

import PayModule from './Alipay';
 /**
  * 喚起支付寶app支付
  * @param {*} payStr 為後端介面返回的支付引數
  */
const aliPayAction = async payStr => {
    PayModule.alipay(payStr, res => {
        const { resultStatus } = res;
        const resObj = {
            '6001': '支付取消',
            '6002': '網路連線出錯',
            '4000': '支付失敗',
            '5000': '重複請求'
        };
        if (resultStatus === '9000') {
            // 支付成功處理
            ....
        } else {
            // 支付失敗處理
            .......
        }
    });
};

對於iOS來說,整合支付寶支付也可以參考這種方式來實現。

到此這篇關於React Native整合支付寶支付的文章就介紹到這了,更多相關React Native支付寶支付內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com