日期:2014-05-17  浏览次数:20682 次

网银接口怎么知道数据是否是银联发送过来的
这是银联提供的接口,如何判断这些参数是否为银联发送过来的?如果MD5码被人截获了再发送相应请求过来就不安全了
<%@page contentType="text/html; charset=gb2312" language="java"%>
<jsp:useBean id="MD5" scope="request" class="beartool.MD5"/>
<%
//**************************************** // MD5密钥要跟订单提交页相同,如Send.asp里的 key = "test" ,修改""号内 test 为您的密钥
// 如果您还没有设置MD5密钥请登陆我们为您提供商户后台,地址:https://merchant3.chinabank.com.cn/
String key = "test"; // 登陆后在上面的导航栏里可能找到“B2C”,在二级导航栏里有“MD5密钥设置”
// 建议您设置一个16位以上的密钥或更高,密钥最多64位,但设置16位已经足够了
//****************************************

//获取参数
   String v_oid = request.getParameter("v_oid"); // 订单号
 String v_pmode = request.getParameter("v_pmode"); // 支付方式中文说明,如"中行长城信用卡"
   String v_pstatus = request.getParameter("v_pstatus"); // 支付结果,20支付完成;30支付失败;
   String v_pstring = request.getParameter("v_pstring"); // 对支付结果的说明,成功时(v_pstatus=20)为"支付成功",支付失败时(v_pstatus=30)为"支付失败"
String v_amount = request.getParameter("v_amount"); // 订单实际支付金额
 String v_moneytype = request.getParameter("v_moneytype"); // 币种
String v_md5str = request.getParameter("v_md5str"); // MD5校验码
 String remark1 = request.getParameter("remark1"); // 备注1
 String remark2 = request.getParameter("remark2"); // 备注2


String text = v_oid+v_pstatus+v_amount+v_moneytype+key;
String v_md5text = MD5.getMD5ofStr(text).toUpperCase();

if (v_md5str.equals(v_md5text))
{
if ("30".equals(v_pstatus))
{
out.print("支付失败");
}else if ("20".equals(v_pstatus)){
// 支付成功,商户 根据自己业务做相应逻辑处理
//此处加入商户系统的逻辑处理(例如判断金额,判断支付状态,更新订单状态等等)......
%>
<TABLE width=500 border=0 align="center" cellPadding=0 cellSpacing=0>
  <TBODY>
<TR> 
  <TD vAlign=top align=middle> <div align="left"><B><FONT style="FONT-SIZE:14px">MD5校验码:<%=v_md5str%></FONT></B></div></TD>
</TR>
<TR> 
  <TD vAlign=top align=middle> <div align="left"><B><FONT style="FONT-SIZE: 14px">订单号:<%=v_oid%></FONT></B></div></TD>
</TR>
<TR> 
  <TD vAlign=top align=middle> <div align="left"><B><FONT style="FONT-SIZE: 14px">支付卡种:<%=v_pmode%></FONT></B></div></TD>
</TR>
<TR> 
  <TD vAlign=top align=middle> <div align="left"><B><FONT style="FONT-SIZE: 14px">支付结果:<%=v_pstring%></FONT></B></div></TD>
</TR>
<TR> 
  <TD vAlign=top align=middle> <div align="left"><B><FONT style="FONT-SIZE: 14px">支付金额:<%=v_amount%></FONT></B></div></TD>
</TR>
<TR> 
  <TD vAlign=top align=middle> <div align="left"><B><FONT style="FONT-SIZE: 14px">支付币种:<%=v_moneytype%></FONT></B></div></TD>
</TR>
  </TBODY>
</TABLE>
<%