微信支付使用入门教程

2022-10-08 12:33:24 浏览数 (1)

第一章 微信扫码支付介绍

微信扫码支付就是我们目前生活中最常使用的移动端支付方式之一。

第二章 微信支付必要条件

我们要完成微信支付,那么我们客户自己是付款方,那么收款方呢?所以在这里我们需要一个收款方。那么要能够成为微信扫码支付的收款方,我们需要去申请微信的服务号,然后去开通扫码支付。(这个服务号个人无法申请,在这里不做教程说明)

第三章 微信支付流程介绍

微信支付模式介绍

模式一:商户必须在公众平台后台设置支付回调URL。

模式二:调用微信的接口,获取支付的地址。

在这里,我无法登陆后台,所以选择使用模式二。

模式二开发流程介绍

根据上述的时序图,得到如下的流程:注意上图中红色部分就是我们开发者需要做的部分

(1)商户后台系统根据用户选购的商品生成订单。

(2)用户确认支付后调用微信支付【统一下单API】生成预支付交易.

(3)微信支付收到请求后生成预支付交易单,并返回交易会话的二维码链接code_url

(4)商户后台系统根据返回的code_url生成二维码。

(5)用户打开微信“扫一扫”扫描二维码,微信客户端将扫码内容发送到微信支付系统。

(6)微信支付系统收到客户端请求,验证链接有效性后发起用户支付,要求用户授权。

(7)用户在微信客户端输入密码,确认支付后,微信客户端提交授权。

(8)微信支付系统根据用户授权完成支付交易。

(9)微信支付系统完成支付交易后给微信客户端返回交易结果,并将交易结果通过短信、微信消息提示用户。微信客户端展示支付交易结果页面。

(10)微信支付系统通过发送异步消息通知商户后台系统支付结果。商户后台系统需回复接收情况,通知微信后台系统不再发送该单的支付通知。

(11)未收到支付通知的情况,商户后台系统调用【查询订单API】。

(12)商户确认订单已支付后给用户发货。

第四章 核心流程所涉及的功能代码

1.调用微信的【统一下单API】,会的到微信支付的地址code_url

2.根据code_url生成二维码

3.调用【查询订单API】,查询微信支付的结果。

第五章 统一下单api代码说明

首先需要下载微信支付的jar包【SDK与DEMO下载】

其中,企业公众号id、api秘钥、商户账号需要申请服务号才能拥有,可以查看第二章,这里公司隐私,不能透露

收款方的配置文件

代码语言:javascript复制
public class MyConfig implements WXPayConfig {
 //获取 App ID(企业方公众号Id)
 @Override
 public String getAppID() {
     return "*****************";
 }
  //获取 API 密钥
 @Override
 public String getKey() {
     return "*****************";
 }
 //获取 Mch ID(商户账号)
 @Override
 public String getMchID() {
     return "****************";
 }

 //获取商户证书内容(我们这里不需要证书)
 @Override
 public InputStream getCertStream() {
     // TODO Auto-generated method stub
     return null;
 }

 //HTTP(S) 连接超时时间,单位毫秒
 @Override
 public int getHttpConnectTimeoutMs() {
     // TODO Auto-generated method stub
     return 8000;
 }

 //HTTP(S) 读数据超时时间,单位毫秒
 @Override
 public int getHttpReadTimeoutMs() {
     return 10000;
 }
}

统一下单DEMO

详细参数点击【统一下单API】

代码语言:javascript复制
public class WXPayUtils {
   public static void main(String[] args) throws Exception {
     MyConfig config = new MyConfig();
     //加载微信支付的企业参数
     WXPay wxpay = new WXPay(config);
     //设置微信支付的参数
     Map<String, String> data = new HashMap<String, String>();
     //商品的描述
     data.put("body", "estore商城");
     //订单号,订单号必须唯一。自己测试请切换其他订单号
     data.put("out_trade_no", "20160909105sss00000012");
     //设备号,无关
     data.put("device_info", "");
     //币种   人民币
     data.put("fee_type", "CNY");
     //支付金额
     data.put("total_fee", "50");
     data.put("spbill_create_ip", "123.12.12.123");
     //异步接收微信支付结果通知的回调地址,通知url必须为外网可访问的url,不能携带参数。我们不适用异步通知,但是这里的参数必须要有
     data.put("notify_url", "http://www.example.com/wxpay/notify");
     data.put("trade_type", "NATIVE");  // 此处指定为扫码支付
     data.put("product_id", "12");

     try {
         Map<String, String> resp = wxpay.unifiedOrder(data);
         for(Map.Entry<String, String> entry:resp.entrySet()){
               String key = entry.getKey();
               String value = entry.getValue();
               System.out.println(key ":" value);
         }
     } catch (Exception e) {
         e.printStackTrace();
     }
 }
} 

输出结果

输出结果是一个map集合,map集合的详细参数介绍同样点击【统一下单API】,重点是,获取map集合中的key为code_url的值,这个就是微信支付的地址。

第六章 二维码生成介绍

我们通常扫描二维码,其实可以发现访问了一个地址。说白了,二维码的本质就是一个网络资源的地址。二维码的生成是通过js插件生成的。

【qrcode.js下载】

代码语言:javascript复制
<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8" />
 <title></title>
</head>
<body>
 <!--
  定义一个div,用于生成二维码      
 -->
 <div id="qrcode"></div>
</body>
<script src="js/qrcode.js"></script>
<script>
 //获取div标签对象
 var qrcodeDiv = document.getElementById("qrcode");
 //第一个参数:二维码图片存放的标签对象        第二个参数:就是扫描二维码,访问的地址。
 new QRCode(qrcodeDiv,"http://www.baidu.com");
</script>
</html>

结果如图:

切换参数中的百度的地址为我们第五章中生成的支付地址weixin://wxpay/bizpayurl?pr=XmGVcaw

七章 查询订单API代码说明

详细参数请参考【查询订单API】

代码语言:javascript复制
public static void main(String[] args) throws Exception {
 //加载企业参数
  MyConfig config = new MyConfig();
 WXPay wxpay = new WXPay(config);
 //设置需要查询的订单的单号
 Map<String, String> data = new HashMap<String, String>();
 data.put("out_trade_no", "20160909105s6s00000012");
 //输出查询的结果
 try {
 Map<String, String> resp = wxpay.orderQuery(data);
 /*
  trade_state代表的就是订单支付结果
   SUCCESS—支付成功
  REFUND—转入退款
 NOTPAY—未支付
 CLOSED—已关闭
 REVOKED—已撤销(刷卡支付)
 USERPAYING--用户支付中
 PAYERROR--支付失败(其他原因,如银行返回失败)
 */
 for(Map.Entry<String, String> entry:resp.entrySet()){
  String key = entry.getKey();
  String value = entry.getValue();
  System.out.println(key ":" value);
           }
       } catch (Exception e) {
 e.printStackTrace();
       }
}

返回值同样是一个map集合,其中trade_state的key所对应的值就是订单的交易状态。

参数结果:

第八章:总结

1.必须申请公众号,获取微信支付的参数。

2.在MyConfig中设置微信支付的参数

3.调用微信支付的下单的api,填写指定参数,获取支付的url地址

4.调用现有的js,给定指定的url地址参数,生成扫码支付的二维码地址

5.后台轮询查询订单的支付状态

0 人点赞