Java集成微信网页扫码支付

官网API

微信支付-开发者文档

1. 创建支付

<!--微信支付-->
<dependency>
  <groupId>com.github.wechatpay-apiv3</groupId>
  <artifactId>wechatpay-java</artifactId>
  <version>0.2.11</version>
</dependency>
    /**
     * 获取5分钟后超时时间
     * @return
     */
    public static String getTimeExpire() {
        // 当前时间
        LocalDateTime now = LocalDateTime.now();
        // 5分钟前的时间
        LocalDateTime fifteenMinutesAgo = now.plusMinutes(5);
        // 获取时区信息(以北京时间为例)
        ZoneId zoneId = ZoneId.of("Asia/Shanghai"); // 东八区时区
        // 将LocalDateTime转换为ZonedDateTime
        ZonedDateTime zonedDateTime = fifteenMinutesAgo.atZone(zoneId);
        // 创建一个符合RFC 3339的DateTimeFormatter
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ssXXX");
        // 格式化日期时间
        String formattedDateTime = zonedDateTime.format(formatter);
        return formattedDateTime;
    }

    /**
     * Native支付下单,获取支付地址
     * @return 微信支付二维码 base64图片
     */
    public static String nativePay(String title, String orderId, Integer totalMoney){
        // 使用自动更新平台证书的RSA配置
        Config config =
                new RSAAutoCertificateConfig.Builder()
                        .merchantId("1xxxxxxxx1") // 商户号,10位数字
                        .privateKeyFromPath("D:\\AH\\apiclient_key.pem")  // API证书地址(此处的路径自己调试一下,能找到就行)
                        .merchantSerialNumber("2xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx3") // API证书序列号
                        .apiV3Key("_xxxxxxxxxxxxxxxx__") // API密匙
                        .build();
        // 构建service
        NativePayService service = new NativePayService.Builder().config(config).build();
        PrepayRequest request = new PrepayRequest();
        Amount amount = new Amount();
        amount.setTotal(totalMoney); // 付款总金额, 传10为 0.1元, 传100元为 1元
        request.setAmount(amount);
        request.setAppid("wxxxxxxxxxxxxxxxxb"); // APPID
        request.setMchid("1xxxxxxxx1"); // 商户号,10位数字
        request.setTimeExpire(getTimeExpire()); // 超时时间
        request.setDescription(title);// 商品的描述
        request.setNotifyUrl("https://xxxx/account/pay/" + orderId);// 支付成功的回调地址(接口要为POST)
        request.setOutTradeNo(orderId);// 本地订单号
        // 调用下单方法,得到应答
        try {
            // 发送请求
            PrepayResponse response = service.prepay(request);
            // 使用微信扫描 code_url 对应的二维码,即可体验Native支付
             BufferedImage bufferedImage = builderQrCodeImage(generateQRCode(response.getCodeUrl(), 330, 330));
            // 将支付二维码返回
            return imageToBase64(bufferedImage);
        }catch (Exception e){
            throw new SearchException(e.getMessage());
        }
    }

        /**
         * 生成二维码
         * @param text
         * @param width
         * @param height
         * @return
         * @throws WriterException
         */
        public static BufferedImage generateQRCode(String text, int width, int height) throws WriterException {
            QRCodeWriter qrCodeWriter = new QRCodeWriter();
            Map<EncodeHintType, ErrorCorrectionLevel> hints = new HashMap<>();
            hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H); // 设置错误纠正级别为H
            BitMatrix bitMatrix = qrCodeWriter.encode(text, BarcodeFormat.QR_CODE, width, height, hints);
            return MatrixToImageWriter.toBufferedImage(bitMatrix);
    
        }

        /**
         * 将BufferdImage转为base64图片
         * @param image
         * @return
         * @throws IOException
         */
        public static String imageToBase64(BufferedImage image) throws IOException {
            // 将BufferedImage转换为字节数组
            ByteArrayOutputStream baos = new ByteArrayOutputStream();
            ImageIO.write(image, "jpg", baos); // 或者使用 "png" 或 "bmp" 等其他图片格式
            byte[] imageBytes = baos.toByteArray();
            // 将字节数组转换为Base64编码的字符串
            String encodedImage = Base64.getEncoder().encodeToString(imageBytes);
            return "data:image/jpeg;base64," + encodedImage;
        }

     /**
     * 二维码设置自定义的边框
     * @param image
     * @return
     */
    public static BufferedImage builderQrCodeImage(BufferedImage image) {
        try {
            File file = new File("边框文件路径");
            BufferedImage borderImage = ImageIO.read(new File(file.getPath()));
            BufferedImage image1 = new BufferedImage(image.getWidth() + 100, image.getHeight() + 100, BufferedImage.TYPE_INT_RGB);
            Graphics2D graphics = image1.createGraphics();
            //消除文字锯齿
            graphics.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_ON);
            //消除图片锯齿
            graphics.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
            //放入二维码
            graphics.drawImage(image, 50, 50, image.getWidth(), image.getHeight(), null);
            //放入边框
            graphics.drawImage(borderImage, 0, 0, image.getWidth() + 100, image.getHeight() + 100, null);
            return image1;
        } catch (IOException e) {
            return image;
        }
    }

