剛做小程序支付,網上找了博客來看,看了很多方式實現,但多數都是上傳文件估計有殘缺或獲取其他總是測試出問題,無奈自己研究整理一下我的小程序支付測式,話不多說,開干
首先給大家推薦一個weixin-java-tool這個開源工具包,里面封裝了很多東西,用起來很方便,有空的小伙伴可以多研究研究這個
這是碼雲地址:https://gitee.com/itwu/weixin-java-tools
點擊demo項目到
找到自己需要的demo,我這里找的是微信支付,所以繼續微信支付 點擊微信支付的github
之后下載源碼,導入開發工具eclipse中
把demo項目啟動,項目啟動后發現項目中有swagger繼承的api可以通過路徑: localhost:8080/swagger-ui.html 查看接口文檔,這里可以找到自己的所要找的接口,我這里找到的是微信支付,其他的有時間的可以去多研究研究
這些就需要自己多花時間研究了,下面就來上重點了,繼承到自己項目中
1.在pom文件中加入maven依賴 <!--微信開源封裝sdk-->
版本跟自己下載的demo項目中的一致就行(我這里是<weixin-java-pay.version>3.9.0</weixin-java-pay.version>)
<dependency> <groupId>com.github.binarywang</groupId> <artifactId>weixin-java-pay</artifactId> <version>${weixin-java-pay.version}</version> </dependency>
2.把相關文件賦值到自己項目中
3.application.yml文件中添加配置
配置到此結束,下面上代碼了
4.新建控制層測試接口
接口測試代碼(只用寫這么多,其他的都是已經封裝好的直接調用就行)
@GetMapping("/createOrder") public <T> T createOrder(HttpServletRequest req) throws WxPayException { JSONObject obj = new JSONObject(ServletUtil.getParamMap(req)); JSONObject item = itemVkMapper.getItemInfo(obj); WxPayUnifiedOrderRequest WxPay = new WxPayUnifiedOrderRequest(); WxPay.setBody( "項目編號:" + item.getStr("itemid") + " 項目金額:" + item.getStr("money") + " 項目類型:" + item.getStr("zab_do")); WxPay.setOutTradeNo(IdUtil.simpleUUID()); WxPay.setTotalFee(1); WxPay.setSpbillCreateIp("127.0.0.1"); WxPay.setNotifyUrl(Variables.NOTIFY_URL); WxPay.setTradeType(Variables.TRADETYPE); WxPay.setOpenid(obj.getStr("openid")); // WxPayUnifiedOrderResult res = this.wxService.unifiedOrder(WxPay); return this.wxService.createOrder(WxPay); }
后端測試代碼到這里就結束了,來微信小程序前端對接接口
toPay: function (event) { var that = this wx.request({ // url: wx.getStorageSync('domainName') + '/api/itempay.ashx', //僅為示例,並非真實的接口地址 url: wx.getStorageSync('basePath') + '/pay/createOrder', method:'get', data: { itemid: event.target.dataset.itemid, userid: wx.getStorageSync('userId'), type: 'mp', openid: wx.getStorageSync('openid') }, header: { 'content-type': 'application/json' // 默認值 }, success: function (res) { // debugger; var param = res.data; wx.requestPayment( { 'timeStamp': param.timeStamp, 'nonceStr': param.nonceStr, 'package': param.packageValue, 'signType': 'MD5', 'paySign': param.paySign, 'success':function(result){ console.log(result); }, 'fail':function(result){ console.log(result); }, 'complete':function(result){ console.log(result); } }) } }) },
操作到此結束,現在開始測試
項目啟動准備測試 在微信開發工具中顯示
轉為真機調試測試結果為
ok了,其他的就自己測試測試了,言盡於此希望了能幫助到小伙伴們