項目GitHub地址:https://github.com/helei112g/payment
微信支付個人覺得在帳號設置上有些麻煩,帳號太多啦,支付寶目前就是一個應用基本涵蓋了所有的接口開發(fā)。
可能是由于微信支付的后端是財付通,反正咱們寫代碼的,也別管那么多。理清楚各配置的關系,然后寫出高質量的代碼就好。
關于如何申請微信支付,只講兩個問題,服務號支付能力的申請在公眾號后后臺申請,app應用的支付能力申請在開發(fā)者中心申請。其他細節(jié)請自行查詢。
登陸微信商戶平臺:https://pay.weixin.qq.com
拿到微信給的商戶號后,登陸商戶平臺,點擊【賬戶中心】進入【API安全】
會看到下面的截圖:
微信支付發(fā)起請求的數(shù)據(jù)需要進行簽名,簽名的密鑰就是在這里設置,設置時候請記錄一下。等會配置中會需要。
下載微信的安全證書,相關說明看這里
配置文件
return [
'app_id' => '應用ID',
'mch_id' => '商戶id',
'md5_key' => '剛剛設置的密鑰',
'app_cert_pem' => 'apiclient_cert.pem',
'app_key_pem' => 'apiclient_key.pem',
'sign_type' => 'MD5',// MD5 HMAC-SHA256
'limit_pay' => [
//'no_credit',
],
'fee_type' => 'CNY',// 貨幣類型 當前僅支持該字段
'notify_url' => 'https://helei112g.github.io/',
'redirect_url' => 'https://helei112g.github.io/',
'return_raw' => false,
];
下面表格中 是否必須 列如果標記為 是
,則該項必須設置,否則sdk將無法得到結果。
參數(shù) | 類型 | 是否必須 | 說明 |
---|---|---|---|
app_id | string | 是 | 應用id,下面會詳細解釋 |
mch_id | string | 是 | 微信支付分配的商戶號 |
md5_key | string | 是 | 用戶在商戶中心設置的api密鑰 |
sign_type | string | 是 | 簽名類型,默認為MD5,支持HMAC-SHA256和MD5。 |
app_cert_pem | string | 是 | 證書pem格式 |
app_key_pem | string | 是 | 證書密鑰pem格式 |
limit_pay | array | 否 | 上傳此參數(shù)no_credit--可限制用戶不能使用信用卡支付 |
fee_type | string | 否 | 默認人民幣:CNY |
notify_url | string | 是 | 異步通知的地址 |
redirect_url | string | 否 | 回調頁面地址 |
return_raw | boolean | 否 | 是否返回微信原始數(shù)據(jù) |
app_id
: 對于公眾號支付,是微信支付分配的公眾賬號ID,如果是app支付則是微信開放平臺審核通過的應用APPID
微信支付接口中,一定要注意區(qū)分不同的帳號類別
- 公眾號支付,需要對應服務號在公眾號后臺申請,該帳號無法用來進行app支付
- app支付,微信開放平臺審核通過的應用APPID,無法用來進行公眾號支付
- 小程序支付也是一個獨立的帳號,微信分配的小程序ID
- 掃碼支付,可以使用app支付的帳號,也可使用公眾支付的帳號
- 刷卡支付,兩個帳號也可以使用
由于我沒有小程序的帳號,沒辦法測它是否可以用于掃碼支付與刷卡支付,有測過的朋友請告訴我一下(微信號:helei543345
)
mch_id
: 商戶號,申請商戶號成功后,騰訊給你發(fā)的郵件里邊有
md5_key
: 在商戶中心自己設置的api密鑰,主要用來簽名支付數(shù)據(jù)
sign_type
: 簽名方式,當前微信支持HMAC-SHA256和MD5,默認使用 MD5
app_cert_pem
: 從apiclient_cert.p12中導出證書部分的文件,為pem格式,請妥善保管不要泄漏和被他人復制
app_key_pem
: 從apiclient_key.pem中導出密鑰部分的文件,為pem格式
關于 app_cert_pem
與 app_key_pem
的詳情請看這里 : https://pay.weixin.qq.com/wiki/doc/api/micropay.php?chapter=4_3
limit_pay
: no_credit--指定不能使用信用卡支付 ,當前微信僅這一個參數(shù),設置了,支付時,用戶無法使用信用卡
fee_type
: 貨幣類型,默認是人民幣,其他可選值看這里:https://pay.weixin.qq.com/wiki/doc/api/micropay.php?chapter=4_2
notify_url
: 異步接收微信支付結果通知的回調地址,通知url必須為外網(wǎng)可訪問的url,不能攜帶參數(shù)。
redirect_url
: 只有在使用h5支付時,才需要設置,也可以選擇不設置。用來控制在h5中支付成功后,跳轉的頁面。
return_raw
: 是否返回微信的原始數(shù)據(jù),默認為false,建議設置為true
- 該參數(shù)如果設置為
false
,sdk內部會映射一些key,并且把微信的金額處理為元 - 如果參數(shù)值為
true
,則只對異步數(shù)據(jù)進行簽名檢查,檢查通過,返回一個數(shù)據(jù)類型的數(shù)據(jù)(微信原始為xml),其中包含的key是微信本身的,并且金額相關的單位都是分
微信的配置文件相對來說比較簡單,只是它的帳號體系有點多,大家在使用時,根據(jù)自己使用不同支付,讀取不同配置,來完成相互間的切換。
另外,如果還需要轉賬或者發(fā)紅包,請設置以下圖中的信息。
今天晚上公司部署新項目,在等待過程中把微信的配置文檔搞定。