第一章 微信扫码支付介绍
微信扫码支付就是我们目前生活中最常使用的移动端支付方式之一。
第二章 微信支付必要条件
我们要完成微信支付,那么我们客户自己是付款方,那么收款方呢?所以在这里我们需要一个收款方。那么要能够成为微信扫码支付的收款方,我们需要去申请微信的服务号,然后去开通扫码支付。(这个服务号个人无法申请,在这里不做教程说明)
第三章 微信支付流程介绍
微信支付模式介绍
模式一:商户必须在公众平台后台设置支付回调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.后台轮询查询订单的支付状态