支付宝h5支付java对接

支付宝h5支付java对接

支付配置相关

SDK

<!-- 阿里支付 SDK -->
<dependency>
    <groupId>com.alipay.sdk</groupId>
    <artifactId>alipay-sdk-java</artifactId>
    <version>4.39.113.ALL</version>
</dependency>

配置

public class AliPayConstant {
    //支付宝支付网关
    public static final String ALIPAY_URL = "https://openapi.alipay.com/gateway.do";
	//支付完成回调接口给后端回调处理订单用
    public static final String ALIPAY_NOTIFY_URL = "XXXXXXXX";
	//前端支付完成跳转地址
    public static final String ALIPAY_RETURN_URL = "https:XXXXX";
	//前端支付中途退出专向地址
    public static final String ALIPAY_QUIT_URL = "https:XXXXX";

	//支付宝应用appid	
    public static final String ALIPAY_APP_ID = "123412331";
    //支付宝应用私钥
    public static final String ALIPAY_APP_PRIVATE_KEY = "ADSADSADSAD";
    //支付宝公钥 注意是支付宝公钥 不是应用公钥
    public static final String ALIPAY_APP_PUBLIC_KEY = "aSAsaDADSADSADS";
    //编码
    public static final String CHARSET = "UTF-8";
    //加密方式
    public static final String SIGN_TYPE = "RSA2";
    //数据类型
    public static final String FORMAT = "json";


}

支付代码

//ParkingBill是我的订单信息
//接口
@Operation(summary = "账单支付")
@PostMapping("/payBill")
public Result<String> payBill(@RequestBody ParkingBill parkingBill) throws AlipayApiException {
    return parkingBillService.aliPay(parkingBill);
}


//实现
    public Result<String> aliPay(ParkingBill parkingBill) throws AlipayApiException {
        // 初始化SDK
        AlipayClient alipayClient = new DefaultAlipayClient(getAlipayConfig());
        // 构造请求参数以调用接口
        AlipayTradeWapPayRequest request = new AlipayTradeWapPayRequest();
        //回调到后端地址
        request.setNotifyUrl(AliPayConstant.ALIPAY_NOTIFY_URL);
        //重定向地址
        request.setReturnUrl(AliPayConstant.ALIPAY_RETURN_URL);
        AlipayTradeWapPayModel model = new AlipayTradeWapPayModel();
        // 设置商户订单号
        model.setOutTradeNo(parkingBill.getBillSysCode());
        // 设置订单总金额
        model.setTotalAmount(parkingBill.getTotalCost().toString());
        // 设置订单标题
        model.setSubject("xxxxxxx");
        // 设置产品码
        model.setProductCode("QUICK_WAP_WAY");
        // 设置用户付款中途退出返回商户网站的地址
        model.setQuitUrl(AliPayConstant.ALIPAY_QUIT_URL);
        request.setBizModel(model);
        log.info("支付参数:{}", JSONObject.toJSONString(request));
        AlipayTradeWapPayResponse response = alipayClient.pageExecute(request, "POST");
        String pageRedirectionData = response.getBody();
        System.out.println(pageRedirectionData);
        if (response.isSuccess()) {
            return Result.success(pageRedirectionData);
        }
       throw new RuntimeException("调用失败");
    }


//初始化支付配置类
   private  static AlipayConfig getAlipayConfig() {
        AlipayConfig alipayConfig = new AlipayConfig();
        alipayConfig.setAppId(AliPayConstant.ALIPAY_APP_ID);
        alipayConfig.setPrivateKey(AliPayConstant.ALIPAY_APP_PRIVATE_KEY);
        alipayConfig.setAlipayPublicKey(AliPayConstant.ALIPAY_APP_PUBLIC_KEY);
        alipayConfig.setFormat("json");
        alipayConfig.setCharset(AliPayConstant.CHARSET);
        alipayConfig.setSignType(AliPayConstant.SIGN_TYPE);
        alipayConfig.setServerUrl(AliPayConstant.ALIPAY_URL);
        return alipayConfig;
    }

回调相关

/**
 * 支付宝回调接口
 */
