React?Native集成支付寶支付的實現(xiàn)方法
在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.java
和PayPackage.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-router中結(jié)合webpack實現(xiàn)按需加載實例
本篇文章主要介紹了React-router中結(jié)合webpack實現(xiàn)按需加載實例,非常具有實用價值,需要的朋友可以參考下2017-05-05React特征學習Form數(shù)據(jù)管理示例詳解
這篇文章主要為大家介紹了React特征學習Form數(shù)據(jù)管理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09react?hooks?d3實現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解
這篇文章主要為大家介紹了react?hooks?d3實現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01