React?Native集成支付寶支付的實(shí)現(xiàn)方法
在RN應(yīng)用開(kāi)發(fā)過(guò)程中,集成支付寶和微信支付除了直接使用第三方的插件之,比如:react-native-yunpeng-alipay,我們還可以借助RN提供的NativeModules調(diào)用原生模塊來(lái)實(shí)現(xiàn)支付。NativeModules是JS代碼調(diào)用原生模塊的橋梁。所以,我們只需要在原生工程中集成支付寶和微信支付的sdk,然后使用NativeModules調(diào)用即可。
首先,我們?nèi)ブЦ秾毠倬W(wǎng)下載支付寶SDK,下載對(duì)應(yīng)的Android版本。

然后,將aar文件放入android/app/libs 文件夾下面,沒(méi)有的話可以新建一個(gè)。

然后,參考原生Android依賴aar包的方式,在android/app/build.gradle文件的dependencies 節(jié)點(diǎn)里面添加如下依賴代碼。
implementation fileTree(dir:"libs",include: ["*.jar","*.aar"])
上面的代碼會(huì)自動(dòng)將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如果有報(bào)錯(cuò)取消下面注釋即可
*/
// @override
public List<Class<? extends JavaScriptModule>> createJSModules() {
return Collections.emptyList();
public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
}接下來(lái),在MainApplication.java中的getPackages()方法注冊(cè)上面的模塊即可。
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";
};
...//省略其他代碼
}接下來(lái),我們只需要在React Native中使用NativeModules調(diào)用Android喚起支付即可。首先,導(dǎo)出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)絡(luò)連接出錯(cuò)',
'4000': '支付失敗',
'5000': '重復(fù)請(qǐng)求'
};
if (resultStatus === '9000') {
// 支付成功處理
....
} else {
// 支付失敗處理
.......
}
});
};
對(duì)于iOS來(lái)說(shuō),集成支付寶支付也可以參考這種方式來(lái)實(shí)現(xiàn)。
到此這篇關(guān)于React Native集成支付寶支付的文章就介紹到這了,更多相關(guān)React Native支付寶支付內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
手把手教你從零開(kāi)始react+antd搭建項(xiàng)目
本文將從最基礎(chǔ)的項(xiàng)目搭建開(kāi)始講起,做一個(gè)基于react和antd的后臺(tái)管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
React-router中結(jié)合webpack實(shí)現(xiàn)按需加載實(shí)例
本篇文章主要介紹了React-router中結(jié)合webpack實(shí)現(xiàn)按需加載實(shí)例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-05-05
React特征學(xué)習(xí)Form數(shù)據(jù)管理示例詳解
這篇文章主要為大家介紹了React特征學(xué)習(xí)Form數(shù)據(jù)管理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
一文帶你掌握React類式組件中setState的應(yīng)用
這篇文章主要為大家詳細(xì)介紹了介紹了React類式組件中setState的三種寫法以及簡(jiǎn)單討論下setState?到底是同步的還是異步的,感興趣的可以了解下2024-02-02
react?hooks?d3實(shí)現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解
這篇文章主要為大家介紹了react?hooks?d3實(shí)現(xiàn)企查查股權(quán)穿透圖結(jié)構(gòu)圖效果詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
React Native項(xiàng)目中使用Lottie動(dòng)畫的方法
這篇文章主要介紹了React Native 實(shí)現(xiàn)Lottie動(dòng)畫的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-10-10

