七 SpringCloud - 微信支付

1、开发文档微信开发文档:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1

七 SpringCloud - 微信支付

文章插图
安全规范:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=4_3
1、签名算法(签名校验工具)签名生成的通用步骤如下:第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA 。特别注意以下重要规则:◆ 参数名ASCII码从小到大排序(字典序);◆ 如果参数的值为空不参与签名;◆ 参数名区分大小写;◆ 验证调用返回或微信主动通知签名时,传送的sign参数不参与签名 , 将生成的签名与该sign值作校验 。◆ 微信接口可能增加字段,验证签名时必须支持增加的扩展字段第二步,在stringA最后拼接上key得到stringSignTemp字符串,并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue 。注意:密钥的长度为32个字节 。2、配置信息 和 工具类2.1 核心配置文件application.yml
#端口server:port: 8096#微信支付自定义配置参数wechat:pay:app-id: xxxx # 公众账号IDmch-id: xxxx # 商户号IDmch-key: xxxxx # 商户密钥order-uri: https://api.mch.weixin.qq.com/pay/unifiedorder # 请求微信支付接口统一下单地址notify-uri: http://xxxxx.natappfree.cc/wxpay/notifyresult # 微信支付结果回调地址view-order-status-uri: https://api.mch.weixin.qq.com/pay/orderquery#查询订单状态地址注意:其中的回调地址,需要内网穿透;
2.2 自定义配置类/** * Created On : 3/11/2022. * <p> * Author : huayu * <p> * Description: 自定义配置类 */@Data@Component@ConfigurationProperties(prefix = "wechat.pay")public class WechatPayConfig {/*公众账号ID*/private String appId;/*商户号ID*/private String mchId;/*商户密钥*/privateString mchKey;/*请求微信支付接口统一下单地址*/private String orderUri;/*微信支付结果回调地址*/private String notifyUri;/*主动查询订单状态地址*/private String viewOrderStatusUri;}2.3 常量类/** * Created On : 3/11/2022. * <p> * Author : huayu * <p> * Description: 微信支付常量类 */public class WechatPayConstant {//系统交易订单号的浅醉标识符public static final String WECHAT_PAY_TRADE_ORDER_PREFIX ="kh";//系统格式化日期字符串 , 到秒public static final String WECHAT_PAY_TIME_PATTERN_ALL = "yyyyMMddHHmmss";//系统格式化日期字符串,到天public static final String WECHAT_PAY_TIME_PATTERN_DAY = "yyyyMMdd";//微信支付的交易类型:naivepublic static final String WECHAT_PAY_TRADE_NATIVE = "NATIVE";//微信支付的签名方式MD5public static final String WECHAT_PAY_SIGN_TYPE_MD5= "MD5";//微信支付的签名参数名public static final String WECHAT_PAY_FIELD_SIGN = "sign";//微信支付下单请求的字符集编码public static final String WECHAT_PAY_ENCODING_UTF8="UTF-8";//微信支付下单结果的成功状态码public static final String WECHAT_PAY_RESULT_SUCCESS = "SUCCESS";//微信支付结果异步回调的同步响应,成功public static final String WECHAT_PAY_NOTIFY_SUCCESS="<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";//微信支付结果异步回调的同步响应,失败public static final String WECHAT_PAY_NOTIFY_FALL="<xml><return_code><![CDATA[FALL]]></return_code><return_msg><![CDATA[NOOK]]></return_msg></xml>";//订单查询 结果成功的状态码public static final String WECHAT_PAY_VIEW_ORDER_STATUS_SUCCESS = "SUCCESS";}2.4 工具类WechatPayUtil 和 WechatPayXmlUtil :https://www.cnblogs.com/xiaoqigui/p/16855921.html
HttpClient4Util http请求工具类:https://www.cnblogs.com/xiaoqigui/p/16839536.html
3、请求微信统一下单接口,下单支付订单 , 返回支付链接
  1. 获取参数,放进map集合中并按key值,字典排序 。
  2. 通过参数生成签名(生成的签名也放进map集合) 。
  3. 将map集合转成xml字符串 。
  4. 获取微信支付统一下单地址,xml参数字符串作为参数发送请求 。
  5. 返回支付的链接(可以生成二维码给用户扫码支付) 。
3.0 参数列表
七 SpringCloud - 微信支付

文章插图
3.1 接口/** * Created On : 3/11/2022. * <p> * Author : huayu * <p> * Description: 微信支付业务接口 */public interface WechatPayService {/*** @author : huayu* @date: 3/11/2022* @param: []* @return : java.lang.String* @description : 生成请求微信支付接口的统一下单接口参数 ,返回xml格式字符串*/String generateWxUnifyOrderXmlParams(String productBody,int totalFee) throws Exception;/*** @author : huayu* @date: 3/11/2022* @param: [unifyOrderXmlParams]* @return : java.util.Map<java.lang.String,java.lang.String>* @description : 请求微信支付统一下单*/Map<String,String> getWchatPayUnifyOrderResult(String unifyOrderXmlParams) throws Exception;}

推荐阅读