之前一段时间研究和整理支付宝后端的代码,现在已经可以正常使用的,其实我们主要的还是担心我要给支付宝传递什么东西,我在什么地方处理我们的业务,我们怎么去响应和接收它。
在这里提一句,支付宝和微信传递的金额单位是不一样的,微信的是分为单位的,支付宝的则是元为单位的,朋友们记得做微信和支付宝支付这一块要注意了,尤其是后端的,记得处理下金额单位的转换啊。支付宝传递0.01(元),到微信就是1(分了)。
话不多说,支付宝后台主要代码附上,总共为2个,一个是配置文件AlipayConfig
public class AlipayConfig {
/**
* 支付宝的基本信息
*/
//支付宝网关
public static String gatewayurl = "https://openapi.alipay.com/gateway.do";
//应用id,收款账号为对应的支付宝账号
public static String App_id = "2016xxxxxxxx";
//用户id
public static String PId = "2088xxxxxxxxxx";
//UTF-8格式的RSA2私钥
public static String RSA2_PRIVATE = "";
//字符编码格式
public static String charset = "UTF-8";
//支付宝公钥(请注意,这里的是支付宝的公钥,不是你生成的公钥,朋友们别弄错了)
public static String alipay_public_key = "";
//服务器异步通知页面的路径 http://格式的路径,不可加自定义参数,必须要是外网也能访问的
public static String notify_url = "http://填写你的能被外网访问的地址/notify.jsp";
//页面跳转同步通知页面路径 http://格式的路径,不可加自定义参数,必须要是外网也能访问的
//public static String return_url = "这里app支付用不上,可以不写";
//签名方式
public static String sign_type = "RSA2";
//参数返回格式
public static String format = "json";
}
有什么疑问的可以问我,下面我在贴上处理代码,AliPay
public class AliPay {
AlipayConfig config = new AlipayConfig();
/**
* 支付宝支付
*
* @param amount
* 价格(以元为单位,1分钱的价格就传0.01,还有,价格你要么对前端传递过来的价格处理验证再调用支付,要么直接后台计算,这样安全,否则会有被拦截修改的风险)
* @param OrderNumber
* 订单号(订单号可以自己生成,记得放到后台生成)
* @return
*/
public String aliPay(String amount, String OrderNumber) {
// 实例化客户端
AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do", config.App_id,
config.RSA2_PRIVATE, "json", config.charset, config.alipay_public_key, config.sign_type);
// 实例化具体API对应的request类,类名称和接口名称对应,当前调用接口名称:alipay.trade.app.pay
AlipayTradeAppPayRequest request = new AlipayTradeAppPayRequest();
AlipayTradeAppPayModel model = new AlipayTradeAppPayModel();
/// 描述信息 添加附加数据
model.setSubject("传说级别的商品"); // 商品标题(对商品的描述)
model.setOutTradeNo(OrderNumber); // 商家订单编号
model.setTimeoutExpress("30m"); // 超时关闭该订单时间
model.setTotalAmount(amount); // 订单总金额
model.setProductCode("QUICK_MSECURITY_PAY"); // 销售产品码,商家和支付宝签约的产品码,为固定值QUICK_MSECURITY_PAY
request.setBizModel(model);
request.setNotifyUrl(config.notify_url); // 回调地址
String orderStr = "";
try {
// 这里和普通的接口调用不同,使用的是sdkExecute
AlipayTradeAppPayResponse response = alipayClient.sdkExecute(request);
orderStr = response.getBody();
/*
* 转换+变成空格,仅供测试查看使用,正式传递不需要转换: con = orderStr.replaceAll("\\+","%20");
*/
System.out.print(orderStr);// 就是orderString 可以直接给客户端请求,无需再做处理。
} catch (AlipayApiException e) {
e.printStackTrace();
}
return orderStr;
}
/**
* 验签
*
* @param requestParams
* 参数列表(包括待验签参数和签名值sign) key-参数名称 value-参数值
* 此段是将支付宝返回的值进行验签,异步回调
* @return
*/
public String aliPay_notify(Map requestParams) {
System.out.println("支付宝支付结果通知" + requestParams.toString());
// 获取支付宝POST过来反馈信息
Map<String, String> params = new HashMap<String, String>();
for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
String name = (String) iter.next();
String[] values = (String[]) 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);
}
// 切记alipaypublickey是支付宝的公钥,请去open.alipay.com对应应用下查看。
// boolean AlipaySignature.rsaCheckV1(Map<String, String> params, String
// publicKey, String charset, String sign_type)
try {
// 验证签名
boolean flag = AlipaySignature.rsaCheckV1(params, config.alipay_public_key, config.charset, "RSA2");
if (flag) {
if ("TRADE_SUCCESS".equals(params.get("trade_status"))) {
// 支付宝交易号
String trade_no = params.get("out_trade_no");
System.out.println("支付宝交易号:"+trade_no);
// 付款金额
String amount = params.get("total_amount");
System.out.println("支付宝付款金额:"+amount);
//下面放你的业务逻辑处理代码
}
}
return "success";
} catch (AlipayApiException e) {
e.printStackTrace();
return "FAIL";
}
}
}
以上便是支付宝支付的主要代码,有问的可以留言,该解析的我都'//' or '/**/'注释了,可以直接copy修改使用,记得导入支付宝的jar包啊,不然会报错的。