当前位置:   article > 正文

支付宝沙箱支付测试_支付宝沙箱支付教程个人测试

支付宝沙箱支付教程个人测试

 

目录

 

1.开发准备

2.配置环境

3.支付接口 

4.初步验证

5.接口回调

6.内网穿透 


1.开发准备

首先用支付宝扫码登录支付宝开发平台

登录 - 支付宝

选择开发工具沙箱

启用公钥模式,设置网关地址,地址复制粘贴上面的支付宝网关地址。

支付宝 - 网上支付 安全快速!

2.配置环境

在pom.xml进行依赖配置。

  1. <dependency>
  2. <groupId>com.alipay.sdk</groupId>
  3. <artifactId>alipay-easysdk</artifactId>
  4. <version>2.2.0</version>
  5. </dependency>

在application.yml中进行配置,注:配置时冒号后面空一格。

  1. alipay:
  2. appId:
  3. appPrivateKey:
  4. alipayPublicKey:
  5. notifyUrl:

配置参数前三个在控制台沙箱应用,notifyUrl后面配置。

然后点击文档>网页&移动应用>开发工具>开发工具>开发工具包(SDK)下载>服务端SDK> Java> Easy版

进行初始化参数配置,代码在示例代码中能找到。

  1. import com.alipay.easysdk.factory.Factory;
  2. import com.alipay.easysdk.factory.Factory.Payment;
  3. import com.alipay.easysdk.kernel.Config;
  4. import com.alipay.easysdk.kernel.util.ResponseChecker;
  5. import com.alipay.easysdk.payment.facetoface.models.AlipayTradePrecreateResponse;
  6. public class Main {
  7. public static void main(String[] args) throws Exception {
  8. // 1. 设置参数(全局只需设置一次)
  9. Factory.setOptions(getOptions());
  10. try {
  11. // 2. 发起API调用(以创建当面付收款二维码为例)
  12. AlipayTradePrecreateResponse response = Payment.FaceToFace()
  13. .preCreate("Apple iPhone11 128G", "2234567890", "5799.00");
  14. // 3. 处理响应或异常
  15. if (ResponseChecker.success(response)) {
  16. System.out.println("调用成功");
  17. } else {
  18. System.err.println("调用失败,原因:" + response.msg + "," + response.subMsg);
  19. }
  20. } catch (Exception e) {
  21. System.err.println("调用遭遇异常,原因:" + e.getMessage());
  22. throw new RuntimeException(e.getMessage(), e);
  23. }
  24. }
  25. private static Config getOptions() {
  26. Config config = new Config();
  27. config.protocol = "https";
  28. config.gatewayHost = "openapi.alipay.com";
  29. config.signType = "RSA2";
  30. config.appId = "<-- 请填写您的AppId,例如:2019091767145019 -->";
  31. // 为避免私钥随源码泄露,推荐从文件中读取私钥字符串而不是写入源码中
  32. config.merchantPrivateKey = "<-- 请填写您的应用私钥,例如:MIIEvQIBADANB ... ... -->";
  33. //注:证书文件路径支持设置为文件系统中的路径或CLASS_PATH中的路径,优先从文件系统中加载,加载失败后会继续尝试从CLASS_PATH中加载
  34. config.merchantCertPath = "<-- 请填写您的应用公钥证书文件路径,例如:/foo/appCertPublicKey_2019051064521003.crt -->";
  35. config.alipayCertPath = "<-- 请填写您的支付宝公钥证书文件路径,例如:/foo/alipayCertPublicKey_RSA2.crt -->";
  36. config.alipayRootCertPath = "<-- 请填写您的支付宝根证书文件路径,例如:/foo/alipayRootCert.crt -->";
  37. //注:如果采用非证书模式,则无需赋值上面的三个证书路径,改为赋值如下的支付宝公钥字符串即可
  38. // config.alipayPublicKey = "<-- 请填写您的支付宝公钥,例如:MIIBIjANBg... -->";
  39. //可设置异步通知接收服务地址(可选)
  40. config.notifyUrl = "<-- 请填写您的支付类接口异步通知接收服务地址,例如:https://www.test.com/callback -->";
  41. //可设置AES密钥,调用AES加解密相关接口时需要(可选)
  42. config.encryptKey = "<-- 请填写您的AES密钥,例如:aa4BtZ4tspm2wnXLb1ThQA== -->";
  43. return config;
  44. }
  45. }

3.支付接口 

官方示例代码

  1. Factory.Payment.FaceToFace()
  2. // 调用agent扩展方法,设置app_auth_token,完成第三方代调用
  3. .agent("ca34ea491e7146cc87d25fca24c4cD11")
  4. .preCreate("Apple iPhone11 128G", "2234567890", "5799.00");

如上所示,第三方调用需要三个数据,依次为,交易名称、支付宝交易凭证号、交易金额。