2. 查询支付订单

public static AccountRechargePayResultDTO queryOrder(String rechargeOrderId){
        // 使用自动更新平台证书的RSA配置
        Config config =
                new RSAAutoCertificateConfig.Builder()
                        .merchantId("1xxxxxxxx1") // 商户号,10位数字
                        .privateKeyFromPath("D:\\AH\\apiclient_key.pem")  // API证书地址(此处的路径自己调试一下,能找到就行)
                        .merchantSerialNumber("2xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx3") // API证书序列号
                        .apiV3Key("_xxxxxxxxxxxxxxxx__") // API密匙
                        .build();
        // 构建service
        NativePayService service = new NativePayService.Builder().config(config).build();
        QueryOrderByOutTradeNoRequest request = new QueryOrderByOutTradeNoRequest();
        request.setMchid("1xxxxxxxx1") // 商户号,10位数字
        request.setOutTradeNo(rechargeOrderId);
        AccountRechargePayResultDTO dto = new AccountRechargePayResultDTO();// 自定义对象
        // 调用下单方法,得到应答
        try {
            // 发送请求
            Transaction response = service.queryOrderByOutTradeNo(request);
            String order = response.getTransactionId(); // 取出第三方订单号
            Transaction.TradeStateEnum status = response.getTradeState(); // 支付状态
            TransactionAmount amount = response.getAmount();
            dto.setMoney(amount.getPayerTotal()); // 订单支付总金额
            String time = response.getSuccessTime(); // 支付成功时间
            dto.setAccountRechargeId(rechargeOrderId);
            dto.setOrderSuccessTime(status.name().equals("SUCCESS") ? convertToFormattedString(time) : "");
            dto.setOrderId(order);
            dto.setOrderStatus(status.name().equals("SUCCESS") ? "1" : "0");
        }catch (Exception e){
            throw new SearchException(e.getMessage());
        }
        return dto;
    }

    /**
     * 时间格式转换
     * @param inputDateTime
     * @return
     */
    public static String convertToFormattedString(String inputDateTime) {
        // 将字符串解析为ZonedDateTime对象
        ZonedDateTime zonedDateTime = ZonedDateTime.parse(inputDateTime);
        // 将ZonedDateTime对象转换为指定的格式
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
        return zonedDateTime.format(formatter);
    }

3. 关闭支付订单

    public static void closeOrder(String rechargeOrderId){
        // 使用自动更新平台证书的RSA配置
        Config config =
                new RSAAutoCertificateConfig.Builder()
                        .merchantId("1xxxxxxxx1") // 商户号,10位数字
                        .privateKeyFromPath("D:\\AH\\apiclient_key.pem")  // API证书地址(此处的路径自己调试一下,能找到就行)
                        .merchantSerialNumber("2xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx3") // API证书序列号
                        .apiV3Key("_xxxxxxxxxxxxxxxx__") // API密匙
                        .build();
        // 构建service
        NativePayService service = new NativePayService.Builder().config(config).build();
        // request.setXxx(val)设置所需参数,具体参数可见Request定义
        CloseOrderRequest request = new CloseOrderRequest();
        request.setMchid("1xxxxxxxx1") // 商户号,10位数字
        request.setOutTradeNo(rechargeOrderId);
        AccountRechargePayResultDTO dto = new AccountRechargePayResultDTO();
        // 调用下单方法,得到应答
        try {
            // 发送请求
            service.closeOrder(request);
        }catch (Exception e){
            throw new SearchException(e.getMessage());
        }
    }

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Java中实现微信扫码登录,您可以按照以下步骤进行操作。 首先,您需要在微信公众平台上创建一个开发者账号,并获取到您的AppID和AppSecret。这些信息将用于后续的认证和授权操作。 然后,您可以使用微信提供的SDK或API来实现扫码登录功能。根据您提供的引用内容,您可以参考微信官方文档中的扫码登录部分来了解具体的实现流程。 在Java中,您可以通过后台的Controller来处理微信的认证和授权逻辑。您可以根据微信返回的参数(如code和state)来调用相应的方法进行验证和授权操作。 在前端页面中,您可以使用微信提供的JS SDK来生成扫码登录的二维码并显示在页面上。同时,您需要在前端页面中添加相应的点击事件,以触发微信登录功能。 在后台的Controller中,您可以通过调用微信的API来获取扫码登录所需的参数,如AppID和redirect_uri。然后将这些参数传递给前端页面,以便生成正确的扫码登录二维码。 总结起来,您需要进行以下步骤来实现Java中的微信扫码登录: 1. 在微信公众平台上创建开发者账号,并获取AppID和AppSecret。 2. 在后台的Controller中处理微信的认证和授权逻辑。 3. 在前端页面中使用微信的JS SDK生成扫码登录二维码,并添加相应的点击事件。 4. 调用微信的API来获取扫码登录所需的参数,并将这些参数传递给前端页面。 希望以上信息能帮助到您实现Java中的微信扫码登录功能。如有更多问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [java集成微信扫码登录](https://blog.csdn.net/weixin_48214611/article/details/120134304)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [java实现微信二维码登录功能](https://blog.csdn.net/weixin_42132143/article/details/89206215)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值