当前位置:   article > 正文

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

支付宝沙箱支付教程

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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

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

3.2. 前端vue部分实现

<div>
    <a href="javascript:void(0);" id="order_btn" @click="addorder()">提交订单</a>
</div>
  • 1
  • 2
  • 3
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();
                    });
            }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

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();
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

3.4. 创建对应的service接口层

public interface PayService {
    Result aliPayOrderSuccess();

    Result alipay(Orderinfo orderinfo, HttpServletResponse response) throws Exception;
}
  • 1
  • 2
  • 3
  • 4
  • 5

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";
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
@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;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57

3.6. 页面的跳转

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/186191
推荐阅读
相关标签
  

闽ICP备14008679号