温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

微信支付集成工具是什么

发布时间:2021-10-20 10:57:31 来源:亿速云 阅读:129 作者:柒染 栏目:大数据

这篇文章将为大家详细讲解有关微信支付集成工具是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

微信支付集成工具

最近老板又安排了新项目,要接入微信支付,看了看以前的支付代码(多年以前别人写的)实在不忍直视,就去找了找微信官方sdk,结果官方sdk用起来实在太不“面向对象”了,由于平时用阿里云比较多,于是决定用阿里云sdk的API风格写一套。

下单和支付结果通知在线上项目通过测试,其他已完成接口,简单做了一两次测试,都通过了。其他未完成接口会择期逐步完成 github: https://github.com/BekeyChao/wxpay/tree/master
在OSCHINA上混,带上个码云仓库: https://gitee.com/BekeyChao/wxpay

快速开始

cd yourpath

git clone gitAddress

cd wxpay

mvn install

克隆源码到本地,通过mvn安装到本地,在pom文件中引入

<dependency>
    <groupId>xyz.bekey</groupId>
    <artifactId>wxpay</artifactId>
    <version>version</version>
</dependency>

目前最新版本是0.0.5, jdk最低要求1.8,代码中并没有大量应用java8新内容,如果希望兼容,只需修改统一下单接口中的LocalDateTime类型

在Spring中使用的例子

微信支付工具都通过实例化WechatPay类来使用,在Spring中建议注册为单例方便使用。

@Configuration
public class WechatPayConfig {

    @Value("${mch_id}")
    private String mch_id; 
    @Value("${key}")
    private String key; 
    @Value("${cert_path}")
    private String cert_path;   // 微信证书路径

    @Bean
    public WechatPay wechatPay() {
        // wxConfig提供了两种构造方法, 默认签名类型为MD5, 默认微信支付服务地址取自官方文档
        WxpayConfig wxConfig = new WxpayConfig(WechatApplication.Yepaofu_Subscribe.getAppid()
                , mch_id, key, cert_path);
        // 自定义 可以忽略不设
        wxConfig.setConnectTimeou(10000);
        wxConfig.setSocketTimeout(10000);
        return new WechatPay(wxConfig);
    }
}

以统一下单接口为例,调用方法

@Service
public class PayService {
    @Autowired
    private WechatPay wechatPay;
    // 统一下单接口
    public void toPay() {
        UnifiedOrderRequest request = new UnifiedOrderRequest();
        request.setTotal_fee(100);
        request.setSpbill_create_ip("10.10.10.10");
        request.setOut_trade_no("test123");
        request.setBody("测试订单");
        request.setTrade_type(TradeType.MWEB);
        request.setOpenid("openid");
        request.setNotify_url("http://mycallbak.com");
        // some else...
                
        UnifiedOrderResponse response = wechatPay.getWechatPayResponse(request);
        boolean success = response.isSuccess();
        if (success) {
            System.out.println(JSON.toJSONString(response)); 
        } else {
            System.out.println(response.getErr_code_des()); 
        }
    }
    // 支付结果回调,请从response中获取xml字符串
    public void handleCallback(String xml) { 
        try {
            UnifiedOrderCallback callback = wechatPay.unifiedorderCallback(xml);
            if (callback.isSuccess()) {
                System.out.println(JSON.toJSONString(callback));
            } else {
                System.out.println(callback.getErr_code_des());
            }
        } catch (InvalidSignException e) {
            // 处理签名异常
            e.printStackTrace();
        }        
    }
    
}

接口完成列表

已完成接口

  • 统一下单接口 UnifiedOrderRequest

  • 查询订单接口 OrderQueryRequest

  • 申请退款接口(需要证书) RefundRequest

  • 退款查询接口 RefundQueryRequest

  • 支付结果通知 UnifiedOrderCallback

未完成接口

  • 关闭订单

  • 海关申报

  • 下载对账单

  • 下载资金账单

  • 交易保障

  • 拉取订单评价数据

  • 退款结果通知(因为需要AES-256-ECB解密,jdk默认不支持,暂时不实现了)

代码风格

微信接口中会有大量的 javabean xml map 之间的转换,我处理的还是比较随意的,在xml -- javabean 之间主要通过fastjson进行转换,因为用起来比较顺手,所以也没在意效率的问题。 整体api风格设计借鉴 阿里云SDK 风格,xxxRequest 对应 xxxResponse,这种api设计很直观,而且通过一个api接口可以统一调用。 在参数校验层面,为了偷懒大量的校验与数据结构转换在Request中进行,所以Request类并不是简单类,在调试中可能会遇到点麻烦,见谅

关于微信支付集成工具是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI