# 關于支付
[TOC]
> Apicloud主推使用微信支付,支付寶支付(當然官網也有第三方支付文檔,銀聯支支付文檔,不過小編不推薦,在這里也不做聲明,需要的童鞋請去Apicloud官網文檔查閱。)
### 1. 支付寶支付
首先配置config.xml
~~~
<feature name="aliPay">
<param name="urlScheme" value="AliPayA*****" />
</feature>
//****表示應用的編號,詳情參考開發控制臺
~~~
配置res/key.xml
在res文件下面創建一個key.xml文件(在這配置,后面代碼中可以不配置,**可選**)
~~~
<?xml version="1.0" encoding="UTF-8"?>
<security>
<item name="aliPay_partner" value="2088********"/><!-商戶號-->
<item name="aliPay_seller" value="2088******"/><!-商戶號-->
<item name="aliPay_rsaPriKey" value="******"/><!--私鑰-->
<item name="aliPay_rsaPubKey" value="********"/><!--公鑰-->
<item name="aliPay_notifyURL" value="www.hmoore.net"/><!--回調地址-->
</security>
~~~
**前方重要!!!!!!!!**</br>
關于私鑰公鑰
打開螞蟻金服開放平臺
https://openhome.alipay.com/platform/home.htm
(ps:關于申請開發者賬號等認證信息在這里不贅述)<br>
1. 登錄開發者賬號

2. 點擊賬戶及秘鑰管理

**因為我們這個項目也有PC和wap端的,pc端用的是開放平臺的秘鑰,具體在申請開發者賬號的時候要用軟件(下文)來申請公鑰然后提交審核,最后完成開放平臺密鑰私鑰獲取。**<br>
*但是。。。咱們app根本不需要開放平臺的東西*<br>
如上圖所示,需要合作伙伴的**密鑰**<br>
PID就是要寫在key.xml里面的或者在代碼中,下面會講怎么寫(官網文檔這會兒夠用~)
RSA(密鑰),截圖上顯示有查看開發者公鑰和查看支付寶公鑰,這個是添加后的,沒添加的時候顯示的是**添加公鑰**
3. 獲取加密軟件點擊查看密鑰說明
點擊PSR私鑰及公鑰生成

進入以后推薦下面的方式一(假如是大神你也可以用方式二)

第一種下載下來!解壓以后如下圖所示
<br>
先運行**支付寶RAS密鑰生成器SHAwithRSA1024_V1.0.bat**<br>
然后打開**RSA**文件夾<br>
<br>
**打開openssl文件**<br>
<br>
點擊生成公鑰,然后點擊生成公鑰私鑰轉換PCKS8.bat然后就會多出下面框里很多東西

