基于Java使用支付宝沙箱支付

基于Java使用支付宝沙箱支付

使用步骤:
参考博客
https://blog.csdn.net/stormdony/article/details/83305651

代码参考:
AlipayConfig.java

import java.io.FileWriter;
import java.io.IOException;
/**
 *类名:AlipayConfig
 *功能:基础配置类
 *详细:设置帐户有关信息及返回路径
 *说明:
 *以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。
 *该代码仅供学习和研究支付宝接口使用,只是提供一个参考。
 */
public class AlipayConfig {
//↓↓↓↓↓↓↓↓↓↓请在这里配置您的基本信息↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
	// 应用ID,您的APPID,收款账号既是您的APPID对应支付宝账号
	public static String app_id = "2016101200667395";
	// 商户私钥,您的PKCS8格式RSA2私钥
    public static String merchant_private_key = "MIIiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCf4QBdkv1BW3bwWng4PCb2Z1aB/ZcbIsViNG3kWxJywReNLU2zTpnS3o7wkGnLpE9OhOSDvafSGpBTG0VMmKVt7hlg5UnFX1Kk/rwxeEQfy6s83Xt2EsAOaYpegscdbEAmDEQ7AZ3Irgj+xnX5mkZI85MtZgxMY4jJfqmNORij9Hko6Cl10m+lj3kIIhior9w7bYEfNvV6drdntls6jLjj4VNL7NnRaANXY2dVq2OEMbWwwwbqyjtyvqLGbXtfcFccZz/4WZSiEZgQrezLFSGE0VS0zgr6IcqvIRIPCqj8+gLPwzibJlNfRMcL6u0QDSZNEEvhOe456oAfjt5BtaEBAgMBAAECggEBAJWphbMS1xpoaZWjyugxfvOoVrXG0r3nNcixdbGPg1yC3u4cW6EfUiWwizQsq6yi+k5xXozobAHlNfdmDuAeALZAbedjnEQz8GRdxYO1pmfxOzH1zw3/jWOwboP8fjJP1FkJoJFv+OkT6X2+AFAQl/zQbpTP83FKt5CPjl6R9Tv8MeepappNQWKwGo4kn86uyWCuO7fumjvMk308gC/0/xWhcnHySbdVjlRJGDQonRX9Gq3fcBBCdWdrHIJ6IEh/yV24IQNox58hIJi/Ofmbs69+1KioAKxPb09o8N/rH26r1Yt6Tg5ndzeg1mSvNPH42QqRyAclLgRLbPPyyjIsBHECgYEA2cOVsKH0DnQ2fn5Jzy4ZjqWocJBP3Zjif1vMhW6gwd7gj9DuRuJx5/dA0S8t/fuZDhp9x5EahYBPK2UYyu7lFyB93AB9NtPJu7mtFQQeku601jU2aesfJXJB4KxPkh/ANIsD5IU/vukIfdu/Vg50FPFGXOtzHJJUABgk8SSfOvUCgYEAu/OAko7+A+voy3ne1q67kx6R4g86m6MbqxjNqqoDLaTHce7ayf3XMRRETRQdBhCOIuLppkmSpOJ/RfvXIRZSkQkJkpbUmLGBfBTFySXb8x4m/gw8QDFqPf1bG8zUY0hJlRYzLD2AxbrzFOALgJFuwl51zVs/NHYlajhYfL9Snl0CgYBTwBHw9ch8SpuuuHlAkhVINFP8vrPIoQTzQGX/J1XyWfp5tTv+zRZLxV8LVJ7WoI3zy6J2P0s47ukDnQfJqmahuxNpoV9JZhQKBgGj2vD8dDE80WHYKQaCzRJ4M3Hva9Wgl1zXeTD2bZNsAw0GlmxpjYOJP5zUEnpDcfgSNpN7xB6x9sYZr9uDLjqDg4y+yfFgqCZ46G5sSQZusoyoNuzg+YI7uBwungJVRsYZJN5rlXh0PIuHtnX7XuXtjNXbSFqI9uPdxMDm6v3EhAoGBANDklNr2McKNnVuQP0eVUoJITBHEoOUZ29iDi19prkFdbTEtwPfOnpmOZZCQHDWW4tkJmsJ79PgWtw5SHRmNRIKi2XbSo0M/HbeDs8P7eW7vHTfBXPKEl6rVXC0yfF8W2q4/X+5wNW6mTYJXsNzHHz6j1b0OtKVDCV/3SDWNuRAk";
	
