前言
本人是一個PHPer,所以本文僅針對PHP開發人員,后面會更新本系列的其他微信公眾號相關的內容,所以提前說明方向,以免誤導了您。不過語言都是相通的,其他語言的開發也可以簡單看看,了解一下,開發前期準備步驟都是一樣的;
話不多說,看正文
1、注冊一個服務號,并認證通過
微信公眾平臺地址:https://mp.weixin.qq.com ,開發者可以使用公司郵箱,根據微信的官方引導注冊 服務號,一定要是公司的郵箱,以后用經常用到的;
注冊完成之后,進行微信認證,路徑:點擊左上方頭像 -> 選擇認證詳情 -> 在出來的界面按要求申請認證即可。
2、開通微信支付功能
認證通過以后,可在微信公眾平臺申請開通微信支付,路徑:平臺首頁 -> 點擊左側微信支付 -> 點擊支付申請 -> 根據官方引導一步步申請即可。
開通微信支付需要注冊登陸 微信商戶平臺,微信支付相關的信息都需要在這個平臺上進行操作。
注冊登陸商戶平臺,進入賬戶中心 -> 支付申請 -> 按要求填寫即可;
- PS:一定要注意服務號和商戶平臺必須是一個賬戶主體,也就是認證的公司需要一致,否則不是同一個商戶。
3、添加服務號和商戶平臺的用戶管理權限
通常開通微信公眾平臺和商戶平臺的人都是管理員,也就是你的老大等人員,我們開發者需要登陸使用功能時也不會使用管理員,所以需要添加自己微信號的權限;
微信公眾平臺的權限叫做 運營者微信號,在公眾平臺的左側 -> 人員設置中添加,需要管理員為我們綁定一個長期的運營者賬號;
商戶平臺地址:https://pay.weixin.qq.com
微信商戶平臺的權限叫做 員工賬號,在商戶平臺 -> 賬戶中心 -> 左側員工賬號管理 -> 選擇某個角色(通常是管理員)-> 新增賬號 -> 按要求填寫之后即可;
如果添加后開發者還是沒有需要的相關權限,可以在角色右上方 配置權限 中授權修改。
4、配置公眾號 JS接口安全域名 和 網頁授權域名
微信強制規定,如果要使用公眾號支付、H5支付、小程序支付等產品時,必須獲取到用戶的openid,也就是用戶唯一標識,如果獲取呢?公眾號支付需要網頁授權,而網頁授權就必須配置 JS接口安全域名 和 網頁授權域名這兩個域名,小程序支付也一致;
不同點是,公眾號支付的域名可以是http/https,而小程序則必須是https;
配置路徑:公眾平臺 -> 左側公眾號設置 -> 功能設置 -> JS接口安全域名/網頁授權域名
需要下載微信的安全配置文件,放到咋們的服務器上,根據 授權的域名+認證文件 可以訪問后即可配置完成;需要注意的是,每次修改認證域名都會再次重新認證域名,所以認證以后文件請不要輕易刪除。
- PS:設置IP白名單,在IP白名單內的IP來源,獲取access_token接口才可調用成功。路徑:公眾平臺首頁 -> 基本配置
5、在商戶平臺開通相應的支付產品功能
登陸微信商戶平臺,進入產品中心,可以開通需要的支付產品,如公眾號支付、掃碼支付、刷卡支付、H5支付;
需要注意的是,在商戶平臺上小程序也屬于公眾號支付,不需要單獨開通。
- PS:如果公司需要做提現等功能,需要直接向用戶付款,那么需要開通 企業付款到零錢 產品功能,此功能主要用來解決合理的商戶對用戶付款需求,最終金額會直接到用戶微信零錢中;
如果公司需要向用戶銀行卡付款,則需要開通 企業付款到個人銀行卡 產品功能,該功能提供由商戶直接付錢至指定銀行卡賬戶的能力,主要用來解決合理的商戶對用戶付款需求。
如果公司提現是用公眾號為用戶發放紅包,那么需要開通 現金紅包 產品功能,企業向指定用戶發放現金紅包,紅包會顯示在服務號中,需要用戶領取,用戶在客戶端領取到紅包之后,所得金額進入微信錢包,可用于轉賬、支付或提取到銀行卡。
- 現金紅包PS:開通條件:入賬方式為即時入賬至商戶號,結算周期為T+1的商戶需滿足以下兩個條件:1.入駐滿90天,2.連續正常交易30天。其余結算周期的商戶無限制
6、在商戶平臺設置支付的相關ip授權
這里以公眾號支付為例,開通公眾號支付后,這是還不能進行開發,我們需要拿到商戶的幾個重要信息:
- APP_ID(公眾平臺獲取):公眾號/小程序開發者ID(AppID) -> 公眾平臺首頁 -> 基本配置
- APP_SECRET(公眾平臺獲取):開發者密碼(AppSecret) -> 公眾平臺首頁 -> 基本配置
- MCH_ID(商戶平臺獲取):商戶號 -> 商戶平臺首頁 -> 賬戶中心 -> 賬戶信息
- API_KEY(商戶平臺獲取):API密鑰 -> 商戶平臺首頁 -> 賬戶中心 -> API安全
- APICLIENT_CERT(商戶平臺獲取):安全證書路徑 -> 商戶平臺首頁 -> 賬戶中心 -> API安全
- PS:如果需要將小程序和公眾號聯通,需要在 公眾平臺首頁 -> 基本配置 中綁定同一個微信開放平臺帳號