刚做小程序支付,网上找了博客来看,看了很多方式实现,但多数都是上传文件估计有残缺或获取其他总是测试出问题,无奈自己研究整理一下我的小程序支付测式,话不多说,开干
首先给大家推荐一个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了,其他的就自己测试测试了,言尽于此希望了能帮助到小伙伴们