支付宝 h5手机浏览器支付

1注册支付宝开放平台账号并创建app 建议全程用法人的 还需要icp备案 没备案就不需要看了
2申请支付宝商家 手机网站支付能力 如果登录过开放平台 那么商户应该也是直接登录的 指在一个浏览器
3申请填写各种资料
4

           <dependency>
                <groupId>com.aliyun</groupId>
                <artifactId>alibabacloud-dysmsapi20170525</artifactId>
                <version>3.0.1</version>
            </dependency>
public String pagePay(String outTradeNo, String totalAmount, String subject, String returnUrl1) {
        // 创建支付客户端
        AlipayClient alipayClient = new DefaultAlipayClient(
                gatewayHost,  //网关
                appId, //开放平台创建的app
                merchantPrivateKey, //开放平台申请的私钥
                "json",
                "UTF-8",
                alipayPublicKey,//支付宝公钥
                "RSA2"
        );

        // 创建支付请求
//        AlipayTradePagePayRequest request = new AlipayTradePagePayRequest();//PC端
        AlipayTradeWapPayRequest request = new AlipayTradeWapPayRequest();//手机端

        // 设置同步跳转地址
        request.setReturnUrl(returnUrl1);//支付完后跳转的地址

        // 设置异步通知地址
        request.setNotifyUrl(notifyUrl);//回调地址

        // 构建业务参数
        String bizContent = "{" +
                "\"out_trade_no\":\"" + outTradeNo + "\"," +//订单号
                "\"total_amount\":\"" + totalAmount + "\"," +//金额
                "\"subject\":\"" + subject + "\"," +//订单名称
                "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"" +
                "}";

        request.setBizContent(bizContent);
      
        try {
            // 执行支付
            // 5. 执行支付请求,生成表单
            return alipayClient.pageExecute(request).getBody();

        } catch (Exception e) {
            log.error("支付异常",e);
            throw new ServiceException("支付异常");
        }
    }
        /**  
         * 创建订单
         */ 
        public Map createOrder(Order order){
                  HashMap<String, String> formMap = new HashMap<>();
                  String form = aliPayConfiguration.pagePay(
                  order.getOrderCode(),//订单编号
                  order.getOrderPrice(),//订单金额
                  order.getGoodsName(),//订单名称);
                  formMap.put("form",form);//返回表单
                  return formMap;
        }

/***
     * 支付宝支付回调
     * @param request
     * @return
     */
    @PostMapping("/aliPayh5Notify") 
    public String aliPayh5Notify(HttpServletRequest request){
        String success = "success";
        String failure = "failure";

        // https://opendocs.alipay.com/open/54/00y8k9 新老版本说明中有异步通知的新版说明
        // 获取支付宝异步回调信息, 将其转为 Map<String, String>
        Map<String, String> params = new HashMap<>();
        Map<String, String[]> requestParams = request.getParameterMap();
        for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
            String name = (String) iter.next();
            String[] values = (String[]) requestParams.get(name);
            String valueStr = "";
            for (int i = 0; i < values.length; i++) {
                valueStr = (i == values.length - 1) ? valueStr + values[i]
                        : valueStr + values[i] + ",";
            }
            // 乱码解决,这段代码在出现乱码时使用。如果mysign和sign不相等也可以使用这段代码转化
            // valueStr = new String(valueStr.getBytes("ISO-8859-1"), "gbk");
            params.put(name, valueStr);
        }

        // 新版 SDK 不用移除 sign_type
        // params.remove("sign_type");

        // 验签
        boolean signVerified = false;
        try {
//            signVerified = Factory.Payment.Common().verifyNotify(params);
            // 2. 验签
            boolean verifyResult = AlipaySignature.rsaCheckV1(
                    params,
                    aliPayConfiguration.getAlipayPublicKey(),
                    "UTF-8",
                    "RSA2"
            );

            // 3. 验签成功后进行业务处理
            if (verifyResult) {
                // 获取通知参数 
                signVerified = verifyResult;

            }
        } catch (Exception e) {
            logger.error("alipay支付异常",e);
            throw new ServiceException("支付异常");
        }

        if(signVerified){ // 验签通过
            String outTradeNo = params.get("out_trade_no");
            String buyer_id = params.get("buyer_id");
            Order order = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderCode, outTradeNo));
            if (order != null) {
                     //....其他处理 
            }else{
                return failure;
            }
            return success;
        }else{ // 验签失败
            return failure;
        }
    }

用的uniapp 封装了个页面 直接路由跳过来

<template>
    <view class="pay-page">
    <web-view  v-if="alipayForm" :src="'data:text/html;charset=utf-8,'+encodeURIComponent(alipayForm)"></web-view>
    </view>
</template>

<script>
    import {
        add1
    } from '@/api/system/order.js'
    export default {
        data(){
            return{
                order:{},
                alipayForm:null,
            }
        },
        onLoad(options) {
           //接收传递过来的参数
           this.pay()
        },
        methods:{
            pay(){
                add1(this.order).then(async res => {
                    // await alert(res.data.form)
                    if(this.isFormString(res.data.form)){
                        this.alipayForm = res.data.form 
                    }
                })
            },
            isFormString(str) {
              // 匹配是否包含 <form 开头和 </form> 结尾
              const formRegex = /<form[\s\S]*<\/form>/i;
              return formRegex.test(str);
            },
        }
    }
    
</script>

<style>
    .pay-page {
        min-height: 100vh;
        background-color: var(--background-color);
        padding-bottom: 40rpx;
    } 
</style>
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容