@Operation(summary = "支付宝回调接口")
@PostMapping("/aliNotify")
public Result aliPayNotify(HttpServletRequest request) throws Exception{
    return parkingBillService.aliPayNotify(request);
}
public Result aliPayNotify(HttpServletRequest request) throws AlipayApiException {
    if (request.getParameter("trade_status").equals("TRADE_SUCCESS")) {
        log.info("=========支付宝异步回调========");

        Map<String, String> params = new HashMap<>();
        Map<String, String[]> requestParams = request.getParameterMap();
        for (String name : requestParams.keySet()) {
            params.put(name, request.getParameter(name));
        }
        String outTradeNo = params.get("out_trade_no");
        //根据订单号查询账单信息 自己业务自己处理
        //
        //
        //
        //
        String sign = params.get("sign");
        log.info("sign: ===》{}", sign);
        String content = AlipaySignature.getSignCheckContentV1(params);
        log.info("content: ===》{}", content);
        boolean checkSignature = AlipaySignature.rsa256CheckContent(content, sign, AliPayConstant.ALIPAY_APP_PUBLIC_KEY, AliPayConstant.CHARSET); // 验证签名
        log.info("签名验证结果: ===》{}", checkSignature);
        if (checkSignature) {
            log.info("交易名称: ===》{}", params.get("subject"));
            log.info("交易状态: ===》{}", params.get("trade_status"));
            log.info("支付宝交易凭证号: ===》{}", params.get("trade_no"));
            log.info("商户订单号: ===》{}", params.get("out_trade_no"));
            log.info("交易金额: ===》{}", params.get("total_amount"));
            log.info("买家在支付宝唯一id: ===》{}", params.get("buyer_id"));
            log.info("买家付款时间: ===》{}", params.get("gmt_payment"));
            log.info("买家付款金额: ===》{}", params.get("buyer_pay_amount"));
            
            //更新账单状态
            //自己业务处理
            //
            //
            return Result.success("支付完成");
        }
        //验签失败自己业务处理
        //
        //
    }
    //支付失败自己业务处理
    //
    //
    return Result.success("支付完成");
}
### Java 实现支付宝网页支付 API 集成 #### 准备工作 为了成功集成支付宝网页支付功能,在开始编码之前需完成一系列准备活动。这包括但不限于注册成为支付宝开放平台的开发者账号,创建应用以获得`AppID`、公私钥对以及其他必要参数。这些信息对于后续配置SDK和调用API至关重要[^1]。 #### 创建项目结构 建议基于Spring MVC (SSM)框架搭建Web应用程序来处理来自浏览器端发起的请求,并向其返回由支付宝服务端生成好的HTML表单用于重定向至支付页面。此过程中涉及到前后端交互逻辑的设计与实现。 #### 导入依赖库 确保项目的构建工具(如Maven或Gradle)已正确引入官方提供的Alipay SDK及相关加密组件支持,以便于简化开发流程中的复杂操作比如签名验证等。 ```xml <!-- Maven pom.xml --> <dependency> <groupId>com.alipay.sdk</groupId> <artifactId>alipay-sdk-java</artifactId> <version>LATEST_VERSION_HERE</version> </dependency> <dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcpkix-jdk15on</artifactId> <version>1.70</version> </dependency> ``` #### 编写业务逻辑代码 下面给出一段简单的示例代码片段展示如何构造交易请求对象并通过客户端执行方法提交给支付宝服务器: ```java // 构建 AlipayTradePagePayRequest 对象 AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest(); alipayRequest.setReturnUrl("http://yourdomain.com/return_url"); alipayRequest.setNotifyUrl("http://yourdomain.com/notify_url"); // 设置业务参数 Map<String, String> bizContent = new HashMap<>(); bizContent.put("out_trade_no", "unique_order_number_here"); // 商户订单号 bizContent.put("total_amount", "9.99"); // 订单金额 bizContent.put("subject", "Test Subject"); // 商品名称 bizContent.put("product_code", "FAST_INSTANT_TRADE_PAY"); // 销售产品码 alipayRequest.setBizContent(JSON.toJSONString(bizContent)); // 使用默认配置初始化 AlipayClient 客户端实例 DefaultAlipayClient client = new DefaultAlipayClient( "https://openapi.alipaydev.com/gateway.do", APP_ID, MERCHANT_PRIVATE_KEY, "json", CHARSET, ALIPAY_PUBLIC_KEY, SIGN_TYPE); try { // 执行支付请求并获取响应体作为 HTML 表单字符串 String form = client.pageExecute(alipayRequest).getBody() ; // 将上述得到的结果直接输出到HTTP响应流中即可触发自动跳转动作 } catch (AlipayApiException e) { throw new RuntimeException(e); } ``` 这段代码展示了如何设置回调地址、组装业务参数以及最终发送支付指令的过程。注意这里使用的URL应指向沙盒环境中对应的网关地址,而在正式上线前则要切换回生产环境下的真实链接[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值