這時你點擊rsa_private_key_pkcs8.pem是沒有東西的!
**然后點擊私鑰轉換PCKS8!!!!支付寶的對應文檔并沒有說需要PCKS8格式的私鑰!但是真的是需要這個**
然后把rsa_public_key.pem里面的公鑰復制添加到網站相應的地方,就是上文中講的可以設置公鑰中,然后會默認添加私鑰,那里自動生成的秘鑰我們用不了,然后我們要用**文件夾中的PCKS8格式的秘鑰!**
**剩下的步驟可以參考apicloud官網的支付寶文檔。**<br>
<br>
<br>
### 2.微信支付(坑最多的!!!)
本文介紹的是Apicloud官網文檔的**方案二**
首先配置config.xml(和支付寶環節一樣)
~~~
<feature name="wxPay">
<param name="urlScheme" value="****************"/>(必須配置)微信開放平臺獲取的 appid
<param name="apiKey" value="***************"/>(必須配置)微信開放平臺獲取的 appid
<param name="apiSecret" value="*************"/>從微信開放平臺獲取的 secret
</feature>
~~~
微信開放平臺!注意是開放平臺,申請app通過以后還要繼續申請支付功能,屆時需要300元,大概5天左右搞定
接著就是res/key.xml(這里可以不配置,在代碼中寫上,我是兩個都配置了,害怕抽風~)
~~~
<security>
<item name="wxPay_appId" value="wx*************"/><!--微信開放平臺獲取的 appid-->
<item name="wxPay_mchId" value="1*******"/><!--商戶號(具體在微信給商家發的郵件里)-->
<item name="wxPay_partnerKey" value="********"/><!--登錄微信商戶然后在API安全 里自己設置的!這個地方一定要注意下,因為小編在這里被坑了好長時間一度懷疑這個模塊到底能不能用 這個和secret不一樣!!!不一樣!!!不一樣!!!-->
<item name="wxPay_notifyUrl" value="*****"/><!--回調地址-->
</security>
~~~
~~~
var wxPay = api.require('wxPay');
wxPay.config({
apiKey: 'wx********',<!--微信開放平臺獲取的 appid-->
mchId: '*********',<!--商戶號(具體在微信給商家發的郵件里)-->
partnerKey: '******',<!--秘鑰-->
notifyUrl: 'http://www.*******.xin'<!--回調地址-->
}, function(ret, err) {
if (ret.status) {
// alert('配置商戶支付參數成功');
wxPay.pay({
description:mc,<!--傳給微信的訂單名稱-->
totalFee:wxjg,<!--給微信傳的價格,這里只能是分,然后是整數-->
tradeNo:a(32)<!--生成隨機的32位隨機碼~這個地方很重要-->
}, function(ret, err) {
// alert( JSON.stringify( ret ) );
if (ret.status){
alert(ret.code);
} else {
alert(err.code);
// alert(err.return_msg);
}
});
} else {
alert(err.code);
}
});
~~~
生成隨機碼的方法↓↓↓
~~~
function a(a) {
var d,
e,
b = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789",
c = "";
for (d = 0; a > d; d += 1)
e = Math.random() * b.length, e = Math.floor(e), c += b.charAt(e);
return c
}//生成32位隨機字符串
~~~
?
> 最主要的是返回-1!
>alert(err.msg);然后看看是什么錯誤,一般返回的是"簽名錯誤",這時去檢查包名和簽名在微信開放平臺是不是弄錯了!去下載一個生成簽名的工具,然后看看。
?
? ?
? ?
?
? ? ?
?
- 關于我們
- ApiCloud
- 支付模塊
- 微信支付--wxPay(客戶端)
- 微信支付--wxPay(服務端)
- 支付寶支付--aliPay(客戶端配置)
- 支付寶支付--aliPay(服務端配置)
- DoT模板
- 緩存模塊
- 監聽模塊
- 百度定位模塊
- 設置狀態欄字體顏色
- 選擇城市插件
- 跨頁面執行方法
- 安卓-點擊返回事件
- 上傳圖片模塊
- 點擊彈出放大圖片層
- 魅族手機apiready問題
- 分享
- 跨win或frm執行腳本
- 關于ios數字自動識別成手機號
- 百度地圖bMap
- 語音識別模塊
- tabBarMenu底部導航
- 第三方登錄
- QQ網站和appQQ賬號的統一問題解決
- 微信登錄
- QQ登錄
- 微博登錄
- 上拉加載、下拉刷新模塊
- 圖片緩存
- 文件和圖片緩存機制分享
- PHP
- 支付寶及時到賬
- no input file specified報錯解決
- thinkphp 整合kindeditor
- 整合tpshop微信模塊到thinkcmf中
- thinkphp3.1.3整合支付寶
- 網站接入QQ OAuth2.0登錄教程
- ThinkPHP整合百度編輯器Ueditor
- PHP加快執行效率的寫法規范
- ThinkPHP操作大全
- PHP操作大全
- Thinkphp中SQL操作返回值
- php5.3 foreach 使用&(與運算符)引用賦值要注意的問題
- mysql給字段追加值
- 阿里大魚短信平臺接入
- Navicat 導出 Mysql 數據字典
- php 面向對象全面教程
- PHP5下調用SOAP
- PHP處理時間格式添加空格
- 偽裝URL請求(.htaccess)
- url請求參數加解密
- JS插件
- artDialog彈窗-頁面傳值
- jQuery點擊遮罩彈出層固定居中
- jeBox原生彈窗
- bxslider輪播
- js生成指定位數隨機數
- 發送短信倒計時
- js調試
- jQuery.validator 表單驗證規則
- Swiper 輪播
- 獲得焦點時-圖片抖動
- uploadify無刷新上傳圖片
- 導航下拉隱藏上拉顯示
- 獲得焦點時-加黑色蒙版
- jquery.qrcode.js生成二維條形碼(支持中文)
- jquery.qrcode.js生成二維條形碼(官方不支持中文)
- nth-child 選擇器
- 無刷新點擊實現加載更多數據
- 刷新頁面方法
- 判斷滾動條向上向下
- 跨瀏覽器復制jQuery-zclip
- js校驗表單后提交表單的三種方法
- 用JS判斷下拉框是否選中
- div中滾動
- 提交時彈出模態框
- 當圖片不顯示時替換方法
- 前端
- CSS3
- HTML5
- css技巧
- 移動端rem
- Flex布局
- 電商詳情滾動條監聽
- VueCircleMenu圓環按鈕
- iframe自適應頁面高度
- 百度Echart
- input:radio改變選中顏色
- Jquery
- 響應式布局基本實現Media Query
- 循環輸出只輸出新內容
- 小程序
- wx.request坑
- 概要
- git操作
- 本地記住密碼
- 操作
- 生成ssh公鑰 記住密碼
- git避坑
- ES6學習手札
- 調試小插件
- 谷歌插件Postman
- PHP調試助手
- WordPress
- 緩存服務器Redis
- 在線代碼運行 Docker
- 在ubuntu下怎樣安裝https
- BrowserSync 瀏覽器同步測試工具
- getmarkman高效的設計稿標注、測量工具
- PHPstrom軟件
- 服務器
- linux 安裝搭建服務器配置及nginx配置
- tpshop的nginx 服務器配置方法
- (服務器訪問文件404解決辦法)IIS 之 添加MIME擴展類型及常用的MIME類型列表
- mysql部分
- mysql緩存
- MySql監控工具--mytop
- MySql主從搭建
- mysql優化
- Mysql 復制 (主從復制)
- iOS開發筆記 - 上線流程
- VUE避坑指南
- 從零開始學Vue
- Vue-cli
- Webpack
- VUE小記
- npm打包空白
- 打包背景圖片/項目圖片不顯示
- VUE避坑指南/elementUI upload 自定義http-request上傳
- 關于watch監聽路由重復加載方法
- 解決加載內容的時候閃動問題
- vuecli沒有network訪問地址
- python學習
- python初始
- pytho內置函數大全
- win10 播放器播放TS文件問題
- 設計網站
- VUE避坑指南/VUE-CLI部署空白
- swiper使用問題
- uni-app學習手冊
- 目錄結構
- layUI
- nodesass版本sassloader版本問題