	// 支付宝公钥,查看地址:https://openhome.alipay.com/platform/keyManage.htm 对应APPID下的支付宝公钥。
    public static String alipay_public_key = "MIIBIjANBgkMIIBCgKCAQEAogY9mjwZXnNvSemRVDQQkbqGc9Ta0f+AvHft+L3QuaWrZA8KvP9oabWHlS6n3UlvR2+n2GjNY0SqvJSJdHlcpPliinTqdOY2pji2rvKUKzFty8dUvCWVaqrr++3C0WutBij8LkcKyTTtBdUzV+JsTTcw22pKy6i8KNvzJI7boorr7mycje0C6h54MKoC/fux3sd07CUoBx1HEOmDEnda2uxO3nNY7SQXXXMH4j/FE3bkGPd6xZTR3gBExavP+4iMOs7Z/WHpoMSwQIDAQAB";

	// 服务器异步通知页面路径  需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问
	public static String notify_url = "http://工程公网访问地址/alipay.trade.page.pay-JAVA-UTF-8/notify_url.jsp";

	// 页面跳转同步通知页面路径 需http://格式的完整路径,不能加?id=123这类自定义参数,必须外网可以正常访问
	public static String return_url = "http://工程公网访问地址/alipay.trade.page.pay-JAVA-UTF-8/return_url.jsp";

	// 签名方式
	public static String sign_type = "RSA2";
	
	// 字符编码格式
	public static String charset = "utf-8";
	
	// 支付宝网关 支付宝网关名-正式环境
	//public static String gatewayUrl = "https://openapi.alipay.com/gateway.do";
    //支付宝网关名-沙箱环境
    public static final String gatewayUrl="https://openapi.alipaydev.com/gateway.do";
	// 支付宝网关
	public static String log_path = "C:\\";


//↑↑↑↑↑↑↑↑↑↑请在这里配置您的基本信息↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑

