微信代金券V3版本核销事件回调方法 java

微信代金券V3版本核销事件回调方法 有没有什么代码可以参考下,不太清除微信回调的调用方式,设置回调地址,创建相应接口,参数获取后不太清楚如何操作

不知道你这个问题是否已经解决, 如果还没有解决的话:
  • 这个问题的回答你可以参考下: https://ask.csdn.net/questions/450172
  • 我还给你找了一篇非常好的博客,你可以看看是否有帮助,链接:富文本点击查看更多,如果内容超多出3行显示,未超过隐藏,显示所有富文本内容
  • 除此之外, 这篇博客: 2020微信支付v3版本java对接详细流程中的 都0202年,我似乎翻遍了百度,都没找到最新版微信支付v3的对接相关的详细博客,我都纳闷了,只有自己摸索。还有就是竟然还有人用一些v3对接的假代码,来骗积分,我真的服了,感同身受,以下是我对接的过程,分享给大家,欢迎小伙伴一起探讨。 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

    ~首先吐槽下腾讯的文档,自己根据文档看,对于没有对接经验的来说,根本看不懂,什么乱起八糟的,心里一万个草泥马。
    其次,特别是对接的数据加密解密,传递格式那些是最让人想疯的东西。所以已经有大佬把这些基础的数据对接做了整合,就在gitee上,ijPay。ijPay我们只需要关注的只有给对象设置参数,发起请求,处理响应数据,就完事,很方便。此篇文章就基于此展开对接的讲解。

    此篇博客大体内容:
    1.ijPay 配置配置文件的讲解
    2.公众号和商户平台配置的讲解
    3.本地直接测试对接微信支付的方式
    4.微信支付v3版nativePay
    5.微信支付v3版jsApiPay
    6.微信支付v3版h5Pay
    7.微信支付通用退订
    8.微信支付通用退订查询
    8.附前后端直接copy的代码

    1.gitee开源支付对接源码(ijpay)地址
    2.ijpay官方文档地址
    3.我的对接代码点击下载【提取码:v18a】之前传到cnds官方给我强制收费,这里重新传了

    ps:ijpay中可以自己读代码,再根据腾讯的文档,摸索(ijpay注释较少,v3的退订使用的v2的退定接口,v3没有提供对应的代码,自己需要参照v2,并且退订参照有坑,后面会说).也可以花钱让ijpay的作者给你在线帮助

    整体对接流程概括如下

    1. 肯定是先下载ijpay源码到本地
      ijpay整合了许多支付,这里我们只讲解微信支付v3的对接,那么我自己是另外新建了一个springboot项目,然后把源码里面的微信v3支付的代码拷贝到新项目里面做测试的,缺什么依赖,根据报红的提示,自己引入,这里不做详细说明.

    在这里插入图片描述

    pom.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.3.3.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.example</groupId>
        <artifactId>wxpay</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>wxpay</name>
        <description>Demo project for Spring Boot</description>
        <packaging>war</packaging>
    
        <properties>
            <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
            <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
            <java.version>1.8</java.version>
            <ijapy.version>2.7.0</ijapy.version>
            <enjoy.version>4.3</enjoy.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
                <version>${slf4j.version}</version>
                <scope>compile</scope>
            </dependency>
            <dependency>
                <groupId>ch.qos.logback</groupId>
                <artifactId>logback-core</artifactId>
                <version>1.1.7</version>
            </dependency>
            <dependency>
                <groupId>ch.qos.logback</groupId>
                <artifactId>logback-classic</artifactId>
                <version>1.2.3</version>
            </dependency>
            <!--添加servlet-api的依赖,用来打war包  -->
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <scope>provided</scope>
            </dependency>
            <!--最终打成war包,排除内置的tomcat-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
                <exclusions>
                    <exclusion>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-starter-tomcat</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-lang3</artifactId>
                <version>3.9</version>
            </dependency>
            <dependency>
                <groupId>com.github.javen205</groupId>
                <artifactId>IJPay-All</artifactId>
                <version>${ijapy.version}</version>
            </dependency>
            <dependency>
                <groupId>com.github.xkzhangsan</groupId>
                <artifactId>xk-time</artifactId>
                <version>2.1.0</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
                <exclusions>
                    <exclusion>
                        <groupId>org.junit.vintage</groupId>
                        <artifactId>junit-vintage-engine</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
            <!-- https://mvnrepository.com/artifact/com.alipay.sdk/alipay-sdk-java -->
            <dependency>
                <groupId>com.alipay.sdk</groupId>
                <artifactId>alipay-sdk-java</artifactId>
                <version>4.7.11.ALL</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-configuration-processor</artifactId>
                <optional>true</optional>
            </dependency>
        </dependencies>
    
        <build>
            <resources>
                <resource>
                    <directory>src/main/resources</directory>
                </resource>
                <resource>
                    <directory>src/main/resources/${profiles.active}</directory>
                </resource>
            </resources>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <fork>true</fork>
                    </configuration>
                </plugin>
            </plugins>
        </build>
        <profiles>
            <!-- 默认激活 dev 开发环境 -->
            <!-- production使用 mvn xxx -Pproduction -->
            <profile>
                <!-- 本地开发环境 -->
                <id>development</id>
                <properties>
                    <profiles.active>dev</profiles.active>
                </properties>
                <activation>
                    <activeByDefault>true</activeByDefault>
                </activation>
            </profile>
            <profile>
                <!-- 生产环境 -->
                <id>production</id>
                <properties>
                    <profiles.active>production</profiles.active>
                </properties>
            </profile>
        </profiles>
    
    </project>
    
    

    2.【 微信支付v3版本证书下载】和【配置配置文件】

    这里先说下公众号和商户平台的关系,公众号的支付依附于商户平台,所以公众号和商户平台要做关联处理:
    登陆商户平台–>产品中心–>AppID账号管理
    关联过程,自行百度咯,不做过多讲解

    1).证书的下载
    登陆商户平台–>账户中心–>api安全–>API安全
    然后生成证书,最终会生成3个文件
    在这里插入图片描述
    生成流程:
    自行查看官方文档

    2).证书copy到【新项目】的文件夹中
    我这边是放在了src\main\resources\cert目录下
    在这里插入图片描述

    3).设置api秘钥和apiv3秘钥
    登陆商户平台–>账户中心–>api安全–>设置api秘钥/设置apiv3秘钥
    保存好,后面要用到

    4).设置配置文件 wxpay_v3.properties
    在这里插入图片描述
    在这里插入图片描述
    为了方便你们copy

    #服务商/直连商户平台 关联的 公众号appid
    v3.appId=?
    #秘钥
    v3.keyPath=?
    #CA证书 格式.pem
    v3.certPath=?
    #CA证书 格式.p12
    v3.certP12Path=?(退订的时候用的这个!!!)
    #平台证书路径
    v3.platformCertPath=?
    #服务商id/商户id
    v3.mchId=?
    #自定义 apiv3 秘钥
    v3.apiKey3=?
    #自定义 api 秘钥
    v3.apiKey=只用于退订的时候(退订的时候用的v2的接口)
    #项目域名
    v3.domain=?
    

    ps:这里讲下配置文件的参数如果获取
    appId:登陆微信公众平台–>开发–>基本配置–>开发者ID(AppID)
    keyPath: 对应apiclient_key.pem所在路径
    certPath: 对应apiclient_cert.pem所在路径
    certP12Path: 对应apiclient_cert.p12所在路径(退订的时候用的这个!!!)
    platformCertPath: 【平台证书】访问v3支付提供的接口获取,下面会讲
    mchId: 登陆商户平台–>账户中心–>商户信息–>微信支付商户号
    apiKey3: 参考上面的设置api秘钥和apiv3秘钥
    apiKey: 参考上面的设置api秘钥和apiv3秘钥
    domain: 项目域名
    关于项目域名,我这边用的natapp做的本地内网映射,可以直接在本地做支付测试,因为natapp代理的域名都是备案了的,非常方便,这里推荐下,不然去服务器上测试,太麻烦了.
    natapp官方链接地址 自己看natapp的文档或者帮助,这里不做过多讲解

    5).获取平台证书,也就是上图的platformCert.pem文件
    启动服务,本地访问接口: localhost/v3/get
    这里会请求腾讯接口,拿到平台证书,并保存到配置文件所配置的路径下(注意文件名在配置文件一开始就要配好)
    配置文件到这里就配好了

    1. 支付对接(直连商户模式)

    ps:v3微信支付官方文档
    基础支付–>【直连模式】和【服务商模式】的区别?
    1.接口对接的角度来说,就访问的地址不同,和传递的参数有差别,实现的效果是一样的,响应的参数的处理方式是一样的
    2.从现实逻辑来讲,
    直连模式是公众号直接对接商户平台,发起支付,
    关系为: 公众号–>商户平台
    服务商模式是基于直连,商户平台又把支付授权给服务商,
    关系为: 公众号–>商户平台–>服务商
    用服务商模式,貌似有返点啥的,没有深入研究,有兴趣自行百度,两者对接方式差不多,只是传递的参数有些许差别.但相应参数的处理是一样的,此篇博客只讲直连方式,服务商模式可以自行举一反三.

  • 您还可以看一下 张旭老师的【拯救者 】数据库系统概论速成课程中的 01·文档下载小节, 巩固相关知识点

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^