普通代码Config配置示例:
public class Config { // 开发者应用私钥。java配置PKCS8格式,PHP/.Net语言配置rsa_private_key.pem文件中原始私钥。 public static final String RSA_RRIVATE_KEY = "详见密钥生成"; // 接口请求网关。当面付支付、查询、退款、撤销接口中为固定值 public static final String URL = "https://openapi.alipay.com/gateway.do"; // 商户应用APPID,只要您的应用中包含当面付接口且是开通状态,就可以用此应用对应的appid。开发者可登录开放平台-管理中心-对应应用中查看 public static final String APPID = "2015********8324"; // 编码字符集。默认 utf-8 public static final String CHARSET = "utf-8"; // 返回格式。默认json public static final String FORMAT = "json"; // 支付宝公钥,用于获取同步返回信息后进行验证,验证是否是支付宝发送的信息。 public static final String ALIPAY_PUBLIC_KEY = "开发者登录开放平台-管理中心-进入应用后查看"; }
AlipayClient是SDK公共请求方法类,AlipayClientFactory是AlipayClient的静态工厂类:
import com.alipay.api.AlipayClient; import com.alipay.api.DefaultAlipayClient; public class AlipayClientFactory { // SDK 公共请求类,包含公共请求参数,以及封装了签名与验签,开发者无需关注签名与验签 private static final AlipayClient client = new DefaultAlipayClient(Config.URL, Config.APPID, Config.RSA_RRIVATE_KEY, Config.FORMAT, Config.CHARSET, Config.ALIPAY_PUBLIC_KEY); public static AlipayClient getAlipayClientInstance() { return client; } }
接口调用示例大致分为3步:
alipay.trade.pay接口代码调用示例:
/** * 统一交易支付(条码支付、声波支付) * @param appAuthToken 如ISV代替商家调用当面付接口,需将商户授权后获取的app_auth_token带上;如商家申请当面付自己调用,则传null。 * @param bizContent = "{\"out_trade_no\":\"123213445324532\",\"scene\":\"bar_code\",\"auth_code\":\"用户钱包付款码(数字)\",\"total_amount\":\"0.01\",\"subject\":\"测试\"}"; * @return * @throws AlipayApiException 请处理异常 */ public AlipayTradePayResponse pay(String appAuthToken, String bizContent) throws AlipayApiException { AlipayTradePayRequest request = new AlipayTradePayRequest(); request.putOtherTextParam("app_auth_token", appAuthToken); request.setBizContent(bizContent); return AlipayClientFactory.getAlipayClientInstance().execute(request); }
注意:
app_auth_token如何获取,详见“接入准备——第三方应用授权”。
alipay.trade.precreate接口代码调用示例:
/** * 扫码支付 * @param appAuthToken 如ISV代替商家调用当面付接口,需将商户授权后获取的app_auth_token带上;如商家申请当面付自己调用,则传null。 * @param bizContent = "{\"out_trade_no\":\"123213445324538\",\"total_amount\":\"0.01\",\"subject\":\"测试\"}"; * @return * @throws AlipayApiException 请处理异常 */ public AlipayTradePrecreateResponse precreate(String appAuthToken, String bizContent) throws AlipayApiException { AlipayTradePrecreateRequest request = new AlipayTradePrecreateRequest(); request.putOtherTextParam("app_auth_token", appAuthToken); request.setBizContent(bizContent); return AlipayClientFactory.getAlipayClientInstance().execute(request); }
当支付结果非支付成功的状态时,开发者需调用查询接口,轮询订单状态。
alipay.trade.query接口代码调用示例:
/** * 查询订单 * @param appAuthToken 如ISV代替商家调用当面付接口,需将商户授权后获取的app_auth_token带上;如商家申请当面付自己调用,则传null。 * @param bizContent = "{\"out_trade_no\":\"123213445324538\"}"; * @return * @throws AlipayApiException 请处理异常 */ public AlipayTradeQueryResponse query(String appAuthToken, String bizContent) throws AlipayApiException { AlipayTradeQueryRequest request = new AlipayTradeQueryRequest(); request.putOtherTextParam("app_auth_token", appAuthToken); request.setBizContent(bizContent); return AlipayClientFactory.getAlipayClientInstance().execute(request); }
注意:
只有发生支付系统超时或者支付结果未知时可调用撤销,正常支付的订单如需实现相同功能请调用退款接口。
alipay.trade.cancel接口代码调用示例:
/** * 撤销订单 * @param appAuthToken 如ISV代替商家调用当面付接口,需将商户授权后获取的app_auth_token带上;如商家申请当面付自己调用,则传null。 * @param bizContent = "{\"out_trade_no\":\"123213445324538\"}"; * @return * @throws AlipayApiException 请异常处理 */ public AlipayTradeCancelResponse cancel(String appAuthToken, String bizContent) throws AlipayApiException { AlipayTradeCancelRequest request = new AlipayTradeCancelRequest(); request.putOtherTextParam("app_auth_token", appAuthToken); request.setBizContent(bizContent); return AlipayClientFactory.getAlipayClientInstance().execute(request); }
当交易发生之后三个月内,由于买家或者卖家的原因需退款,卖家可通过退款接口将支付款退还给买家,支付宝将在收到退款请求并验证成功后,按退款规则将支付款原路退回到买家账号上。
alipay.trade.refund接口代码调用示例:
/** * 申请退款 * @param appAuthToken 如ISV代替商家调用当面付接口,需将商户授权后获取的app_auth_token带上;如商家申请当面付自己调用,则传null。 * @param bizContent = "{\"trade_no\":\"20160303363475784957483739744\",\"refund_amount\":\"0.01\"}"; * @return * @throws AlipayApiException 请异常处理 */ public AlipayTradeRefundResponse refund(String appAuthToken, String bizContent) throws AlipayApiException { AlipayTradeRefundRequest request = new AlipayTradeRefundRequest(); request.putOtherTextParam("app_auth_token", appAuthToken); request.setBizContent(bizContent); return AlipayClientFactory.getAlipayClientInstance().execute(request); }