文章目录

  • 支付宝沙盒介绍
  • 配置
  • 支付宝付款
  • 数据验签
  • 收单

支付宝沙盒介绍

操作指引,官网:https://opendocs.alipay.com/common/02kkv7

  1. 登录
  2. 开发工具推荐 > 沙盒
  3. 获取信息(后面要用)
  4. 配置支付宝网关地址,必须是外网可以访问到的,可使用ngrok作内网穿透(需要注意的是,若使用ngrok,访问项目的域名实际为ngrok外网地址)。
    否则,即使在项目中配置了回调地址return_url,也不会生效。

配置

pom配置

<dependency><groupId>com.alipay.sdk</groupId><artifactId>alipay-sdk-java</artifactId><version>4.31.40.ALL</version>
</dependency>

yml配置(所有**需要配置自己的,可以使用上面沙盒环境中提供的信息)

#支付宝相关的配置
#应用ID,您的APPID,收款账号既是您的APPID对应支付宝账号
alipay.app_id=**
#商户私钥,您的PKCS8格式RSA2私钥
alipay.merchant_private_key=**
#支付宝公钥,查看地址:https://openhome.alipay.com/platform/keyManage.htm 对应APPID下的支付宝公钥。
alipay.alipay_public_key=**
#服务器[异步通知]页面路径  需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问
#支付宝会悄悄的给我们发送一个请求,告诉我们支付成功的信息
alipay.notify_url=**
#页面跳转同步通知页面路径 需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问
#同步通知,支付成功,一般跳转到成功页
alipay.return_url=**
#订单支付页过期时间,例如1分钟
alipay.timeout=1m
#签名方式
alipay.sign_type=RSA2
#字符编码格式
alipay.charset=utf-8
#支付宝网关; https://openapi.alipaydev.com/gateway.do
alipay.gatewayUrl=https://openapi.alipaydev.com/gateway.do
#日期格式,用于将异步返回的日期字符串转换为Date
spring.mvc.format.date=yyyy-MM-dd HH:mm:ss

配置类,提供一个支付方法,返回一个页面

import com.alipay.api.AlipayApiException;
import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;
import com.alipay.api.request.AlipayTradePagePayRequest;
import com.ljy.gulimall.gulimallorder.vo.PayVo;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;@ConfigurationProperties(prefix = "alipay")
@Component
@Data
public class AlipayTemplate {// 应用ID,您的APPID,收款账号既是您的APPID对应支付宝账号public String app_id;// 商户私钥,您的PKCS8格式RSA2私钥public String merchant_private_key;// 支付宝公钥,查看地址:https://openhome.alipay.com/platform/keyManage.htm 对应APPID下的支付宝公钥。public String alipay_public_key;// 服务器[异步通知]页面路径  需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问// 支付宝会悄悄的给我们发送一个请求,告诉我们支付成功的信息public String notify_url;// 页面跳转同步通知页面路径 需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问//同步通知,支付成功,一般跳转到成功页public String return_url;// 签名方式private  String sign_type;// 字符编码格式private  String charset;//订单超时时间private String timeout;// 支付宝网关; https://openapi.alipaydev.com/gateway.dopublic String gatewayUrl;public  String pay(PayVo vo) throws AlipayApiException {//AlipayClient alipayClient = new DefaultAlipayClient(AlipayTemplate.gatewayUrl, AlipayTemplate.app_id, AlipayTemplate.merchant_private_key, "json", AlipayTemplate.charset, AlipayTemplate.alipay_public_key, AlipayTemplate.sign_type);//1、根据支付宝的配置生成一个支付客户端AlipayClient alipayClient = new DefaultAlipayClient(gatewayUrl,app_id, merchant_private_key, "json",charset, alipay_public_key, sign_type);//2、创建一个支付请求 //设置请求参数AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();alipayRequest.setReturnUrl(return_url);alipayRequest.setNotifyUrl(notify_url);//商户订单号,商户网站订单系统中唯一订单号,必填String out_trade_no = vo.getOut_trade_no();//付款金额,必填String total_amount = vo.getTotal_amount();//订单名称,必填String subject = vo.getSubject();//商品描述,可空String body = vo.getBody();alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","+ "\"total_amount\":\""+ total_amount +"\","+ "\"subject\":\""+ subject +"\","+ "\"body\":\""+ body +"\","+ "\"timeout_express\":\""+timeout+"\","+ "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");//会收到支付宝的响应,响应的是一个页面,只要浏览器显示这个页面,就会自动来到支付宝的收银台页面return alipayClient.pageExecute(alipayRequest).getBody();}
}