每次交易凭证号不能相同。

由以上信息,创建支付接口。

新建一个 AliPayController.java

  1. import com.alipay.easysdk.factory.Factory;
  2. import com.alipay.easysdk.payment.page.models.AlipayTradePagePayResponse;
  3. import com.example.springboot.controller.dto.AliPay;
  4. import org.springframework.web.bind.annotation.GetMapping;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.RestController;
  7. import java.net.URLEncoder;
  8. @RestController
  9. @RequestMapping("/alipay")
  10. public class AliPayController {
  11. @GetMapping("/pay") // &subject=xxx&traceNo=xxx&totalAmount=xxx
  12. public String pay(AliPay aliPay) {
  13. AlipayTradePagePayResponse response;
  14. try {
  15. // 发起API调用(以创建当面付收款二维码为例)
  16. response = Factory.Payment.Page()
  17. .pay(URLEncoder.encode(aliPay.getSubject(), "UTF-8"), aliPay.getTraceNo(), aliPay.getTotalAmount(), "");
  18. } catch (Exception e) {
  19. System.err.println("调用遭遇异常,原因:" + e.getMessage());
  20. throw new RuntimeException(e.getMessage(), e);
  21. }
  22. return response.getBody();
  23. }
  24. }

创建实体类 Alipay.java

  1. import lombok.Data;
  2. @Data
  3. public class AliPay {
  4. //交易名称
  5. private String subject;
  6. //支付宝交易凭证号
  7. private String traceNo;
  8. //交易金额
  9. private String totalAmount;
  10. }

然后在拦截器加上忽略接口alipay的配置。

4.初步验证

URL:http://localhost:8080/alipay/pay?subject=xxx&traceNo=xxx&totalAmount=100

然后可以选择买家沙箱账号密码登录支付,或者下载沙箱版支付宝APP账号密码登录扫码支付。

 

5.接口回调

想要接收支付宝开发平台传回来的反馈,需要接口回调。

  1. //判断支付宝付款交易是否成功。true,false.
  2. request.getParameter("trade_status").equals("TRADE_SUCCESS")

支付类异步通知验签示例代码,官方平台可查。

  1. Map<String, String> parameters = new HashMap<>();
  2. parameters.put("charset", "UTF-8");
  3. parameters.put("sign", "GM0CbuqaEivqgb......");
  4. parameters.put("app_id", "2018091261392200");
  5. parameters.put("sign_type", "RSA2");
  6. parameters.put("isv_ticket", "");
  7. parameters.put("timestamp", "2020-03-25 16:27:08");
  8. //... ... 接收到的所有参数放入一个Map中
  9. Factory.Payment.Common().verifyNotify(parameters);

在 AliPayController.java加如下代码。在其中可对反馈数据进行处理。对前台进行反馈。

  1. @PostMapping("/notify") // 注意这里必须是POST接口
  2. public String payNotify(HttpServletRequest request) throws Exception {
  3. if (request.getParameter("trade_status").equals("TRADE_SUCCESS")) {
  4. Map<String, String> params = new HashMap<>();
  5. Map<String, String[]> requestParams = request.getParameterMap();
  6. for (String name : requestParams.keySet()) {
  7. params.put(name, request.getParameter(name));
  8. }
  9. String tradeNo = params.get("out_trade_no");
  10. String gmtPayment = params.get("gmt_payment");
  11. String alipayTradeNo = params.get("trade_no");
  12. // 支付宝验签
  13. if (Factory.Payment.Common().verifyNotify(params)) {
  14. // 验签通过
  15. System.out.println("交易名称: " + params.get("subject"));
  16. System.out.println("交易状态: " + params.get("trade_status"));
  17. System.out.println("支付宝交易凭证号: " + params.get("trade_no"));
  18. System.out.println("商户订单号: " + params.get("out_trade_no"));
  19. System.out.println("交易金额: " + params.get("total_amount"));
  20. System.out.println("买家在支付宝唯一id: " + params.get("buyer_id"));
  21. System.out.println("买家付款时间: " + params.get("gmt_payment"));
  22. System.out.println("买家付款金额: " + params.get("buyer_pay_amount"));
  23. }
  24. }
  25. return "******";
  26. }

6.内网穿透 

然后因为本地localhost,支付宝开发平台没法传输反馈数据过来。

需要进行内网穿透。

Natapp软件地址:https://natapp.cn/

选择需要版本自行下载。

登录注册过后,购买免费隧道,配置自己端口号,免费购买。

点击复制authtoken号。

创建authtoken启动项。

然后打开下载的Natapp软件文件夹,创建文本把下面代码加上先前复制的authtoken号,然后把文件后缀改成bat。

natapp.exe -authtoken=

点击start.bat文件启动。有如下显示证明启动成功。

更改 application.yml 里的配置:

然后就可以进行功能测试了。

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

闽ICP备14008679号