支付宝沙箱的使用---详细教程

本文介绍了如何配置支付宝的沙箱环境,包括登录控制台和获取应用信息。接着详细讲述了密钥生成工具的下载与使用,以及如何在项目中生成和导入密钥。在项目接入部分,文章提到了SpringBoot应用中添加支付宝依赖,前端Vue部分的实现,以及创建支付Controller和服务层的详细步骤,包括异步和同步回调的设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.支付宝沙箱环境配置

可查看官方网址操作

1.1进入沙箱环境并登录

在这里插入图片描述

1.2.进入支付宝平台中的控制台,点击沙箱

在这里插入图片描述

1.3.进入沙箱即可看到相关信息

2.生成密钥工具下载

官方网站教程

2.1. 工具下载

在这里插入图片描述

2.2.安装之后进入

在这里插入图片描述

2.3.生成密钥打开文件位置即可

在这里插入图片描述

2.4. 进入刚才的沙箱应用点击自定义密钥

在这里插入图片描述

2.5. 将生成的公钥复制进去,结果为下图点击确定即可

在这里插入图片描述

3.项目中接入支付宝

3.1. 导入支付宝支付的依赖

    <!--   支付宝支付的依赖     -->
    <dependency>
        <groupId>com.alipay.sdk</groupId>
        <artifactId>alipay-sdk-java</artifactId>
        <version>4.16.2.ALL</version>
    </dependency>

此项目使用的为springboot+maven+vue实现

3.2. 前端vue部分实现

<div>
    <a href="javascript:void(0);" id="order_btn" @click="addorder()">提交订单</a>
</div>
var vm = new Vue({
        el: "#app",
        data: {
            addrs: [],
        },
        methods: {
            addorder: function () {
                if (this.addr.aname == null) {
                    alert("请填写收货地址");
                    return;
                }
                var params = new URLSearchParams();
			  //后端接收的参数
                axios.post("../barleyfrontorder/pay/alipay", params)
                    .then((resp) => {
                        // 添加之前先删除一下,如果单页面,页面不刷新,添加进去的内容会一直保留在页面中,二次调用form表单会出错
                        const divForm = document.getElementsByTagName("div");
                        if (divForm.length) {
                            document.body.removeChild(divForm[0]);
                        }
                        const div = document.createElement("div");
                        div.innerHTML = resp.data; // data就是接口返回的form 表单字符串
                        document.body.appendChild(div);
                        document.forms[0].setAttribute("target", "_blank"); // 新开窗口跳转
                        document.forms[0].submit();
                    });
            }
}

3.3. 创建支付的Controller类(PayController)

在Controller中定义接口

@Controller
public class PayController {
    @Autowired
    private PayService payService;

    @ResponseBody
    @RequestMapping("/pay/alipay")
    public Result alipay(Orderinfo orderinfo, HttpServletResponse response) throws Exception {
        return payService.alipay(orderinfo,response);

    }
    @RequestMapping("success")
    public Result aliPayOrderSuccess(){
        return payService.aliPayOrderSuccess();
    }
}

3.4. 创建对应的service接口层

public interface PayService {
    Result aliPayOrderSuccess();

    Result alipay(Orderinfo orderinfo, HttpServletResponse response) throws Exception;
}

3.5. 创建service接口实现层

首先设置以下属性

  • APP_ID (appId,从沙箱应用中获得)
  • APP_PRIVATE_KEY (应用私钥,生成密钥工具获得)
  • ALIPAY_PUBLIC_KEY (支付宝公钥,上一步骤获得)
  • GATEWAY_URL (支付宝网关地址,在开发平台沙箱管理页面中获得)
  • SIGN_TYPE (签名类型)
  • NOTIFY_URL (异步回调地址,须是公网IP,后面再解释)
  • RETURN_URL (同步回调地址,可以是私网IP)
//appid
private final String APP_ID = "沙箱应用中获得"; //改为自己的
//应用私钥
private final String APP_PRIVATE_KEY = "生成密钥工具获得";  //改为自己的
private final String CHARSET = "UTF-8";  //不需要改
// 支付宝公钥
private final String ALIPAY_PUBLIC_KEY = "上一步获得";
//这是沙箱接口路径,正式路径为https://openapi.alipay.com/gateway.do
private final String GATEWAY_URL = "https://openapi.alipaydev.com/gateway.do"; //不需要改
private final String FORMAT = "JSON"; //不需要改
//签名方式
private final String SIGN_TYPE = "RSA2";  //不需要改
//支付宝异步通知路径,付款完毕后会异步调用本项目的方法,必须为公网地址
private final String NOTIFY_URL = "http://localhost:20000/barleyfrontorder/success"; 
//支付宝同步通知路径,也就是当付款完毕后跳转本项目的页面,可以不是公网地址
private final String RETURN_URL = "http://localhost:20000/barleyfrontorder/success";
@Service
@Transactional(  propagation= Propagation.SUPPORTS,
        isolation= Isolation.DEFAULT,  timeout=2000,
        readOnly=true, rollbackFor=RuntimeException.class
)
@Slf4j
public class PayServieImpl implements PayService {
    @Autowired
    OrderDao orderDao;

    @Override
    public Result aliPayOrderSuccess() {
        return new Result().ok("支付成功");
    }

    @Override
    public Result alipay(Orderinfo orderinfo,HttpServletResponse response) throws Exception {

        //调用封装好的方法(给支付宝接口发送请求)
        String result = sendRequestToAlipay(orderinfo, "abcd",response);
        orderDao.insert(orderinfo);

        return new Result().ok(result);
    }

    /**
     * 参数1:订单中的信息
     */
    //支付宝官方提供的接口
    private String sendRequestToAlipay(Orderinfo orderinfo, String subject, HttpServletResponse httpResponse) throws AlipayApiException, IOException {
        //获得初始化的AlipayClient
        AlipayClient alipayClient = new DefaultAlipayClient(GATEWAY_URL, APP_ID, APP_PRIVATE_KEY, FORMAT, CHARSET, ALIPAY_PUBLIC_KEY, SIGN_TYPE);

        //设置请求参数
        AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
        alipayRequest.setReturnUrl(RETURN_URL);
        alipayRequest.setNotifyUrl(NOTIFY_URL);

        //商品描述(可空)
        String body = "欢迎下单";
        alipayRequest.setBizContent("{\"orderinfo\":\"" + orderinfo + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");

        alipayRequest.setBizContent("{\"out_trade_no\":\"" + orderinfo.getOid() + "\","
                + "\"total_amount\":\"" + orderinfo.getTotalPrice() + "\","
                + "\"subject\":\"" + subject + "\","
                + "\"body\":\"" + body + "\","
                + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");
        //请求
        String result = alipayClient.pageExecute(alipayRequest).getBody();
        //此部分必须要写 否则不会跳转到支付页面
        httpResponse.setContentType("text/html;charset=" + CHARSET);
        httpResponse.getWriter().write(result);// 直接将完整的表单html输出到页面
        httpResponse.getWriter().flush();
        httpResponse.getWriter().close();
        return result;
    }
}

3.6. 页面的跳转

上面即完成代码部分的书写,后面即可跳转到一下页面
在这里插入图片描述
此部分输入自己的账号名和密码,都是支付宝官网获得,点击下一步即可刷新支付宝二维码,手机扫码即可完成支付。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值