微信小程序集成微信支付开发,后端是springboot项目
<h1>一、准备工作</h1><p>首先是进入到小程序后台关联微信支付商户、以及接入微信支付申请</p>
<p><img src="https://img2023.cnblogs.com/blog/1112095/202305/1112095-20230522215125122-291723166.png"></p>
<p> </p>
<p><img src="https://img2023.cnblogs.com/blog/1112095/202305/1112095-20230522215245729-592459557.png"></p>
<h1>二、小程序端代码</h1>
<p>主要是用到了 wx.requestPayment API</p>
<h2>2.1 在wxml文件中添加支付按钮</h2>
<pre class="code-block-wrapper"><code class="hljs code-block-body html"><span class="hljs-tag"><<span class="hljs-name">button <span class="hljs-attr">bindtap=<span class="hljs-string">"requestPayment">支付<span class="hljs-tag"></<span class="hljs-name">button>
</span></span></span></span></span></span></code></pre>
<h2>2.2 在wxss文件中定义支付按钮样式</h2>
<pre class="code-block-wrapper"><code class="hljs code-block-body css"><span class="hljs-selector-tag">button {
<span class="hljs-attribute">background-color: <span class="hljs-number">#00bfff;
<span class="hljs-attribute">color: <span class="hljs-number">#fff;
<span class="hljs-attribute">border: none;
<span class="hljs-attribute">border-radius: <span class="hljs-number">4px;
<span class="hljs-attribute">padding: <span class="hljs-number">10rpx;
<span class="hljs-attribute">font-size: <span class="hljs-number">16rpx;
}
</span></span></span></span></span></span></span></span></span></span></span></span></code></pre>
<h2>2.3 在js文件中编写调起支付接口的函数</h2>
<pre class="code-block-wrapper"><code class="hljs code-block-body javascript"><span class="hljs-keyword">const app = <span class="hljs-title function_">getApp();
<span class="hljs-title class_">Page({
<span class="hljs-attr">data: {
<span class="hljs-comment">// 支付参数
<span class="hljs-attr">paymentParams: {}
},
<span class="hljs-comment">// 点击支付按钮触发的函数
<span class="hljs-title function_">requestPayment(<span class="hljs-params">) {
wx.<span class="hljs-title function_">request({
<span class="hljs-attr">url: <span class="hljs-string">'https://yourdomain.com/user/createOrder', <span class="hljs-comment">// 后端服务获取支付参数
<span class="hljs-attr">success: <span class="hljs-function">(<span class="hljs-params">res) => {
<span class="hljs-keyword">const paymentParams = res.<span class="hljs-property">data.<span class="hljs-property">paymentParams;
wx.<span class="hljs-title function_">requestPayment({
<span class="hljs-attr">nonceStr: paymentParams.<span class="hljs-property">nonceStr,
<span class="hljs-attr">package: paymentParams.<span class="hljs-property">package,
<span class="hljs-attr">paySign: paymentParams.<span class="hljs-property">paySign,
<span class="hljs-attr">signType: paymentParams.<span class="hljs-property">signType,
<span class="hljs-attr">timeStamp: paymentParams.<span class="hljs-property">timeStamp,
<span class="hljs-attr">success: <span class="hljs-function">(<span class="hljs-params">res) => {
<span class="hljs-comment">// 支付成功后的处理逻辑
},
<span class="hljs-attr">fail: <span class="hljs-function">(<span class="hljs-params">res) => {
<span class="hljs-comment">// 支付失败后的处理逻辑
}
})
},
<span class="hljs-attr">fail: <span class="hljs-function">(<span class="hljs-params">res) => {
<span class="hljs-comment">// 获取支付参数失败后的处理逻辑
}
});
}
});</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></code></pre>
<h1>三、后端服务代码</h1>
<p>这边后端是用Java开发的,SpringBoot2.0小程序支付功能实现weixin-java-pay,主要是用到了第三方封装好的微信支付SDK</p>
<blockquote>
<p>WxJava - 微信开发 Java SDK(开发工具包); 支持包括微信支付、开放平台、公众号、企业微信/企业号、小程序等微信功能的后端开发。</p>
</blockquote>
<h2 id="hsdk">3.1 SDK使用方式</h2>
<p>Maven方式引入:</p>
<pre class="highlighter-hljs"><code class="xml language-xml hljs highlighter-hljs"><span class="hljs-tag"><<span class="hljs-name">dependency>
<span class="hljs-tag"><<span class="hljs-name">groupId>com.github.binarywang<span class="hljs-tag"></<span class="hljs-name">groupId>
<span class="hljs-tag"><<span class="hljs-name">artifactId>(不同模块参考下文)<span class="hljs-tag"></<span class="hljs-name">artifactId>
<span class="hljs-tag"><<span class="hljs-name">version>3.3.0<span class="hljs-tag"></<span class="hljs-name">version>
<span class="hljs-tag"></<span class="hljs-name">dependency>
</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></code></pre>
<p>各模块的<strong>artifactId:</strong></p>
<ul>
<li>微信小程序:<code>weixin-java-miniapp</code></li>
<li>微信支付:<code>weixin-java-pay</code></li>
<li>微信开放平台:<code>weixin-java-open</code></li>
<li>公众号(包括订阅号和服务号):<code>weixin-java-mp</code></li>
<li>企业号/企业微信:<code>weixin-java-cp</code></li>
</ul>
<h2 id="h">3.2 配置微信相关信息</h2>
<p>application.yml</p>
<pre class="highlighter-hljs"><code class="yaml language-yaml highlighter-hljs hljs"><span class="hljs-comment">#微信小程序配置
<span class="hljs-attr">wx:
<span class="hljs-attr">miniapp:
<span class="hljs-attr">configs:
<span class="hljs-string">- <span class="hljs-string">appid: <span class="hljs-comment">#微信公众号或者小程序等的appid 必填
<span class="hljs-string">secret: <span class="hljs-comment">#微信公众号或者小程序等的secret 必填
<span class="hljs-string">token: <span class="hljs-comment">#微信小程序消息服务器配置的token
<span class="hljs-string">aesKey: <span class="hljs-comment">#微信小程序消息服务器配置的EncodingAESKey
<span class="hljs-string">msgDataFormat: <span class="hljs-string">JSON
<span class="hljs-attr">pay:
<span class="hljs-string">appId: <span class="hljs-comment">#微信公众号或者小程序等的appid 必填
<span class="hljs-string">mchId: <span class="hljs-comment">#微信支付商户号 必填
<span class="hljs-string">mchKey: <span class="hljs-comment">#微信支付商户密钥
<span class="hljs-string">subAppId: <span class="hljs-comment">#服务商模式下的子商户公众账号ID
<span class="hljs-string">subMchId: <span class="hljs-comment">#服务商模式下的子商户号
<span class="hljs-string">keyPath: <span class="hljs-string">classpath:cert/apiclient_cert.p12 <span class="hljs-comment"># p12证书的位置,可以指定绝对路径,也可以指定类路径(以classpath:开头)
<span class="hljs-string">notifyUrl: <span class="hljs-string">https://www.xxx.com/wx/notify <span class="hljs-comment">#微信支付回调地址 自己定义但是必须放到外网微信可以访问的到
</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></code></pre>
<h2 id="h-1">3.3 编写统一订单接口业务</h2>
<p>调用统一下单支付接口:<strong>wxService.createOrder(orderRequest)</strong></p>
<pre class="highlighter-hljs"><code class="java language-java hljs highlighter-hljs"><span class="hljs-comment">/**
<span class="hljs-doctag"><span class="hljs-doctag"><span class="hljs-doctag"> * <span class="hljs-doctag">@Author 夏威夷8080
* <span class="hljs-doctag">@DateTime 2019年4月6日 上午11:54:08
* <span class="hljs-doctag">@version V1.0
*/
<span class="hljs-keyword">
<span class="hljs-keyword">import java.math.BigDecimal;
<span class="hljs-keyword">import java.text.SimpleDateFormat;
<span class="hljs-keyword">import java.util.Date;
<span class="hljs-keyword">import java.util.HashMap;
<span class="hljs-keyword">import java.util.Map;
<span class="hljs-keyword">import javax.servlet.http.HttpServletRequest;
<span class="hljs-keyword">import javax.servlet.http.HttpServletResponse;
<span class="hljs-keyword">import javax.servlet.http.HttpSession;
<span class="hljs-keyword">import org.apache.commons.io.IOUtils;
<span class="hljs-keyword">import org.apache.commons.lang3.StringUtils;
<span class="hljs-keyword">import org.springframework.beans.factory.annotation.Autowired;
<span class="hljs-keyword">import org.springframework.beans.factory.annotation.Value;
<span class="hljs-keyword">import org.springframework.web.bind.annotation.PostMapping;
<span class="hljs-keyword">import org.springframework.web.bind.annotation.RequestBody;
<span class="hljs-keyword">import org.springframework.web.bind.annotation.RequestMapping;
<span class="hljs-keyword">import org.springframework.web.bind.annotation.ResponseBody;
<span class="hljs-keyword">import org.springframework.web.bind.annotation.RestController;
<span class="hljs-keyword">import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
<span class="hljs-keyword">import com.github.binarywang.wxpay.bean.notify.WxPayNotifyResponse;
<span class="hljs-keyword">import com.github.binarywang.wxpay.bean.notify.WxPayOrderNotifyResult;
<span class="hljs-keyword">import com.github.binarywang.wxpay.bean.request.WxPayUnifiedOrderRequest;
<span class="hljs-keyword">import com.github.binarywang.wxpay.bean.result.BaseWxPayResult;
<span class="hljs-keyword">import com.github.binarywang.wxpay.constant.WxPayConstants;
<span class="hljs-keyword">import com.github.binarywang.wxpay.exception.WxPayException;
<span class="hljs-keyword">import com.github.binarywang.wxpay.service.WxPayService;
<span class="hljs-keyword">import io.renren.common.utils.DateUtils;
<span class="hljs-keyword">import io.renren.common.utils.IPUtils;
<span class="hljs-keyword">import io.renren.common.utils.PageUtils;
<span class="hljs-keyword">import io.renren.common.utils.R;
<span class="hljs-keyword">import io.renren.modules.soft.entity.AuthorizationEntity;
<span class="hljs-keyword">import io.renren.modules.soft.entity.HospitalEntity;
<span class="hljs-keyword">import io.renren.modules.soft.entity.OrderEntity;
<span class="hljs-keyword">import io.renren.modules.soft.entity.PayFlowEntity;
<span class="hljs-keyword">import io.renren.modules.soft.entity.PurchaseRecordEntity;
<span class="hljs-keyword">import io.renren.modules.soft.entity.RefundRecordEntity;
<span class="hljs-keyword">import io.renren.modules.soft.service.AuthorizationService;
<span class="hljs-keyword">import io.renren.modules.soft.service.BedBaseService;
<span class="hljs-keyword">import io.renren.modules.soft.service.DeviceService;
<span class="hljs-keyword">import io.renren.modules.soft.service.HospitalService;
<span class="hljs-keyword">import io.renren.modules.soft.service.OrderService;
<span class="hljs-keyword">import io.renren.modules.soft.service.PayFlowService;
<span class="hljs-keyword">import io.renren.modules.soft.service.PurchaseRecordService;
<span class="hljs-keyword">import io.renren.modules.soft.service.RefundRecordService;
<span class="hljs-keyword">import io.renren.modules.soft.service.StatementService;
<span class="hljs-keyword">import io.renren.modules.soft.service.ThirdUserService;
<span class="hljs-keyword">import io.renren.modules.soft.service.UserAuthorizationService;
<span class="hljs-keyword">import io.renren.modules.soft.service.UserService;
<span class="hljs-keyword">import io.swagger.annotations.Api;
<span class="hljs-keyword">import io.swagger.annotations.ApiImplicitParam;
<span class="hljs-keyword">import io.swagger.annotations.ApiImplicitParams;
<span class="hljs-keyword">import io.swagger.annotations.ApiOperation;
<span class="hljs-keyword">import lombok.extern.slf4j.Slf4j;
<span class="hljs-comment">/**
* <span class="hljs-doctag">@ClassName: WxUserVedioController
* <span class="hljs-doctag">@Description:
* <span class="hljs-doctag">@Author 夏威夷8080
* <span class="hljs-doctag">@DateTime 2019年4月6日 上午11:54:08
*/
<span class="hljs-meta">@Api(tags = "普通用户操作接口")
<span class="hljs-meta">@RestController
<span class="hljs-meta">@RequestMapping("/wx")
<span class="hljs-meta">@Slf4j
<span class="hljs-keyword">public <span class="hljs-keyword">class <span class="hljs-title class_">WxxxxUserVedioController {
<span class="hljs-meta">@Value("${wx.notifyUrl}")
<span class="hljs-keyword">private String notifyUrl;
<span class="hljs-meta">@Autowired
<span class="hljs-keyword">private WxPayService wxService;
<span class="hljs-meta">@Autowired
<span class="hljs-keyword">private HospitalService hospitalService;
<span class="hljs-meta">@Autowired
<span class="hljs-keyword">private PayFlowService payFlowService;
<span class="hljs-meta">@Autowired
<span class="hljs-keyword">private OrderService orderService;
<span class="hljs-comment">/**
* <span class="hljs-doctag">@Title: createOrder
* <span class="hljs-doctag">@Description:
* <span class="hljs-doctag">@Author 夏威夷8080
* <span class="hljs-doctag">@DateTime 2019年4月6日 下午12:12:11
* <span class="hljs-doctag">@param
* <span class="hljs-doctag">@return
*/
<span class="hljs-meta">@PostMapping("/user/createOrder")
<span class="hljs-keyword">public R <span class="hljs-title function_">createOrder<span class="hljs-params">(HttpServletRequest request,<span class="hljs-meta">@RequestBody Map<String,String> map) <span class="hljs-keyword">throws WxPayException{
<span class="hljs-type">String <span class="hljs-variable">bed_id <span class="hljs-operator">= map.get(<span class="hljs-string">"bedId");
log.info(<span class="hljs-string">"参数的bed_id:{}", bed_id);
<span class="hljs-keyword">if (StringUtils.isAnyBlank(bed_id)) {
<span class="hljs-keyword">return R.error(<span class="hljs-string">"参数不能为null");
}
<span class="hljs-type">Long <span class="hljs-variable">bedId <span class="hljs-operator">= Long.valueOf(bed_id).longValue();
<span class="hljs-comment">//根据bedId 查找所属医院的价格
<span class="hljs-type">HospitalEntity <span class="hljs-variable">hospitalEntity <span class="hljs-operator">= hospitalService.hospitalByBedId(bed_id.trim());
<span class="hljs-type">BigDecimal <span class="hljs-variable">money <span class="hljs-operator">= hospitalEntity.getCharge();
<span class="hljs-type">HttpSession <span class="hljs-variable">session <span class="hljs-operator">= request.getSession();
<span class="hljs-type">String <span class="hljs-variable">mobile <span class="hljs-operator">= (String) session.getAttribute(<span class="hljs-string">"userphone");
<span class="hljs-type">String <span class="hljs-variable">userId <span class="hljs-operator">= (String) session.getAttribute(<span class="hljs-string">"userId");
<span class="hljs-comment">// TODO 插入订单记录
<span class="hljs-comment">// TODO 记录用户的购买记录
<span class="hljs-comment">// TODO 调用统一生成订单接口
<span class="hljs-type">WxPayUnifiedOrderRequest <span class="hljs-variable">orderRequest <span class="hljs-operator">= <span class="hljs-keyword">new <span class="hljs-title class_">WxPayUnifiedOrderRequest();
orderRequest.setSignType(WxPayConstants.SignType.MD5);
orderRequest.setBody(<span class="hljs-string">"短信主体");
orderRequest.setOutTradeNo(order_No); <span class="hljs-comment">//自己生成order_No
orderRequest.setTradeType(WxPayConstants.TradeType.JSAPI);
<span class="hljs-comment">// orderRequest.setTotalFee(BaseWxPayRequest.yuanToFen(yuanMoney));//直接分
orderRequest.setTotalFee(money.intValue());<span class="hljs-comment">//直接分
orderRequest.setOpenid(userEntity.getOpenid()); <span class="hljs-comment">// 获取微信支付用户的openId
orderRequest.setSpbillCreateIp(IPUtils.getIpAddr(request));
<span class="hljs-type">Date <span class="hljs-variable">now <span class="hljs-operator">= <span class="hljs-keyword">new <span class="hljs-title class_">Date();
<span class="hljs-type">Date <span class="hljs-variable">afterDate <span class="hljs-operator">= DateUtils.addDateMinutes(now, <span class="hljs-number">10);<span class="hljs-comment">//10分钟后
orderRequest.setTimeStart(DateUtils.format(now, <span class="hljs-string">"yyyyMMddHHmmss"));
orderRequest.setTimeExpire(DateUtils.format(afterDate, <span class="hljs-string">"yyyyMMddHHmmss"));
orderRequest.setNotifyUrl(notifyUrl);
<span class="hljs-type">Object <span class="hljs-variable">order <span class="hljs-operator">= wxService.createOrder(orderRequest);
<span class="hljs-keyword">return R.ok().put(<span class="hljs-string">"order", order);
}
<span class="hljs-meta">@ApiOperation("微信支付回调地址")
<span class="hljs-meta">@ResponseBody
<span class="hljs-meta">@PostMapping("/notify")
<span class="hljs-keyword">public String <span class="hljs-title function_">payNotify<span class="hljs-params">(HttpServletRequest request, HttpServletResponse response) {
<span class="hljs-keyword">try {
<span class="hljs-comment">/*HttpSession session = request.getSession();
String mobile = (String) session.getAttribute("userphone");
if (StringUtils.isBlank(mobile)) {
return R.error(401, "session获取不到授权手机号!");
}
//获取用户手机号,根据用户手机号获取用户ID
AuthorizationEntity user = authorizationService.getOneByMobile(mobile);*/
<span class="hljs-type">String <span class="hljs-variable">xmlResult <span class="hljs-operator">= IOUtils.toString(request.getInputStream(), request.getCharacterEncoding());
<span class="hljs-type">WxPayOrderNotifyResult <span class="hljs-variable">notifyResult <span class="hljs-operator">= wxService.parseOrderNotifyResult(xmlResult);
<span class="hljs-comment">// 结果正确 outTradeNo
<span class="hljs-type">String <span class="hljs-variable">orderId <span class="hljs-operator">= notifyResult.getOutTradeNo();
<span class="hljs-type">String <span class="hljs-variable">tradeNo <span class="hljs-operator">= notifyResult.getTransactionId();
<span class="hljs-type">String <span class="hljs-variable">totalFee <span class="hljs-operator">= BaseWxPayResult.fenToYuan(notifyResult.getTotalFee());
<span class="hljs-keyword">if(<span class="hljs-string">"SUCCESS".equals(notifyResult.getResultCode())) {
<span class="hljs-type">PayFlowEntity <span class="hljs-variable">entity <span class="hljs-operator">= <span class="hljs-keyword">new <span class="hljs-title class_">PayFlowEntity();
entity.setPayFee(BigDecimal.valueOf(notifyResult.getCashFee()));
entity.setPayFlowNo(orderId);
entity.setPayUserInfo(notifyResult.getOpenid());
entity.setThreeInNo(tradeNo);
payFlowService.save(entity);
<span class="hljs-type">OrderEntity <span class="hljs-variable">order_entity <span class="hljs-operator">= <span class="hljs-keyword">new <span class="hljs-title class_">OrderEntity();
<span class="hljs-type">SimpleDateFormat <span class="hljs-variable">sdf <span class="hljs-operator">= <span class="hljs-keyword">new <span class="hljs-title class_">SimpleDateFormat(<span class="hljs-string">"yyyyMMddHHmmss");
order_entity.setCreateTime(<span class="hljs-keyword">new <span class="hljs-title class_">Date());
<span class="hljs-comment">//更新订单信息
UpdateWrapper<OrderEntity> updateWrapper = <span class="hljs-keyword">new <span class="hljs-title class_">UpdateWrapper<>();
updateWrapper.set(<span class="hljs-string">"order_status", <span class="hljs-string">"1");
updateWrapper.set(<span class="hljs-string">"pay_id", notifyResult.getOpenid());
updateWrapper.set(<span class="hljs-string">"pay_status", <span class="hljs-string">"1");
updateWrapper.set(<span class="hljs-string">"pay_end_time", sdf.parse(notifyResult.getTimeEnd()));
updateWrapper.eq(<span class="hljs-string">"order_no",notifyResult.getOutTradeNo());
orderService.update(updateWrapper);
}
<span class="hljs-comment">//自己处理订单的业务逻辑,需要判断订单是否已经支付过,否则可能会重复调用
<span class="hljs-keyword">return WxPayNotifyResponse.success(<span class="hljs-string">"成功");
} <span class="hljs-keyword">catch (Exception e) {
log.error(<span class="hljs-string">"微信回调结果异常,异常原因{}", e.getMessage());
<span class="hljs-comment">// WxPayNotifyResponse.fail(e.getMessage());
<span class="hljs-keyword">return WxPayNotifyResponse.success(<span class="hljs-string">"code:"+<span class="hljs-number">9999+<span class="hljs-string">"微信回调结果异常,异常原因:"+e.getMessage());
}
}
}
</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></code></pre>
<h1> 四、总结</h1>
<div>梳理下简单流程</div>
<div>后端生成预订单返回给前端 -> 前端拿到订单信息调用 wx.requestPayment API进行支付 -> 支付成功,跳转到回调地址 -> 在回调url里处理支付成功后的业务逻辑</div>
<p> </p><br><br>
来源:https://www.cnblogs.com/shamo89/p/17421896.html
頁:
[1]