    /** 
     * 写日志,方便测试(看网站需求,也可以改成把记录存入数据库)
     * @param sWord 要写入日志里的文本内容
     */
    public static void logResult(String sWord) {
        FileWriter writer = null;
        try {
            writer = new FileWriter(log_path + "alipay_log_" + System.currentTimeMillis()+".txt");
            writer.write(sWord);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (writer != null) {
                try {
                    writer.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}


PayMoney.java

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.alipay.config.*;
import com.alipay.api.*;
import com.alipay.api.request.*;
/**
 * Servlet implementation class PayMoney
 */
@WebServlet("/payMoney.do")
public class PayMoney extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		//获得初始化的AlipayClient
        AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
      //设置请求参数
        AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
        alipayRequest.setReturnUrl(AlipayConfig.return_url);
        alipayRequest.setNotifyUrl(AlipayConfig.notify_url);
        //商户订单号,商户网站订单系统中唯一订单号,必填
        String out_trade_no = request.getParameter("WIDout_trade_no");
        //付款金额,必填
        String total_amount = request.getParameter("WIDtotal_amount");
        //订单名称,必填
        String subject =request.getParameter("WIDsubject");
        //商品描述,可空
        String body = request.getParameter("WIDbody");
        alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\"," 
                + "\"total_amount\":\""+ total_amount +"\"," 
                + "\"subject\":\""+ subject +"\"," 
                + "\"body\":\""+ body +"\"," 
                + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");

        //请求
        String result;
		try {
			result = alipayClient.pageExecute(alipayRequest).getBody();
			response.setContentType("text/html;charset=" + AlipayConfig.charset);
	        response.getWriter().write(result);//直接将完整的表单html输出到页面
	        response.getWriter().flush();
	        response.getWriter().close();
		} catch (AlipayApiException e) {
			e.printStackTrace();
			response.getWriter().write("捕获异常出错");
	        response.getWriter().flush();
	        response.getWriter().close();
		}		
	}
}

前端页面管理
在这里插入图片描述
index.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
	pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>支付宝电脑网站支付</title>
<style>
* {
	margin: 0;
	padding: 0;
}
ul, ol {
	list-style: none;
}
body {
	font-family: "Helvetica Neue", Helvetica, Arial, "Lucida Grande",
		sans-serif;
}
.tab-head {
	margin-left: 120px;
	margin-bottom: 10px;
}
.tab-content {
	clear: left;
	display: none;
}
h2 {
	border-bottom: solid #02aaf1 2px;
	width: 200px;
	height: 25px;
	margin: 0;
	float: left;
	text-align: center;
	font-size: 16px;
}
.selected {
	color: #FFFFFF;
	background-color: #02aaf1;
}
.show {
	clear: left;
	display: block;
}
.hidden {
	display: none;
}
.new-btn-login-sp {
	padding: 1px;
	display: inline-block;
	width: 75%;
}
.new-btn-login {
	background-color: #02aaf1;
	color: #FFFFFF;
	font-weight: bold;
	border: none;
	width: 100%;
	height: 30px;
	border-radius: 5px;
	font-size: 16px;
}
#main {
	width: 100%;
	margin: 0 auto;
	font-size: 14px;
}
.red-star {
	color: #f00;
	width: 10px;
	display: inline-block;
}
.null-star {
	color: #fff;
}
.content {
	margin-top: 5px;
}
.content dt {
	width: 100px;
	display: inline-block;
	float: left;
	margin-left: 20px;
	color: #666;
	font-size: 13px;
	margin-top: 8px;
}
.content dd {
	margin-left: 120px;
	margin-bottom: 5px;
}
.content dd input {
	width: 85%;
	height: 28px;
	border: 0;
	-webkit-border-radius: 0;
	-webkit-appearance: none;
}
#foot {
	margin-top: 10px;
	position: absolute;
	bottom: 15px;
	width: 100%;
}
.foot-ul {
	width: 100%;
}
.foot-ul li {
	width: 100%;
	text-align: center;
	color: #666;
}
.note-help {
	color: #999999;
	font-size: 12px;
	line-height: 130%;
	margin-top: 5px;
	width: 100%;
	display: block;
}
#btn-dd {
	margin: 20px;
	text-align: center;
}
.foot-ul {
	width: 100%;
}
.one_line {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #eeeeee;
	width: 100%;
	margin-left: 20px;
}
.am-header {
	display: -webkit-box;
	display: -ms-flexbox;
	display: box;
	width: 100%;
	position: relative;
	padding: 7px 0;
	-webkit-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	background: #1D222D;
	height: 50px;
	text-align: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	box-pack: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	box-align: center;
}
.am-header h1 {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	box-flex: 1;
	line-height: 18px;
	text-align: center;
	font-size: 18px;
	font-weight: 300;
	color: #fff;
}
</style>
</head>
<body text=#000000 bgColor="#ffffff" leftMargin=0 topMargin=4>
	<header class="am-header">
	<h1>支付宝电脑网站支付体验入口页</h1>
	</header>
	<div id="main">
		<div id="tabhead" class="tab-head">
			<h2 id="tab1" class="selected" name="tab">付 款</h2>
			<h2 id="tab2" name="tab">交 易 查 询</h2>
			<h2 id="tab3" name="tab">退 款</h2>
			<h2 id="tab4" name="tab">退 款 查 询</h2>
			<h2 id="tab5" name="tab">交 易 关 闭</h2>
		</div>
		<form name=alipayment action=payMoney.do method=post target="_blank">
			<div id="body1" class="show" name="divcontent">
				<dl class="content">
					<dt>商户订单号 :</dt>
					<dd>
						<input id="WIDout_trade_no" name="WIDout_trade_no" />
					</dd>
					<hr class="one_line">
					<dt>订单名称 :</dt>
					<dd>
						<input id="WIDsubject" name="WIDsubject" />
					</dd>
					<hr class="one_line">
					<dt>付款金额 :</dt>
					<dd>
						<input id="WIDtotal_amount" name="WIDtotal_amount" />
					</dd>
					<hr class="one_line">
					<dt>商品描述:</dt>
					<dd>
						<input id="WIDbody" name="WIDbody" />
					</dd>
					<hr class="one_line">
					<dt></dt>
					<dd id="btn-dd">
						<span class="new-btn-login-sp">
							<button class="new-btn-login" type="submit"
								style="text-align: center;">付 款</button>
						</span> <span class="note-help">如果您点击“付款”按钮,即表示您同意该次的执行操作。</span>
					</dd>
				</dl>
			</div>
		</form>
		<form name=tradequery action=alipay.trade.query.jsp method=post
			target="_blank">
			<div id="body2" class="tab-content" name="divcontent">
				<dl class="content">
					<dt>商户订单号 :</dt>
					<dd>
						<input id="WIDTQout_trade_no" name="WIDTQout_trade_no" />
					</dd>
					<hr class="one_line">
					<dt>支付宝交易号 :</dt>
					<dd>
						<input id="WIDTQtrade_no" name="WIDTQtrade_no" />
					</dd>
					<hr class="one_line">
					<dt></dt>
					<dd id="btn-dd">
						<span class="new-btn-login-sp">
							<button class="new-btn-login" type="submit"
								style="text-align: center;">交 易 查 询</button>
						</span> <span class="note-help">商户订单号与支付宝交易号二选一,如果您点击“交易查询”按钮,即表示您同意该次的执行操作。</span>
					</dd>
				</dl>
			</div>
		</form>
		<form name=traderefund action=alipay.trade.refund.jsp method=post
			target="_blank">
			<div id="body3" class="tab-content" name="divcontent">
				<dl class="content">
					<dt>商户订单号 :</dt>
					<dd>
						<input id="WIDTRout_trade_no" name="WIDTRout_trade_no" />
					</dd>
					<hr class="one_line">
					<dt>支付宝交易号 :</dt>
					<dd>
						<input id="WIDTRtrade_no" name="WIDTRtrade_no" />
					</dd>
					<hr class="one_line">
					<dt>退款金额 :</dt>
					<dd>
						<input id="WIDTRrefund_amount" name="WIDTRrefund_amount" />
					</dd>
					<hr class="one_line">
					<dt>退款原因 :</dt>
					<dd>
						<input id="WIDTRrefund_reason" name="WIDTRrefund_reason" />
					</dd>
					<hr class="one_line">
					<dt>退款请求号 :</dt>
					<dd>
						<input id="WIDTRout_request_no" name="WIDTRout_request_no" />
					</dd>
					<hr class="one_line">
					<dt></dt>
					<dd id="btn-dd">
						<span class="new-btn-login-sp">
							<button class="new-btn-login" type="submit"
								style="text-align: center;">退 款</button>
						</span> <span class="note-help">商户订单号与支付宝交易号二选一,如果您点击“退款”按钮,即表示您同意该次的执行操作。</span>
					</dd>
				</dl>
			</div>
		</form>
		<form name=traderefundquery
			action=alipay.trade.fastpay.refund.query.jsp method=post
			target="_blank">
			<div id="body4" class="tab-content" name="divcontent">
				<dl class="content">
					<dt>商户订单号 :</dt>
					<dd>
						<input id="WIDRQout_trade_no" name="WIDRQout_trade_no" />
					</dd>
					<hr class="one_line">
					<dt>支付宝交易号 :</dt>
					<dd>
						<input id="WIDRQtrade_no" name="WIDRQtrade_no" />
					</dd>
					<hr class="one_line">
					<dt>退款请求号 :</dt>
					<dd>
						<input id="WIDRQout_request_no" name="WIDRQout_request_no" />
					</dd>
					<hr class="one_line">
					<dt></dt>
					<dd id="btn-dd">
						<span class="new-btn-login-sp">
							<button class="new-btn-login" type="submit"
								style="text-align: center;">退 款 查 询</button>
						</span> <span class="note-help">商户订单号与支付宝交易号二选一,如果您点击“退款查询”按钮,即表示您同意该次的执行操作。</span>
					</dd>
				</dl>
			</div>
		</form>
		<form name=tradeclose action=alipay.trade.close.jsp method=post
			target="_blank">
			<div id="body5" class="tab-content" name="divcontent">
				<dl class="content">
					<dt>商户订单号 :</dt>
					<dd>
						<input id="WIDTCout_trade_no" name="WIDTCout_trade_no" />
					</dd>
					<hr class="one_line">
					<dt>支付宝交易号 :</dt>
					<dd>
						<input id="WIDTCtrade_no" name="WIDTCtrade_no" />
					</dd>
					<hr class="one_line">
					<dt></dt>
					<dd id="btn-dd">
						<span class="new-btn-login-sp">
							<button class="new-btn-login" type="submit"
								style="text-align: center;">交 易 关 闭</button>
						</span> <span class="note-help">商户订单号与支付宝交易号二选一,如果您点击“交易关闭”按钮,即表示您同意该次的执行操作。</span>
					</dd>
				</dl>
			</div>
		</form>
		<div id="foot">
			<ul class="foot-ul">
				<li>支付宝版权所有 2015-2018 ALIPAY.COM</li>
			</ul>
		</div>
	</div>
