- 浏览: 157162 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
18335864773:
推荐用户国内自主研发的组件 pageoffice 组件生成 e ...
java 导出Excel poi 实现 -
nijinglie:
这个jsp页面具体怎么写????
java 导出Excel poi 实现 -
fxwjsw:
Array.prototype.distinct = func ...
js数组去除重复项目 -
ae6623:
讲的很好!!赞一个,嗯是图片向上滚动了-100px;这就好理解 ...
css背景定位技术 -
qieyi28:
呵呵
javascript &的秒用
转载地址 [url] http://my.oschina.net/bairrfhoinn/blog/78184[/url]
首先是发送快钱支付请求的页面send.jsp,内容如下:
001
<%@ page contentType="text/html; charset=gb2312" language="java"%>
002
<%@ page import="encrypt.MD5Util"%>
003
<%
004
/**
005
* @Description: 快钱人民币支付网关接口范例
006
* @Copyright (c) 上海快钱信息服务有限公司
007
* @version 2.0
008
*/
009
010
//人民币网关账户号
011
///请登录快钱系统获取用户编号,用户编号后加01即为人民币网关账户号。
012
String merchantAcctId="";
013
014
//人民币网关密钥
015
///区分大小写.请与快钱联系索取
016
String key="";
017
018
//字符集.固定选择值。可为空。
019
///只能选择1、2、3.
020
///1代表UTF-8; 2代表GBK; 3代表GB2312
021
///默认值为1
022
String inputCharset="3";
023
024
025
//服务器接受支付结果的后台地址.与[pageUrl]不能同时为空。必须是绝对地址。
026
///快钱通过服务器连接的方式将交易结果发送到[bgUrl]对应的页面地址,在商户处理完成后输出的<result>如果为1,页面会转向到<redirecturl>对应的地址。
027
///如果快钱未接收到<redirecturl>对应的地址,快钱将把支付结果GET到[pageUrl]对应的页面。
028
String bgUrl="http://www.yoursite.com/receive.jsp";
029
030
//网关版本.固定值
031
///快钱会根据版本号来调用对应的接口处理程序。
032
///本代码版本号固定为v2.0
033
String version="v2.0";
034
035
//语言种类.固定选择值。
036
///只能选择1、2、3
037
///1代表中文;2代表英文
038
///默认值为1
039
String language="1";
040
041
//签名类型.固定值
042
///1代表MD5签名
043
///当前版本固定为1
044
String signType="1";
045
046
//支付人姓名
047
///可为中文或英文字符
048
String payerName="payerName";
049
050
//支付人联系方式类型.固定选择值
051
///只能选择1
052
///1代表Email
053
String payerContactType="1";
054
055
//支付人联系方式
056
///只能选择Email或手机号
057
String payerContact="";
058
059
//商户订单号
060
///由字母、数字、或[-][_]组成
061
String orderId=new java.text.SimpleDateFormat("yyyyMMddHHmmss").format(new java.util.Date());
062
063
//订单金额,以分为单位,必须是整型数字,比方2,代表0.02元
064
String orderAmount="2";
065
066
//订单提交时间如;20080101010101
067
///14位数字。年[4位]月[2位]日[2位]时[2位]分[2位]秒[2位]
068
///如;20080101010101
069
String orderTime=new java.text.SimpleDateFormat("yyyyMMddHHmmss").format(new java.util.Date());
070
071
//商品名称,可为中文或英文字符
072
String productName="productName";
073
074
//商品数量,可为空,非空时必须为数字
075
String productNum="1";
076
077
//商品代码,可为字符或者数字
078
String productId="";
079
080
//商品描述
081
String productDesc="";
082
083
//扩展字段1
084
///在支付结束后原样返回给商户
085
String ext1="";
086
087
//扩展字段2
088
///在支付结束后原样返回给商户
089
String ext2="";
090
091
//支付方式.固定选择值
092
///只能选择00、10、11、12、13、14
093
///00:组合支付(网关支付页面显示快钱支持的各种支付方式,推荐使用)10:银行卡支付(网关支付页面只显示银行卡支付).11:电话银行支付(网关支付页面只显示电话支付).12:快钱账户支付(网关支付页面只显示快钱账户支付).13:线下支付(网关支付页面只显示线下支付方式)
094
String payType="00";
095
096
//同一订单禁止重复提交标志
097
///固定选择值: 1、0
098
///1代表同一订单号只允许提交1次;0表示同一订单号在没有支付成功的前提下可重复提交多次。默认为0建议实物购物车结算类商户采用0;虚拟产品类商户采用1
099
String redoFlag="1";
100
101
//快钱的合作伙伴的账户号
102
///如未和快钱签订代理合作协议,不需要填写本参数
103
String pid="";
104
//生成加密签名串
105
///请务必按照如下顺序和规则组成加密串!
106
String signMsgVal="";
107
signMsgVal=appendParam(signMsgVal,"inputCharset",inputCharset);//字符集设置
108
signMsgVal=appendParam(signMsgVal,"bgUrl",bgUrl);//服务器接受支付结果的后台地址,必须是绝对地址
109
signMsgVal=appendParam(signMsgVal,"version",version);//服务器版本号
110
signMsgVal=appendParam(signMsgVal,"language",language);//语言版本
111
signMsgVal=appendParam(signMsgVal,"signType",signType);//签名类型,固定值1
112
signMsgVal=appendParam(signMsgVal,"merchantAcctId",merchantAcctId);//人民币网关账户号
113
signMsgVal=appendParam(signMsgVal,"payerName",payerName);//支付人姓名,允许为中文或者英文
114
signMsgVal=appendParam(signMsgVal,"payerContactType",payerContactType);//支付人联系方式的类型,固定值1
115
signMsgVal=appendParam(signMsgVal,"payerContact",payerContact);//支付人联系方式,只能选择手机号或者Email
116
signMsgVal=appendParam(signMsgVal,"orderId",orderId);//商户订单号,是一个包含时间格式的字符串
117
signMsgVal=appendParam(signMsgVal,"orderAmount",orderAmount);//订单金额,以分为单位,必须是整型数字,比如数字2代表0.02元
118
signMsgVal=appendParam(signMsgVal,"orderTime",orderTime);////订单提交时间,如;20120801010101
119
signMsgVal=appendParam(signMsgVal,"productName",productName);//商品名称,可为中文或英文字符
120
signMsgVal=appendParam(signMsgVal,"productNum",productNum);//商品数量,可为空,非空时必须为壹个可以转化成整型数字的字符串
121
signMsgVal=appendParam(signMsgVal,"productId",productId);//商品代码,可为字符或者数字
122
signMsgVal=appendParam(signMsgVal,"productDesc",productDesc);//商品描述信息
123
signMsgVal=appendParam(signMsgVal,"ext1",ext1);//扩展字段1,在支付结束后原样返回给商户
124
signMsgVal=appendParam(signMsgVal,"ext2",ext2);//扩展字段2,在支付结束后原样返回给商户
125
signMsgVal=appendParam(signMsgVal,"payType",payType);//支付方式,推荐组合支付(网关支付页面显示快钱支持的各种支付方式),取值"00"
126
signMsgVal=appendParam(signMsgVal,"redoFlag",redoFlag);//是否允许同一订单重复提交,为1不允许,为0允许
127
signMsgVal=appendParam(signMsgVal,"pid",pid);//快钱的合作伙伴的账户号,可选项
128
signMsgVal=appendParam(signMsgVal,"key",key);
129
//下面这壹行中字符编码"UTF-8"实际与上面参数中的inputCharset没有任何关系,不过我们当时在理解这段代码时费了不少劲,前者只与JSP文件的编码格式有关
130
String signMsg=MD5Util.md5Hex(signMsgVal.getBytes("UTF-8")).toUpperCase();
131
%>
132
<%!
133
//功能函数。将变量值不为空的参数组成字符串
134
public String appendParam(String returnStr,String paramId,String paramValue)
135
{
136
if(!returnStr.equals(""))
137
{
138
if(!paramValue.equals(""))
139
{
140
returnStr=returnStr+"&"+paramId+"="+paramValue;
141
}
142
}
143
else
144
{
145
if(!paramValue.equals(""))
146
{
147
returnStr=paramId+"="+paramValue;
148
}
149
}
150
return returnStr;
151
}
152
//功能函数。将变量值不为空的参数组成字符串。结束
153
%>
154
<!doctype html public "-//w3c//dtd html 4.0 transitional//en" >
155
<html>
156
<head>
157
<title>使用快钱支付</title>
158
<meta http-equiv="content-type" content="text/html; charset=gb2312" >
159
</head>
160
<body>
161
<div align="center">
162
<table width="259" border="0" cellpadding="1" cellspacing="1" bgcolor="#CCCCCC" >
163
<tr bgcolor="#FFFFFF">
164
<td width="80">支付方式:</td>
165
<td >快钱[99bill]</td>
166
</tr>
167
<tr bgcolor="#FFFFFF">
168
<td >订单编号:</td>
169
<td ><%=orderId %></td>
170
</tr>
171
<tr bgcolor="#FFFFFF">
172
<td>订单金额:</td>
173
<td><%=orderAmount %></td>
174
</tr>
175
<tr bgcolor="#FFFFFF">
176
<td>支付人:</td>
177
<td><%=payerName %></td>
178
</tr>
179
<tr bgcolor="#FFFFFF">
180
<td>商品名称:</td>
181
<td><%=productName %></td>
182
</tr>
183
<tr>
184
<td></td>
185
<td></td>
186
</tr>
187
</table>
188
</div>
189
190
<div align="center" style="font-size=12px;font-weight: bold;color=red;">
191
<form name="kqPay" action="https://www.99bill.com/gateway/recvMerchantInfoAction.htm" method="post">
192
<input type="hidden" name="inputCharset" value="<%=inputCharset %>"/>
193
<input type="hidden" name="bgUrl" value="<%=bgUrl %>"/>
194
<input type="hidden" name="version" value="<%=version %>"/>
195
<input type="hidden" name="language" value="<%=language %>"/>
196
<input type="hidden" name="signType" value="<%=signType %>"/>
197
<input type="hidden" name="signMsg" value="<%=signMsg %>"/>
198
<input type="hidden" name="merchantAcctId" value="<%=merchantAcctId %>"/>
199
<input type="hidden" name="payerName" value="<%=payerName %>"/>
200
<input type="hidden" name="payerContactType" value="<%=payerContactType %>"/>
201
<input type="hidden" name="payerContact" value="<%=payerContact %>"/>
202
<input type="hidden" name="orderId" value="<%=orderId %>"/>
203
<input type="hidden" name="orderAmount" value="<%=orderAmount %>"/>
204
<input type="hidden" name="orderTime" value="<%=orderTime %>"/>
205
<input type="hidden" name="productName" value="<%=productName %>"/>
206
<input type="hidden" name="productNum" value="<%=productNum %>"/>
207
<input type="hidden" name="productId" value="<%=productId %>"/>
208
<input type="hidden" name="productDesc" value="<%=productDesc %>"/>
209
<input type="hidden" name="ext1" value="<%=ext1 %>"/>
210
<input type="hidden" name="ext2" value="<%=ext2 %>"/>
211
<input type="hidden" name="payType" value="<%=payType %>"/>
212
<input type="hidden" name="redoFlag" value="<%=redoFlag %>"/>
213
<input type="hidden" name="pid" value="<%=pid %>"/>
214
<input type="submit" name="submit" value="提交到快钱">
215
</form>
216
</div>
217
</body>
218
</html>
上面这个文件中,有几个需要注意的地方:(1)组装之后的变量 signMsgVal 需要将其加密,加密时的字符集与我们的参数列表中的inputCharset没有任何关系的,如果壹定要讲,它只与页面的编码格式有关,目前我们的页面中使用的是UTF-8,所以这里我也将其字符格式设置成了UTF-8;(2)本页面提交之后应该跳转至receive.jsp,而不是响应我们的应用,当时我们的代码中就是这个地方完全弄错了,所以无论我们怎么尝试,都无法回调我们的应用请求。据客户方反馈的信息,说这个功能当初测试的时候是通过的,我颇表怀疑,因为这个流程根本就不通,如何能够测试通过呢;(3)对SignMsgVal进行加密的方法MD5Util.md5Hex(),其定义是由快钱技术部门直接提供的,其功能就是加密字符串并生成对应的KEY,用于快钱系统完成支付之后将回调信息返回给我们的系统;因此,这个加密的过程是与支付的流程完全独立的,也就是说我们完全可以用自己实现的加密方案来替换这部分代码,或者也可以选用其它市场上已经成熟的加密方案;(4)特别需要注意的是,此时我们不将加密之后生成的KEY值发送到快钱系统,而是将它保留,用于快钱返回之后验证某次支付请求是否与我们的订单明细信息相匹配。(5)变量中merchantAccId也是壹个需要注意的地方,它是快钱方提供给我们应用的壹个类似收款帐号样的东西,具体可以咨询快钱技术部或者你的应用提供商。
001
<%@page contentType="text/html; charset=UTF-8" language="java"%>
002
<%@ page import="encrypt.MD5Util"%>
003
<%
004
/**
005
* @Description: 快钱人民币支付网关接口范例
006
* @Copyright (c) 上海快钱信息服务有限公司
007
* @version 2.0
008
*/
009
010
//获取人民币网关账户号
011
String merchantAcctId=(String)request.getParameter("merchantAcctId").trim();
012
013
//设置人民币网关密钥
014
///区分大小写
015
String key="";
016
017
//获取网关版本.固定值
018
///快钱会根据版本号来调用对应的接口处理程序。
019
///本代码版本号固定为v2.0
020
String version=(String)request.getParameter("version").trim();
021
022
//获取语言种类.固定选择值。
023
///只能选择1、2、3
024
///1代表中文;2代表英文
025
///默认值为1
026
String language=(String)request.getParameter("language").trim();
027
028
//签名类型.固定值
029
///1代表MD5签名
030
///当前版本固定为1
031
String signType=(String)request.getParameter("signType").trim();
032
033
//获取支付方式
034
///值为:10、11、12、13、14
035
///00:组合支付(网关支付页面显示快钱支持的各种支付方式,推荐使用)10:银行卡支付(网关支付页面只显示银行卡支付).11:电话银行支付(网关支付页面只显示电话支付).12:快钱账户支付(网关支付页面只显示快钱账户支付).13:线下支付(网关支付页面只显示线下支付方式).14:B2B支付(网关支付页面只显示B2B支付,但需要向快钱申请开通才能使用)
036
String payType=(String)request.getParameter("payType").trim();
037
038
//获取银行代码
039
///参见银行代码列表
040
String bankId=(String)request.getParameter("bankId").trim();
041
042
//获取商户订单号
043
String orderId=(String)request.getParameter("orderId").trim();
044
045
//获取订单提交时间
046
///获取商户提交订单时的时间.14位数字。年[4位]月[2位]日[2位]时[2位]分[2位]秒[2位]
047
///如:20080101010101
048
String orderTime=(String)request.getParameter("orderTime").trim();
049
050
//获取原始订单金额
051
///订单提交到快钱时的金额,单位为分。
052
///比方2 ,代表0.02元
053
String orderAmount=(String)request.getParameter("orderAmount").trim();
054
055
//获取快钱交易号
056
///获取该交易在快钱的交易号
057
String dealId=(String)request.getParameter("dealId").trim();
058
059
//获取银行交易号
060
///如果使用银行卡支付时,在银行的交易号。如不是通过银行支付,则为空
061
String bankDealId=(String)request.getParameter("bankDealId").trim();
062
063
//获取在快钱交易时间
064
///14位数字。年[4位]月[2位]日[2位]时[2位]分[2位]秒[2位]
065
///如;20080101010101
066
String dealTime=(String)request.getParameter("dealTime").trim();
067
068
//获取实际支付金额
069
///单位为分
070
///比方 2 ,代表0.02元
071
String payAmount=(String)request.getParameter("payAmount").trim();
072
073
//获取交易手续费
074
///单位为分
075
///比方 2 ,代表0.02元
076
String fee=(String)request.getParameter("fee").trim();
077
078
//获取扩展字段1
079
String ext1=(String)request.getParameter("ext1").trim();
080
081
//获取扩展字段2
082
String ext2=(String)request.getParameter("ext2").trim();
083
084
//获取处理结果
085
///10代表 成功11代表 失败
086
///00代表 下订单成功(仅对电话银行支付订单返回);01代表 下订单失败(仅对电话银行支付订单返回)
087
String payResult=(String)request.getParameter("payResult").trim();
088
089
//获取错误代码
090
///详细见文档错误代码列表
091
String errCode=(String)request.getParameter("errCode").trim();
092
093
//获取加密签名串
094
String signMsg=(String)request.getParameter("signMsg").trim();
095
096
//生成加密串。必须保持如下顺序。
097
String merchantSignMsgVal="";
098
merchantSignMsgVal=appendParam(merchantSignMsgVal,"merchantAcctId",merchantAcctId);
099
merchantSignMsgVal=appendParam(merchantSignMsgVal,"version",version);
100
merchantSignMsgVal=appendParam(merchantSignMsgVal,"language",language);
101
merchantSignMsgVal=appendParam(merchantSignMsgVal,"signType",signType);
102
merchantSignMsgVal=appendParam(merchantSignMsgVal,"payType",payType);
103
merchantSignMsgVal=appendParam(merchantSignMsgVal,"bankId",bankId);
104
merchantSignMsgVal=appendParam(merchantSignMsgVal,"orderId",orderId);
105
merchantSignMsgVal=appendParam(merchantSignMsgVal,"orderTime",orderTime);
106
merchantSignMsgVal=appendParam(merchantSignMsgVal,"orderAmount",orderAmount);
107
merchantSignMsgVal=appendParam(merchantSignMsgVal,"dealId",dealId);
108
merchantSignMsgVal=appendParam(merchantSignMsgVal,"bankDealId",bankDealId);
109
merchantSignMsgVal=appendParam(merchantSignMsgVal,"dealTime",dealTime);
110
merchantSignMsgVal=appendParam(merchantSignMsgVal,"payAmount",payAmount);
111
merchantSignMsgVal=appendParam(merchantSignMsgVal,"fee",fee);
112
merchantSignMsgVal=appendParam(merchantSignMsgVal,"ext1",ext1);
113
merchantSignMsgVal=appendParam(merchantSignMsgVal,"ext2",ext2);
114
merchantSignMsgVal=appendParam(merchantSignMsgVal,"payResult",payResult);
115
merchantSignMsgVal=appendParam(merchantSignMsgVal,"errCode",errCode);
116
merchantSignMsgVal=appendParam(merchantSignMsgVal,"key",key);
117
118
String merchantSignMsg=MD5Util.md5Hex(merchantSignMsgVal.getBytes("UTF-8")).toUpperCase();
119
//初始化结果及地址
120
int rtnOk=0;
121
String rtnUrl="";
122
123
//商家进行数据处理,并跳转回商家显示支付结果的页面
124
///首先进行签名字符串验证
125
if(signMsg.toUpperCase().equals(merchantSignMsg.toUpperCase())){
126
///接着进行支付结果判断
127
switch(Integer.parseInt(payResult)){
128
case 10:
129
// 商户网站逻辑处理,比方更新订单支付状态为成功
130
// 特别注意:只有signMsg.toUpperCase().equals(merchantSignMsg.toUpperCase()),且payResult=10,才表示支付成功
131
//报告给快钱处理结果,并提供将要重定向的地址。
132
rtnOk=1;
133
rtnUrl="http://www.yoursite.com/show.jsp?msg=success!";
134
break;
135
default:
136
rtnOk=1;
137
rtnUrl="http://www.yoursite.com/show.jsp?msg=false!";
138
break;
139
}
140
}else{
141
rtnOk=1;
142
rtnUrl="http://www.yoursite.com/show.jsp?msg=error!";
143
}
144
145
%>
146
<%!
147
//功能函数。将变量值不为空的参数组成字符串
148
public String appendParam(String returnStr,String paramId,String paramValue) {
149
if(!returnStr.equals("")) {
150
if(!paramValue.equals(""))
151
{
152
returnStr=returnStr+"&"+paramId+"="+paramValue;
153
}
154
} else {
155
if(!paramValue.equals(""))
156
{
157
returnStr=paramId+"="+paramValue;
158
}
159
}
160
return returnStr;
161
}
162
//功能函数。将变量值不为空的参数组成字符串。结束
163
//以下报告给快钱处理结果,并提供将要重定向的地址
164
%>
165
<result><%=rtnOk %></result><redirecturl><%=rtnUrl %></redirecturl>
上壹页的代码是receive.jsp,它是快钱完成它的任务之后返回我们的信息接收页面,返回时会携带所有我们刚才提交的参数以及完成支付时用到的壹些信息,如交易号、银行标识号、商户号、支付成功或者失败时的标识码等。这个页面有壹个特别的地方在于它底部的那个字符串,通过与快钱技术部门沟通之后得知,它是用于再壹次发送到快钱时必须的内容,用于告诉快钱本次提交是成功还是失败,其中的参数rtnOk是状态标识码,rtnUrl则是快钱系统回调我们的应用时要用到的请求地址,这个地址必须是公网地址,也就是说,它必须能够通过公共网络被快钱访问到,不可以是局域网地址如http://127.0.0.1:8080/之类,而应该是类似于http://www.google.com.sg/这种。
在这个页面的请求发送之后,接下来就是我们自己的应用的页面了,快钱也提供了壹个简单的样例页面来展示它,内容如下:
01
<%@page contentType="text/html; charset=UTF-8" language="java"%>
02
<%
03
/*
04
* @Description: 快钱人民币支付网关接口范例
05
* @Copyright (c) 上海快钱信息服务有限公司
06
* @version 2.0
07
*/
08
09
/*
10
在本文件中,商家应从数据库中,查询到订单的状态信息以及订单的处理结果。给出支付人响应的提示。
11
本范例采用最简单的模式,直接从receive页面获取支付状态提示给用户。
12
*/
13
String orderId=(String)request.getParameter("orderId").trim();
14
String orderAmount=(String)request.getParameter("orderAmount").trim();
15
String msg=(String)request.getParameter("msg").trim();
16
%>
17
<!doctype html public "-//w3c//dtd html 4.0 transitional//en" >
18
<html>
19
<head>
20
<title>快钱支付结果</title>
21
<meta http-equiv="content-type" content="text/html; charset=UTF-8" >
22
</head>
23
<body>
24
<div align="center">
25
<table width="259" border="0" cellpadding="1" cellspacing="1" bgcolor="#CCCCCC" >
26
<tr bgcolor="#FFFFFF">
27
<td width="80">支付方式:</td>
28
<td >快钱[99bill]</td>
29
</tr>
30
<tr bgcolor="#FFFFFF">
31
<td >订单编号:</td>
32
<td ><%=orderId %></td>
33
</tr>
34
<tr bgcolor="#FFFFFF">
35
<td>订单金额:</td>
36
<td><%=(orderAmount)+"分" %></td>
37
</tr>
38
<tr bgcolor="#FFFFFF">
39
<td>支付结果:</td>
40
<td><%=msg %></td>
41
</tr>
42
<tr>
43
<td></td>
44
<td></td>
45
</tr>
46
</table>
47
</div>
48
</body>
49
</html>
上面这个页面中的内容,其实我们可以随便的自定义,这里只是提供个样例,没有什么特别的内容,照着做就行了。
首先是发送快钱支付请求的页面send.jsp,内容如下:
001
<%@ page contentType="text/html; charset=gb2312" language="java"%>
002
<%@ page import="encrypt.MD5Util"%>
003
<%
004
/**
005
* @Description: 快钱人民币支付网关接口范例
006
* @Copyright (c) 上海快钱信息服务有限公司
007
* @version 2.0
008
*/
009
010
//人民币网关账户号
011
///请登录快钱系统获取用户编号,用户编号后加01即为人民币网关账户号。
012
String merchantAcctId="";
013
014
//人民币网关密钥
015
///区分大小写.请与快钱联系索取
016
String key="";
017
018
//字符集.固定选择值。可为空。
019
///只能选择1、2、3.
020
///1代表UTF-8; 2代表GBK; 3代表GB2312
021
///默认值为1
022
String inputCharset="3";
023
024
025
//服务器接受支付结果的后台地址.与[pageUrl]不能同时为空。必须是绝对地址。
026
///快钱通过服务器连接的方式将交易结果发送到[bgUrl]对应的页面地址,在商户处理完成后输出的<result>如果为1,页面会转向到<redirecturl>对应的地址。
027
///如果快钱未接收到<redirecturl>对应的地址,快钱将把支付结果GET到[pageUrl]对应的页面。
028
String bgUrl="http://www.yoursite.com/receive.jsp";
029
030
//网关版本.固定值
031
///快钱会根据版本号来调用对应的接口处理程序。
032
///本代码版本号固定为v2.0
033
String version="v2.0";
034
035
//语言种类.固定选择值。
036
///只能选择1、2、3
037
///1代表中文;2代表英文
038
///默认值为1
039
String language="1";
040
041
//签名类型.固定值
042
///1代表MD5签名
043
///当前版本固定为1
044
String signType="1";
045
046
//支付人姓名
047
///可为中文或英文字符
048
String payerName="payerName";
049
050
//支付人联系方式类型.固定选择值
051
///只能选择1
052
///1代表Email
053
String payerContactType="1";
054
055
//支付人联系方式
056
///只能选择Email或手机号
057
String payerContact="";
058
059
//商户订单号
060
///由字母、数字、或[-][_]组成
061
String orderId=new java.text.SimpleDateFormat("yyyyMMddHHmmss").format(new java.util.Date());
062
063
//订单金额,以分为单位,必须是整型数字,比方2,代表0.02元
064
String orderAmount="2";
065
066
//订单提交时间如;20080101010101
067
///14位数字。年[4位]月[2位]日[2位]时[2位]分[2位]秒[2位]
068
///如;20080101010101
069
String orderTime=new java.text.SimpleDateFormat("yyyyMMddHHmmss").format(new java.util.Date());
070
071
//商品名称,可为中文或英文字符
072
String productName="productName";
073
074
//商品数量,可为空,非空时必须为数字
075
String productNum="1";
076
077
//商品代码,可为字符或者数字
078
String productId="";
079
080
//商品描述
081
String productDesc="";
082
083
//扩展字段1
084
///在支付结束后原样返回给商户
085
String ext1="";
086
087
//扩展字段2
088
///在支付结束后原样返回给商户
089
String ext2="";
090
091
//支付方式.固定选择值
092
///只能选择00、10、11、12、13、14
093
///00:组合支付(网关支付页面显示快钱支持的各种支付方式,推荐使用)10:银行卡支付(网关支付页面只显示银行卡支付).11:电话银行支付(网关支付页面只显示电话支付).12:快钱账户支付(网关支付页面只显示快钱账户支付).13:线下支付(网关支付页面只显示线下支付方式)
094
String payType="00";
095
096
//同一订单禁止重复提交标志
097
///固定选择值: 1、0
098
///1代表同一订单号只允许提交1次;0表示同一订单号在没有支付成功的前提下可重复提交多次。默认为0建议实物购物车结算类商户采用0;虚拟产品类商户采用1
099
String redoFlag="1";
100
101
//快钱的合作伙伴的账户号
102
///如未和快钱签订代理合作协议,不需要填写本参数
103
String pid="";
104
//生成加密签名串
105
///请务必按照如下顺序和规则组成加密串!
106
String signMsgVal="";
107
signMsgVal=appendParam(signMsgVal,"inputCharset",inputCharset);//字符集设置
108
signMsgVal=appendParam(signMsgVal,"bgUrl",bgUrl);//服务器接受支付结果的后台地址,必须是绝对地址
109
signMsgVal=appendParam(signMsgVal,"version",version);//服务器版本号
110
signMsgVal=appendParam(signMsgVal,"language",language);//语言版本
111
signMsgVal=appendParam(signMsgVal,"signType",signType);//签名类型,固定值1
112
signMsgVal=appendParam(signMsgVal,"merchantAcctId",merchantAcctId);//人民币网关账户号
113
signMsgVal=appendParam(signMsgVal,"payerName",payerName);//支付人姓名,允许为中文或者英文
114
signMsgVal=appendParam(signMsgVal,"payerContactType",payerContactType);//支付人联系方式的类型,固定值1
115
signMsgVal=appendParam(signMsgVal,"payerContact",payerContact);//支付人联系方式,只能选择手机号或者Email
116
signMsgVal=appendParam(signMsgVal,"orderId",orderId);//商户订单号,是一个包含时间格式的字符串
117
signMsgVal=appendParam(signMsgVal,"orderAmount",orderAmount);//订单金额,以分为单位,必须是整型数字,比如数字2代表0.02元
118
signMsgVal=appendParam(signMsgVal,"orderTime",orderTime);////订单提交时间,如;20120801010101
119
signMsgVal=appendParam(signMsgVal,"productName",productName);//商品名称,可为中文或英文字符
120
signMsgVal=appendParam(signMsgVal,"productNum",productNum);//商品数量,可为空,非空时必须为壹个可以转化成整型数字的字符串
121
signMsgVal=appendParam(signMsgVal,"productId",productId);//商品代码,可为字符或者数字
122
signMsgVal=appendParam(signMsgVal,"productDesc",productDesc);//商品描述信息
123
signMsgVal=appendParam(signMsgVal,"ext1",ext1);//扩展字段1,在支付结束后原样返回给商户
124
signMsgVal=appendParam(signMsgVal,"ext2",ext2);//扩展字段2,在支付结束后原样返回给商户
125
signMsgVal=appendParam(signMsgVal,"payType",payType);//支付方式,推荐组合支付(网关支付页面显示快钱支持的各种支付方式),取值"00"
126
signMsgVal=appendParam(signMsgVal,"redoFlag",redoFlag);//是否允许同一订单重复提交,为1不允许,为0允许
127
signMsgVal=appendParam(signMsgVal,"pid",pid);//快钱的合作伙伴的账户号,可选项
128
signMsgVal=appendParam(signMsgVal,"key",key);
129
//下面这壹行中字符编码"UTF-8"实际与上面参数中的inputCharset没有任何关系,不过我们当时在理解这段代码时费了不少劲,前者只与JSP文件的编码格式有关
130
String signMsg=MD5Util.md5Hex(signMsgVal.getBytes("UTF-8")).toUpperCase();
131
%>
132
<%!
133
//功能函数。将变量值不为空的参数组成字符串
134
public String appendParam(String returnStr,String paramId,String paramValue)
135
{
136
if(!returnStr.equals(""))
137
{
138
if(!paramValue.equals(""))
139
{
140
returnStr=returnStr+"&"+paramId+"="+paramValue;
141
}
142
}
143
else
144
{
145
if(!paramValue.equals(""))
146
{
147
returnStr=paramId+"="+paramValue;
148
}
149
}
150
return returnStr;
151
}
152
//功能函数。将变量值不为空的参数组成字符串。结束
153
%>
154
<!doctype html public "-//w3c//dtd html 4.0 transitional//en" >
155
<html>
156
<head>
157
<title>使用快钱支付</title>
158
<meta http-equiv="content-type" content="text/html; charset=gb2312" >
159
</head>
160
<body>
161
<div align="center">
162
<table width="259" border="0" cellpadding="1" cellspacing="1" bgcolor="#CCCCCC" >
163
<tr bgcolor="#FFFFFF">
164
<td width="80">支付方式:</td>
165
<td >快钱[99bill]</td>
166
</tr>
167
<tr bgcolor="#FFFFFF">
168
<td >订单编号:</td>
169
<td ><%=orderId %></td>
170
</tr>
171
<tr bgcolor="#FFFFFF">
172
<td>订单金额:</td>
173
<td><%=orderAmount %></td>
174
</tr>
175
<tr bgcolor="#FFFFFF">
176
<td>支付人:</td>
177
<td><%=payerName %></td>
178
</tr>
179
<tr bgcolor="#FFFFFF">
180
<td>商品名称:</td>
181
<td><%=productName %></td>
182
</tr>
183
<tr>
184
<td></td>
185
<td></td>
186
</tr>
187
</table>
188
</div>
189
190
<div align="center" style="font-size=12px;font-weight: bold;color=red;">
191
<form name="kqPay" action="https://www.99bill.com/gateway/recvMerchantInfoAction.htm" method="post">
192
<input type="hidden" name="inputCharset" value="<%=inputCharset %>"/>
193
<input type="hidden" name="bgUrl" value="<%=bgUrl %>"/>
194
<input type="hidden" name="version" value="<%=version %>"/>
195
<input type="hidden" name="language" value="<%=language %>"/>
196
<input type="hidden" name="signType" value="<%=signType %>"/>
197
<input type="hidden" name="signMsg" value="<%=signMsg %>"/>
198
<input type="hidden" name="merchantAcctId" value="<%=merchantAcctId %>"/>
199
<input type="hidden" name="payerName" value="<%=payerName %>"/>
200
<input type="hidden" name="payerContactType" value="<%=payerContactType %>"/>
201
<input type="hidden" name="payerContact" value="<%=payerContact %>"/>
202
<input type="hidden" name="orderId" value="<%=orderId %>"/>
203
<input type="hidden" name="orderAmount" value="<%=orderAmount %>"/>
204
<input type="hidden" name="orderTime" value="<%=orderTime %>"/>
205
<input type="hidden" name="productName" value="<%=productName %>"/>
206
<input type="hidden" name="productNum" value="<%=productNum %>"/>
207
<input type="hidden" name="productId" value="<%=productId %>"/>
208
<input type="hidden" name="productDesc" value="<%=productDesc %>"/>
209
<input type="hidden" name="ext1" value="<%=ext1 %>"/>
210
<input type="hidden" name="ext2" value="<%=ext2 %>"/>
211
<input type="hidden" name="payType" value="<%=payType %>"/>
212
<input type="hidden" name="redoFlag" value="<%=redoFlag %>"/>
213
<input type="hidden" name="pid" value="<%=pid %>"/>
214
<input type="submit" name="submit" value="提交到快钱">
215
</form>
216
</div>
217
</body>
218
</html>
上面这个文件中,有几个需要注意的地方:(1)组装之后的变量 signMsgVal 需要将其加密,加密时的字符集与我们的参数列表中的inputCharset没有任何关系的,如果壹定要讲,它只与页面的编码格式有关,目前我们的页面中使用的是UTF-8,所以这里我也将其字符格式设置成了UTF-8;(2)本页面提交之后应该跳转至receive.jsp,而不是响应我们的应用,当时我们的代码中就是这个地方完全弄错了,所以无论我们怎么尝试,都无法回调我们的应用请求。据客户方反馈的信息,说这个功能当初测试的时候是通过的,我颇表怀疑,因为这个流程根本就不通,如何能够测试通过呢;(3)对SignMsgVal进行加密的方法MD5Util.md5Hex(),其定义是由快钱技术部门直接提供的,其功能就是加密字符串并生成对应的KEY,用于快钱系统完成支付之后将回调信息返回给我们的系统;因此,这个加密的过程是与支付的流程完全独立的,也就是说我们完全可以用自己实现的加密方案来替换这部分代码,或者也可以选用其它市场上已经成熟的加密方案;(4)特别需要注意的是,此时我们不将加密之后生成的KEY值发送到快钱系统,而是将它保留,用于快钱返回之后验证某次支付请求是否与我们的订单明细信息相匹配。(5)变量中merchantAccId也是壹个需要注意的地方,它是快钱方提供给我们应用的壹个类似收款帐号样的东西,具体可以咨询快钱技术部或者你的应用提供商。
001
<%@page contentType="text/html; charset=UTF-8" language="java"%>
002
<%@ page import="encrypt.MD5Util"%>
003
<%
004
/**
005
* @Description: 快钱人民币支付网关接口范例
006
* @Copyright (c) 上海快钱信息服务有限公司
007
* @version 2.0
008
*/
009
010
//获取人民币网关账户号
011
String merchantAcctId=(String)request.getParameter("merchantAcctId").trim();
012
013
//设置人民币网关密钥
014
///区分大小写
015
String key="";
016
017
//获取网关版本.固定值
018
///快钱会根据版本号来调用对应的接口处理程序。
019
///本代码版本号固定为v2.0
020
String version=(String)request.getParameter("version").trim();
021
022
//获取语言种类.固定选择值。
023
///只能选择1、2、3
024
///1代表中文;2代表英文
025
///默认值为1
026
String language=(String)request.getParameter("language").trim();
027
028
//签名类型.固定值
029
///1代表MD5签名
030
///当前版本固定为1
031
String signType=(String)request.getParameter("signType").trim();
032
033
//获取支付方式
034
///值为:10、11、12、13、14
035
///00:组合支付(网关支付页面显示快钱支持的各种支付方式,推荐使用)10:银行卡支付(网关支付页面只显示银行卡支付).11:电话银行支付(网关支付页面只显示电话支付).12:快钱账户支付(网关支付页面只显示快钱账户支付).13:线下支付(网关支付页面只显示线下支付方式).14:B2B支付(网关支付页面只显示B2B支付,但需要向快钱申请开通才能使用)
036
String payType=(String)request.getParameter("payType").trim();
037
038
//获取银行代码
039
///参见银行代码列表
040
String bankId=(String)request.getParameter("bankId").trim();
041
042
//获取商户订单号
043
String orderId=(String)request.getParameter("orderId").trim();
044
045
//获取订单提交时间
046
///获取商户提交订单时的时间.14位数字。年[4位]月[2位]日[2位]时[2位]分[2位]秒[2位]
047
///如:20080101010101
048
String orderTime=(String)request.getParameter("orderTime").trim();
049
050
//获取原始订单金额
051
///订单提交到快钱时的金额,单位为分。
052
///比方2 ,代表0.02元
053
String orderAmount=(String)request.getParameter("orderAmount").trim();
054
055
//获取快钱交易号
056
///获取该交易在快钱的交易号
057
String dealId=(String)request.getParameter("dealId").trim();
058
059
//获取银行交易号
060
///如果使用银行卡支付时,在银行的交易号。如不是通过银行支付,则为空
061
String bankDealId=(String)request.getParameter("bankDealId").trim();
062
063
//获取在快钱交易时间
064
///14位数字。年[4位]月[2位]日[2位]时[2位]分[2位]秒[2位]
065
///如;20080101010101
066
String dealTime=(String)request.getParameter("dealTime").trim();
067
068
//获取实际支付金额
069
///单位为分
070
///比方 2 ,代表0.02元
071
String payAmount=(String)request.getParameter("payAmount").trim();
072
073
//获取交易手续费
074
///单位为分
075
///比方 2 ,代表0.02元
076
String fee=(String)request.getParameter("fee").trim();
077
078
//获取扩展字段1
079
String ext1=(String)request.getParameter("ext1").trim();
080
081
//获取扩展字段2
082
String ext2=(String)request.getParameter("ext2").trim();
083
084
//获取处理结果
085
///10代表 成功11代表 失败
086
///00代表 下订单成功(仅对电话银行支付订单返回);01代表 下订单失败(仅对电话银行支付订单返回)
087
String payResult=(String)request.getParameter("payResult").trim();
088
089
//获取错误代码
090
///详细见文档错误代码列表
091
String errCode=(String)request.getParameter("errCode").trim();
092
093
//获取加密签名串
094
String signMsg=(String)request.getParameter("signMsg").trim();
095
096
//生成加密串。必须保持如下顺序。
097
String merchantSignMsgVal="";
098
merchantSignMsgVal=appendParam(merchantSignMsgVal,"merchantAcctId",merchantAcctId);
099
merchantSignMsgVal=appendParam(merchantSignMsgVal,"version",version);
100
merchantSignMsgVal=appendParam(merchantSignMsgVal,"language",language);
101
merchantSignMsgVal=appendParam(merchantSignMsgVal,"signType",signType);
102
merchantSignMsgVal=appendParam(merchantSignMsgVal,"payType",payType);
103
merchantSignMsgVal=appendParam(merchantSignMsgVal,"bankId",bankId);
104
merchantSignMsgVal=appendParam(merchantSignMsgVal,"orderId",orderId);
105
merchantSignMsgVal=appendParam(merchantSignMsgVal,"orderTime",orderTime);
106
merchantSignMsgVal=appendParam(merchantSignMsgVal,"orderAmount",orderAmount);
107
merchantSignMsgVal=appendParam(merchantSignMsgVal,"dealId",dealId);
108
merchantSignMsgVal=appendParam(merchantSignMsgVal,"bankDealId",bankDealId);
109
merchantSignMsgVal=appendParam(merchantSignMsgVal,"dealTime",dealTime);
110
merchantSignMsgVal=appendParam(merchantSignMsgVal,"payAmount",payAmount);
111
merchantSignMsgVal=appendParam(merchantSignMsgVal,"fee",fee);
112
merchantSignMsgVal=appendParam(merchantSignMsgVal,"ext1",ext1);
113
merchantSignMsgVal=appendParam(merchantSignMsgVal,"ext2",ext2);
114
merchantSignMsgVal=appendParam(merchantSignMsgVal,"payResult",payResult);
115
merchantSignMsgVal=appendParam(merchantSignMsgVal,"errCode",errCode);
116
merchantSignMsgVal=appendParam(merchantSignMsgVal,"key",key);
117
118
String merchantSignMsg=MD5Util.md5Hex(merchantSignMsgVal.getBytes("UTF-8")).toUpperCase();
119
//初始化结果及地址
120
int rtnOk=0;
121
String rtnUrl="";
122
123
//商家进行数据处理,并跳转回商家显示支付结果的页面
124
///首先进行签名字符串验证
125
if(signMsg.toUpperCase().equals(merchantSignMsg.toUpperCase())){
126
///接着进行支付结果判断
127
switch(Integer.parseInt(payResult)){
128
case 10:
129
// 商户网站逻辑处理,比方更新订单支付状态为成功
130
// 特别注意:只有signMsg.toUpperCase().equals(merchantSignMsg.toUpperCase()),且payResult=10,才表示支付成功
131
//报告给快钱处理结果,并提供将要重定向的地址。
132
rtnOk=1;
133
rtnUrl="http://www.yoursite.com/show.jsp?msg=success!";
134
break;
135
default:
136
rtnOk=1;
137
rtnUrl="http://www.yoursite.com/show.jsp?msg=false!";
138
break;
139
}
140
}else{
141
rtnOk=1;
142
rtnUrl="http://www.yoursite.com/show.jsp?msg=error!";
143
}
144
145
%>
146
<%!
147
//功能函数。将变量值不为空的参数组成字符串
148
public String appendParam(String returnStr,String paramId,String paramValue) {
149
if(!returnStr.equals("")) {
150
if(!paramValue.equals(""))
151
{
152
returnStr=returnStr+"&"+paramId+"="+paramValue;
153
}
154
} else {
155
if(!paramValue.equals(""))
156
{
157
returnStr=paramId+"="+paramValue;
158
}
159
}
160
return returnStr;
161
}
162
//功能函数。将变量值不为空的参数组成字符串。结束
163
//以下报告给快钱处理结果,并提供将要重定向的地址
164
%>
165
<result><%=rtnOk %></result><redirecturl><%=rtnUrl %></redirecturl>
上壹页的代码是receive.jsp,它是快钱完成它的任务之后返回我们的信息接收页面,返回时会携带所有我们刚才提交的参数以及完成支付时用到的壹些信息,如交易号、银行标识号、商户号、支付成功或者失败时的标识码等。这个页面有壹个特别的地方在于它底部的那个字符串,通过与快钱技术部门沟通之后得知,它是用于再壹次发送到快钱时必须的内容,用于告诉快钱本次提交是成功还是失败,其中的参数rtnOk是状态标识码,rtnUrl则是快钱系统回调我们的应用时要用到的请求地址,这个地址必须是公网地址,也就是说,它必须能够通过公共网络被快钱访问到,不可以是局域网地址如http://127.0.0.1:8080/之类,而应该是类似于http://www.google.com.sg/这种。
在这个页面的请求发送之后,接下来就是我们自己的应用的页面了,快钱也提供了壹个简单的样例页面来展示它,内容如下:
01
<%@page contentType="text/html; charset=UTF-8" language="java"%>
02
<%
03
/*
04
* @Description: 快钱人民币支付网关接口范例
05
* @Copyright (c) 上海快钱信息服务有限公司
06
* @version 2.0
07
*/
08
09
/*
10
在本文件中,商家应从数据库中,查询到订单的状态信息以及订单的处理结果。给出支付人响应的提示。
11
本范例采用最简单的模式,直接从receive页面获取支付状态提示给用户。
12
*/
13
String orderId=(String)request.getParameter("orderId").trim();
14
String orderAmount=(String)request.getParameter("orderAmount").trim();
15
String msg=(String)request.getParameter("msg").trim();
16
%>
17
<!doctype html public "-//w3c//dtd html 4.0 transitional//en" >
18
<html>
19
<head>
20
<title>快钱支付结果</title>
21
<meta http-equiv="content-type" content="text/html; charset=UTF-8" >
22
</head>
23
<body>
24
<div align="center">
25
<table width="259" border="0" cellpadding="1" cellspacing="1" bgcolor="#CCCCCC" >
26
<tr bgcolor="#FFFFFF">
27
<td width="80">支付方式:</td>
28
<td >快钱[99bill]</td>
29
</tr>
30
<tr bgcolor="#FFFFFF">
31
<td >订单编号:</td>
32
<td ><%=orderId %></td>
33
</tr>
34
<tr bgcolor="#FFFFFF">
35
<td>订单金额:</td>
36
<td><%=(orderAmount)+"分" %></td>
37
</tr>
38
<tr bgcolor="#FFFFFF">
39
<td>支付结果:</td>
40
<td><%=msg %></td>
41
</tr>
42
<tr>
43
<td></td>
44
<td></td>
45
</tr>
46
</table>
47
</div>
48
</body>
49
</html>
上面这个页面中的内容,其实我们可以随便的自定义,这里只是提供个样例,没有什么特别的内容,照着做就行了。
发表评论
-
Eclipse常用快捷键 10个最有用的快捷键
2017-10-12 16:46 548Eclipse中10个最有用的快捷键组合 一个E ... -
redis boundValueOps 方法操作解释
2017-06-21 17:17 25401.我的项目是maven项目,最近因为要用到,先引进下面两 ... -
centos 配置java JDK
2017-04-19 10:50 627因为使用的是Centos所以安装JDK,先从官网下载 h ... -
java 过滤器filter防sql注入
2016-07-14 11:03 990XSSFilter.java public void ... -
JSP 中使用常量防止硬编码
2016-06-11 11:55 2051jsp页面硬编码是个很头疼的问题,工作这么多年,看到 ... -
srpingMvc3.2 配置日期转换
2016-06-10 12:08 754配置spingMVC日期转换器,最近 ... -
eclipse,代码中有错误,项目中却不显示红叉
2016-06-04 23:27 14411.单个项目修改 项目上右键-->prope ... -
FORM表单防止重复提交的解决思路
2016-05-05 23:31 708现在分2种场景描述: ... -
Spring 面向切面编程(AOP)
2016-03-20 18:01 1027一、什么是 AOP 面向 ... -
java 导出Excel poi 实现
2016-01-29 09:22 7032今天又做了一个Excel 导出的功能 ... -
Spring MVC之@RequestBody, @ResponseBody 使用方法
2016-01-21 11:37 3840@RequestBody 作用: i) ... -
jsp 标签 TagSupport的学习
2015-11-11 00:52 709TagSupport的学习 ... -
quartz spring 实现动态定时任务
2015-08-02 17:59 5390在实际项目应用中经常会用到定时任务,可以通过q ... -
Maven 区分开发环境和测试环境 配置
2015-07-30 19:41 1447项目开发过程中,如果一个项目经常发布,那么 ... -
HttpClient 请求和接收
2015-06-29 09:45 523最近要写一个简单的数据请求接口,嫌麻烦就 ... -
网站设计之装饰模式,解决WAP公用部分重复代码
2015-03-30 15:15 892sitemesh应用Decorator模式,用fi ... -
Redis的Java客户端Jedis的八种调用方式(事务、管道、分布式…)介绍
2015-02-09 10:14 760redis是一个著名的key-val ... -
svn cleanup failed–previous operation has not finished; run cleanup if it was in
2014-10-28 15:24 652svn提交遇到恶心的问题,可能是因为上次cleanup中断后 ... -
schema 命名空间的理解
2014-10-06 10:47 753这几天重新温习了一下JAVA基础,发现对SC ... -
Callable与Future的介绍
2014-05-18 14:38 682Callable与 Future 两功能是Java在后 ...
相关推荐
为了更好地理解和应用Drools,你可以阅读“规则引擎Drools在J2EE项目开发中的应用.pdf”这份文档,它将详细讲解如何在实际项目中集成和使用Drools,包括规则的编写、引擎的配置、以及与J2EE环境的交互等内容。...
除了这些工具,还有一些通用的测试工具在J2EE项目中也很常见,例如SonarQube用于静态代码分析和质量控制,Jenkins用于持续集成和持续部署,确保每次代码更改后都能快速发现问题。 在实际测试过程中,还需要遵循敏捷...
这个“集成jetty的j2ee项目demo”提供了一个实用的示例,帮助开发者了解如何在项目中配置和运行Jetty来服务J2EE应用程序。Jetty 8.1.16是这个项目所使用的版本,它在当时是一个稳定且功能丰富的版本,支持Servlet ...
本教程将详细介绍如何在J2EE项目中集成Flex,使得前端展示更加动态和交互。 一、前期准备 1. 开发环境:Eclipse 3.2及以上版本,搭配Myeclipse 5.5。 2. 服务器:Tomcat 5.5版本。 3. Flex插件:从Adobe官方网站...
在J2EE项目中,Servlet常用于接收客户端请求,处理业务逻辑,并将结果返回给用户。 2. **JSP(JavaServer Pages)**:JSP是一种动态网页技术,允许开发者在HTML页面中嵌入Java代码。它简化了视图层的开发,使页面...
3. **EJB(Enterprise JavaBeans)**:EJB是J2EE中用于构建可复用的、分布式的、容器管理的组件。EJB有三种类型:会话bean(Session Beans)处理业务逻辑,实体bean(Entity Beans)代表持久化的业务对象,和消息...
在搭建好基础环境后,接下来是J2EE项目的工程建立。这通常涉及创建项目、定义模块结构、配置构建路径等步骤。良好的组织结构不仅有助于代码的管理和维护,还能提高团队协作效率。 #### 五、总结 本文详细介绍了...
7. **JNDI(Java Naming and Directory Interface)**:在J2EE中,JNDI用于查找和绑定资源,如数据源、邮件会话等。 8. **JDBC(Java Database Connectivity)**:用于与数据库进行交互,J2EE项目通常需要数据库...
1. **Servlet与JSP**:在J2EE中,Servlet是用于处理HTTP请求的核心组件,它接收客户端请求,处理数据,并返回响应。JSP(JavaServer Pages)则是一种视图技术,允许开发者将HTML和Java代码混合编写,便于快速生成...
这个压缩包“j2ee项目中所用到的包”包含了在J2EE项目中常用的框架和库,使得开发者能够快速搭建开发环境,减少寻找和配置组件的时间,提高开发效率。 首先,我们来看看其中的一个关键组件——Hibernate。Hibernate...
在J2EE中,我们可以通过Java Database Connectivity (JDBC) API 来建立数据库连接,或者利用Java EE提供的Contexts and Dependency Injection (CDI) 来管理数据库连接池,如Apache DBCP或HikariCP,以提高性能和资源...
在企业 OA 系统项目中,我们可以看到 JSP + Struts + Hibernate 技术栈的使用,以信息化为建设目标,建立学院的办公系统,通过信息化技术与学院管理有效结合,实现传统业务的信息化管理,提高办公效率与企业管理效益...
通过深入研究提供的J2EE项目案例源代码,初学者不仅可以学习到如何在实际项目中应用这些技术,还能了解如何组织代码结构,遵循设计模式,以及如何有效地利用J2EE提供的服务。这将有助于他们快速提升在企业级Java开发...
在J2EE中,JNDI常用来查找资源,如数据源、EJB引用或邮件会话。 6. **JTA(Java Transaction API)**:JTA是Java平台的一部分,用于处理分布式事务。它定义了应用程序如何与事务管理器交互,确保跨多个资源(如...
在"StarFlow 与J2EE项目的应用集成"中,主要关注的是如何将StarFlow的流程编排能力与J2EE的强大服务支持相结合。这可能涉及到以下几个方面: 1. **服务调用**:在StarFlow的工作流中,可能会调用J2EE应用中的服务,...
在J2EE项目开发中,理解并掌握J2EE架构及其相关技术是非常关键的。J2EE应用程序通常由四层结构组成,分别是客户层、应用层、表示逻辑层和企业信息系统层。客户层主要负责与用户的交互,应用层处理业务逻辑,表示逻辑...
Servlet是Java编写的小型服务器端程序,主要负责接收和响应HTTP请求,是J2EE中的核心组件。在本项目中,servlet扮演了控制器的角色,它接收来自JSP的请求,处理业务逻辑,然后可能调用DAO(数据访问对象)来与数据库...
本书汇集了大量企业级应用项目开发的经验,归纳了不同项目中使用的框架、模式、设计方法、开发方法,形成一个完整的技术体系和指导方法,以供用J2EE进行项目开发的初级人员和有一定经验的高级开发人员阅读。...