zoukankan      html  css  js  c++  java
  • java引用微信支付的p12证书文件

    最近对接微信支付的退款功能,其中涉及到引用证书文件。

    1. 绝对路径:

        // windows:
        public static String PATH1 = "E:\project_ceshi\apiclient_cert.p12";    
      //
    linux public static String PATH2 = "/home/www/ceshi/apiclient_cert.p12";

      使用决定路径时,直接引用即可:File file = new File(PATH1);

    2.相对路径(类加载器加载):注意:maven打包转码问题

      文件放在项目中的resources下:

        

      引用时:

      String path = "apiclient_cert.p12";
      File file = new File(this.getClass().getClassLoader().getResource(path).getFile());

      类加载编译后,resources下的文件的位置:

        

      这个时候文件正常加载进去了,但是此时坑来了,程序运行时报错:java.io.IOException: DerInputStream.getLength(): lengthTag=111, too big.

      原因maven打包时,会对文件进行转码,重新编码后会导致证书文件不可用

      解决poom依赖中进行配置,让maven打包时过滤掉不需要转码的文件

      具体如下:

    <!--处理资源文件插件,默认的资源文件在src/main/resources目录下,可以实现filter-->
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-resources-plugin</artifactId>
                    <configuration>
                        <encoding>UTF-8</encoding>
                        <!-- 过滤不需要转码的后缀为pem、pfx的证书文件 -->
                        <nonFilteredFileExtensions>
                            <nonFilteredFileExtension>pem</nonFilteredFileExtension>
                            <nonFilteredFileExtension>pfx</nonFilteredFileExtension>
                            <nonFilteredFileExtension>p12</nonFilteredFileExtension>
                        </nonFilteredFileExtensions>
                        <delimiters>
                            <!--这里干掉了对@符号的解析,这个是该插件的一个问题-->
                            <delimiter>${*}</delimiter>
                        </delimiters>
                    </configuration>
                </plugin>

      此时便可以正常运行了(采用绝对路径可以正常请求的情况下,排除文件问题);

  • 相关阅读:
    2019-07-26
    2019-07-25
    免费的论文查重网站
    图片转链接
    hexo GitHub创建博客是遇到的问题
    苹果手机安装小火箭
    旅游--南京
    查看电脑基本信息以及电脑性能分析
    Android 不能root
    x-mind ZEN 指定安装路径(其他默认安装c盘可参考)
  • 原文地址:https://www.cnblogs.com/mufengforward/p/10635069.html
Copyright © 2011-2022 走看看