<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在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.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); } }; // 非同步呼叫 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!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45