微信公众号对接JSAPI模式的微信支付简介与总结

步骤一:初始化微信支付框架

(一)、官方文档说明:




(二)、注意事项:

1.附录1红框中所说的access_token不是通过code获取的用户access_token,具体获取方式请点击对应链接;

2.jsapi_ticket必须缓存,不然客户端每访问一次就刷新一次的话,后一次返回之后,前一次使用的jsapi_ticket就失效了;

3.初始化方法中使用到的timestamp和nonceStr参数和后台调用统一下单接口中的参数需要一致,否则容易报“订单信息错误”异常;

4.signature签名生成中用到的url参数是完全URL地址(包含后面带的参数)。正常如http://URL/index.html?code=021dba33f98bec86933e96e2a80f115l&state=123。


步骤二:调用微信支付

(一)、官方文档说明:



(二)、注意事项:

1.prepay_id 通过微信支付统一下单接口拿到,统一下单接口中的openid参数(trade_type=JSAPI,此参数必传)需要公众号中跳转到业务页面时获取的code获取,并且通一下单接口中的生成签名用到的参数必须是非空参数;

2.paySign支付签名生成时,


参数名要写正确。本人当时误把红框中的参数写成appid导致一直提示“签名失败”;(补充:在对接APP模式的支付的时候,这些参数又必须是小写的。具体可参见https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=9_12)

3.联调的时候,在公众号平台配置测试地址和测试的微信号。


步骤三:处理支付通知

(一)、官方文档说明:



(二)、注意事项:

1.支付通知地址为“统一下单接口”中传的notify_url参数;

2.验签时注意参与签名的参数需要时非null和非空的参数。


参考文档:

1.http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html 微信JSSDK官方文档

2.https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1 微信支付统一下单等接口官方说明文档

3.http://blog.youkuaiyun.com/fuyifang/article/details/40707517 微信openid获取的几种方法介绍

4.http://www.cnblogs.com/txw1958/p/wxpayv3-jsapi.html 通过微信官方文档接口介绍对接步骤的文档

5.http://blog.youkuaiyun.com/molaifeng/article/details/42968673 微信支付可能遇到的一些坑

6.https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=9_1 微信APP支付官方文档


### 实现Java对接微信公众号JSAPI支付(V2版本) #### Maven依赖 为了实现微信公众号JSAPI支付接口对接,首先需要引入必要的Maven依赖: ```xml <dependency> <groupId>com.github.wechatpay-apiv3</groupId> <artifactId>wechatpay-java</artifactId> <version>0.2.7</version> </dependency> ``` 此依赖提供了处理微信支付所需的工具和支持[^2]。 #### 构造统一下单请求参数 在进行支付前,服务器需向微信发起统一订单创建请求。以下是构建该请求所需的主要字段及其说明: | 参数名 | 类型 | 描述 | | --- | --- | --- | | appid | String | 应用ID | | mch_id | String | 商户号 | | nonce_str | String | 随机字符串 | | sign_type | String | 签名类型,默认为MD5 | | body | String | 商品描述 | | out_trade_no | String | 商家订单号 | | total_fee | Integer | 订单总金额(分) | | spbill_create_ip | String | 客户端IP地址 | | notify_url | String | 接收异步通知URL | 这些信息会被封装成`UnifiedOrderRequest`对象并提交给微信支付平台以获取支付交易会话标识(prepay_id)[^1]。 #### 获取prepay_id后的前端调起支付配置 当成功获得`prepay_id`之后,服务端应返回如下JSON结构供前端页面使用JavaScript API完成实际付款流程: ```json { "appId": "", "timeStamp": "", "nonceStr": "", "package": "prepay_id=", "signType":"", "paySign":"" } ``` 其中各个属性的具体含义已在上述表格中有所提及;而`paySign`则是基于以上五个键值对按照特定规则计算得出的签名结果。 #### Java代码示例 下面给出一段简单的Spring Boot风格的服务方法用于处理整个过程中的核心逻辑部分——即生成下单请求以及解析响应数据提取出`prepay_id`: ```java import com.github.wxpay.sdk.WXPayUtil; // ... other imports ... @Service public class WeChatPaymentService { private static final Logger logger = LoggerFactory.getLogger(WeChatPaymentService.class); @Value("${wechat.app.id}") private String appId; // Other properties like merchant id, key... public Map<String, Object> createPrepay(String orderId, int amountInFen) throws Exception { SortedMap<String, String> params = new TreeMap<>(); // Fill required parameters... params.put("appid", this.appId); params.put("mch_id", this.merchantId); params.put("body", "Test Product"); params.put("out_trade_no", orderId); params.put("total_fee", String.valueOf(amountInFen)); params.put("spbill_create_ip", getLocalIp()); params.put("notify_url", notificationUrl); params.put("trade_type", "JSAPI"); // Add more fields as needed according to your business requirements String xmlString = WXPayUtil.generateSignedXml(params, this.key); HttpClient client = HttpClients.createDefault(); HttpPost post = new HttpPost("https://api.mch.weixin.qq.com/pay/unifiedorder"); post.setEntity(new StringEntity(xmlString)); HttpResponse response = client.execute(post); if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK){ String responseBody = EntityUtils.toString(response.getEntity(), StandardCharsets.UTF_8); try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); InputSource is = new InputSource(new StringReader(responseBody)); org.w3c.dom.Document document = builder.parse(is); NodeList prepayIdNodes = document.getElementsByTagName("prepay_id"); if(prepayIdNodes.getLength()>0){ Element element=(Element)prepayIdNodes.item(0); return buildFrontEndConfig(element.getTextContent()); }else{ throw new RuntimeException("Failed to obtain prepay_id from wechat server."); } } catch (Exception e) { logger.error(e.getMessage(),e); throw e; } } else { throw new IOException("Unexpected status code:" + response.getStatusLine().getStatusCode()); } } private Map<String,Object> buildFrontEndConfig(String prepayId)throws Exception{ long timestamp=System.currentTimeMillis()/1000L;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值