相关实体类

import lombok.Data;@Data
public class PayVo {/*** 商户订单号 必填*/private String out_trade_no;/*** 订单名称 必填*/private String subject;/*** 付款金额 必填*/private String total_amount;/*** 商品描述 可空*/private String body;
}

支付宝付款

示例:

 /*** 指定返回类型是text/html*/@ResponseBody@GetMapping(value = "/alipay",produces = MediaType.TEXT_HTML_VALUE)public String alipay() throws AlipayApiException {//构建支付详情PayVo payVo=...//生成支付页面并返回return alipayTemplate.pay(payVo);}

数据验签

对于异步回调返回的数据,我们需要保证数据是支付宝返回的,而不是伪造的,因此,必须进行校验之后再使用

先给出一个示例:

public String payedNotify(HttpServletRequest request,PayAsyncVo asyncVo) throws AlipayApiException {// 只要收到支付宝的异步通知,返回 success 支付宝便不再通知// 获取支付宝POST过来反馈信息// 验签// 获取请求参数封装为MapMap<String, String> params = new HashMap<>();Map<String, String[]> requestParams = request.getParameterMap();for (String name : requestParams.keySet()) {String[] values = requestParams.get(name);String valueStr = "";for (int i = 0; i < values.length; i++) {valueStr = (i == values.length - 1) ? valueStr + values[i]: valueStr + values[i] + ",";}//乱码解决,这段代码在出现乱码时使用// valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");params.put(name, valueStr);}//调用SDK验证签名/** * 工具类参数说明:* @param params    待验签的从支付宝接收到的参数Map* @param publicKey 支付宝公钥* @param charset   参数内容编码集* @param signType  指定采用的签名方式,RSA、RSA2、SM2* @return true:验签通过;false:验签不通过* @throws AlipayApiException*///public static boolean verifyV1(Map<String, String> params, String publicKey, String charset, String signType)boolean signVerified = AlipaySignature.rsaCheckV1(params, alipayTemplate.getAlipay_public_key(),alipayTemplate.getCharset(), alipayTemplate.getSign_type()); if (signVerified) {// TODO 验签成功后,按照支付结果异步通知中的描述,对支付结果中的业务内容进行二次校验,校验成功后在response中返回success并继续商户自身业务处理,校验失败返回failurereturn "sussess";} else {// TODO 验签失败则记录异常日志,并在response中返回failure.return "error";}
}

封装异步返回结果的实体类:

注意:需要在配置文件中配置:spring.mvc.format.date=yyyy-MM-dd HH:mm:ss,防止时间转换错误

import lombok.Data;
import lombok.ToString;import java.util.Date;@ToString
@Data
public class PayAsyncVo {private String gmt_create;private String charset;private String gmt_payment;private Date notify_time;private String subject;private String sign;private String buyer_id;//支付者的idprivate String body;//订单的信息private String invoice_amount;//支付金额private String version;private String notify_id;//通知idprivate String fund_bill_list;private String notify_type;//通知类型; trade_status_syncprivate String out_trade_no;//订单号private String total_amount;//支付的总额private String trade_status;//交易状态  TRADE_SUCCESSprivate String trade_no;//流水号private String auth_app_id;//private String receipt_amount;//商家收到的款private String point_amount;//private String app_id;//应用idprivate String buyer_pay_amount;//最终支付的金额private String sign_type;//签名类型private String seller_id;//商家的id}

参考资料:

  • 数据验签官网:https://opendocs.alipay.com/common/02mse7
  • 异步通知参数说明https://opendocs.alipay.com/open/270/105902

收单

  • 设置订单支付过期时间,可在上面的yaml配置文件修改alipay.timeout属性值
  • 订单一旦解锁,手动收单:https://opendocs.alipay.com/open/028wob
  • 查订单状态:https://opendocs.alipay.com/open/028woa
  • 对账:https://opendocs.alipay.com/open/028woc

整合支付-alipay相关推荐

  1. 微信整合支付和退款以及回掉

    参数整合 @Data @Component @ConfigurationProperties(prefix = "weachat") public class WeachatPro ...

  2. 集成支付宝支付(AliPay)详解,防跳坑

    更新时间:2016/02/22 现在的支付方式一般有三种, 支付宝, 微信, 网银. 个人觉得最简单易用的还是支付宝, 微信虽然看起来币支付宝要简单,但是后端太麻烦了, 网银就不说了. 先放出官方文档 ...

  3. Java 支付宝支付 Alipay

    相关官方文档位置:https://docs.open.alipay.com/api_1 阿里的文档还是比较清晰明了的,Java部分的代码更是做了非常棒的封装,引用jar包中的方法,支付宝的流程都类似, ...

  4. PHP对接支付 alipay支付

    踩过的坑 注意事项(以下接口参数针对的是沙箱环境): 1.支付结果返回客户端不需要htmlspecialchars php 不需要转义(对于php编译环境而言) 2.统一订单交易接口 :两个商户订单号 ...

  5. 支付宝电脑网站支付 alipay.trade.page.pay

    只涉及支付接口 其他接口没有使用 支付宝官方文档:https://docs.open.alipay.com/270/105899/ 支付接口文档 https://docs.open.alipay.co ...

  6. h5支付不能打开支付宝 ios_iOS支付宝支付(Alipay)详细接入流程以及项目中遇到的问题分析...

    最近在项目中接入了微信支付和支付宝支付,总的来说没有那么坑,很多人都说文档不全什么的,确实没有面面 俱到,但是认真一步一步测试下还是妥妥的,再配合懂得后台,效率也是很高的,看了这篇文章,你也只要几分钟 ...

  7. 支付宝服务器参数怎么修改,支付宝支付--aliPay(客户端配置)

    首先配置config.xml 注意:面改版,有些地方会有不同,其实大同小异,有不懂的请看服务端文档的截图 注: ****表示应用的编号,用'AliPay'和 widgetId 拼接 配置res/key ...

  8. ios含有支付_苹果APP Store审核提示包含第三方支付Alipay被拒

    APP里肯定是不包含支付功能的,云打包APP时也没有勾选第三方支付,但提交审核时仍然被拒,如下: We discovered that your app contains hidden feature ...

  9. iOS支付宝支付(Alipay)详细接入流程以及项目中遇到的问题分析

    最近在项目中接入了微信支付和支付宝支付,总的来说没有那么坑,很多人都说文档不全什么的,确实没有面面俱到,但是认真一步一步测试下还是妥妥的,再配合懂得后台,效率也是很高的,看了这篇文章,你也只要几分钟, ...

最新文章

  1. AI药物全球100领军人物:43%来自学界 美英顶级AI专家人数最多
  2. MEET大会报名开启 | 李开复张亚勤等产学研大咖邀你共同见证智能未来
  3. KDDockWidgets源码编译及安装
  4. Linux下如何避免误操作执行 rm
  5. Valgrind快速入门指南
  6. linux添加自定义的命令!
  7. python实现二分类_感知器做二分类的原理及python numpy实现
  8. 耐人寻味的 8 幅Java技术图
  9. Linux用户环境变量及操作
  10. 手机连无线显示服务器超时,手机wifi为什么会连接超时
  11. 去商场淘打折商品时,计算打折以后的价钱是件颇费脑子的事情。例如原价 ¥988,标明打 7 折,则折扣价应该是 ¥988 x 70% = ¥691.60。本题就请你写个程序替客户计算折扣价。
  12. uni-table单元格中预览图片:阻止冒泡
  13. 澳元兑美元预测:美元可能因美国经济衰退担忧而进一步下跌(MogaFX)
  14. 层次聚类——linkage方法
  15. php realpath()
  16. C语言中 || \ 符号的意思
  17. 为什么商品宝贝属性越改权重越低,怎样改商品信息对权重没影响
  18. 公益运动App平台开发详情
  19. [转载]我如何在计算机视觉顶级会议CVPR上发表论文?
  20. Java的发展历史以及当前Java的发展现状

热门文章

  1. 19 Python __dict__与dir()区别
  2. The Load Slice Core Microarchitecture
  3. 在iPhone上实现标签云
  4. 浙大PTA基础编程题目集:7-1 厘米换算英尺英寸
  5. Spring源码窥探之:ImportBeanDefinitionRegistrar
  6. ux设计师怎样找同类产品_完成ux训练营后的前100天,担任产品设计师
  7. bilibili视频下载信息获取
  8. 【Pandas】 ValueError: Unable to parse string “2,00“ at position 3769
  9. 本地ping不上虚拟机地址? 只需简单几步即可
  10. 教你几招如何看透一个人一件事!