</body>
<script language="javascript">
	var tabs = document.getElementsByName('tab');
	var contents = document.getElementsByName('divcontent');
	
	(function changeTab(tab) {
	    for(var i = 0, len = tabs.length; i < len; i++) {
	        tabs[i].onmouseover = showTab;
	    }
	})();
	
	function showTab() {
	    for(var i = 0, len = tabs.length; i < len; i++) {
	        if(tabs[i] === this) {
	            tabs[i].className = 'selected';
	            contents[i].className = 'show';
	        } else {
	            tabs[i].className = '';
	            contents[i].className = 'tab-content';
	        }
	    }
	}
	
	function GetDateNow() {
		var vNow = new Date();
		var sNow = "";
		sNow += String(vNow.getFullYear());
		sNow += String(vNow.getMonth() + 1);
		sNow += String(vNow.getDate());
		sNow += String(vNow.getHours());
		sNow += String(vNow.getMinutes());
		sNow += String(vNow.getSeconds());
		sNow += String(vNow.getMilliseconds());
		document.getElementById("WIDout_trade_no").value =  sNow;
		document.getElementById("WIDsubject").value = "测试";
		document.getElementById("WIDtotal_amount").value = "0.01";
	}
	GetDateNow();
</script>
</html>

运行结果截图:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值