支付宝APP支付后端 -java

之前一段时间研究和整理支付宝后端的代码,现在已经可以正常使用的,其实我们主要的还是担心我要给支付宝传递什么东西,我在什么地方处理我们的业务,我们怎么去响应和接收它。

在这里提一句,支付宝和微信传递的金额单位是不一样的,微信的是分为单位的,支付宝的则是元为单位的,朋友们记得做微信和支付宝支付这一块要注意了,尤其是后端的,记得处理下金额单位的转换啊。支付宝传递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包啊,不然会报错的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值