zoukankan      html  css  js  c++  java
  • 通过网银在线进行在线支付

    总结一下 在我们一个项目中使用的通过网银在线进行在线支付的步骤:


    下面我用一个asp.net 的例子做一下说明:

    一共建立2个页面 Send.aspx (发送交易数据给网银在线) 和 Receive.aspx (接收网银在线的交易结果)

    一. 建立页面 Send.aspx (作用是收集支付的数据 并将信息通过页面Post的方式传递给网银在线)

    1. 网页代码

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Send.aspx.cs" Inherits="Send" %>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

    <html xmlns="http://www.w3.org/1999/xhtml" >
    <head runat="server">
        <title>订单提交</title>
    </head>
    <body >
    <body onLoad="javascript:document.E_FORM.submit()" >
         <form    action="https://pay3.chinabank.com.cn/PayGate"  method="post" name="E_FORM">
       
          <input type="hidden" name="v_md5info"    value="<%=v_md5info%>" size="100" />
          <input type="hidden" name="v_mid"        value="<%=v_mid%>" />
          <input type="hidden" name="v_oid"        value="<%=v_oid%>" />
          <input type="hidden" name="v_amount"     value="<%=v_amount%>" />
          <input type="hidden" name="v_moneytype"  value="<%=v_moneytype%>" />
          <input type="hidden" name="v_url"        value="<%=v_url%>" />


    <!--以下几项项为网上支付完成后,随支付反馈信息一同传给信息接收页-->
       
      <input type="hidden"  name="remark1" value="<%=remark1%>" />
      <input type="hidden"  name="remark2" value="<%=remark2%>" />
       
      <!--以下几项只是用来记录客户信息,可以不用,不影响支付 -->

     <input type="hidden"  name="v_rcvname"      value="<%=v_rcvname%>" />
     <input type="hidden"  name="v_rcvaddr"      value="<%=v_rcvaddr%>" />
     <input type="hidden"  name="v_rcvtel"       value="<%=v_rcvtel%>" />
     <input type="hidden"  name="v_rcvpost"      value="<%=v_rcvpost%>" />
     <input type="hidden"  name="v_rcvemail"     value="<%=v_rcvemail%>" />
     <input type="hidden"  name="v_rcvmobile"    value="<%=v_rcvmobile%>" />

     <input type="hidden"  name="v_ordername"    value="<%=v_ordername%>" />
     <input type="hidden"  name="v_orderaddr"    value="<%=v_orderaddr%>" />
     <input type="hidden"  name="v_ordertel"     value="<%=v_ordertel%>" />
     <input type="hidden"  name="v_orderpost"    value="<%=v_orderpost%>" />
     <input type="hidden"  name="v_orderemail"   value="<%=v_orderemail%>" />
     <input type="hidden"  name="v_ordermobile"  value="<%=v_ordermobile%>" />
        </form>
    </body>
    </html>

        注解:《1》 onLoad="javascript:document.E_FORM.submit()" 
                这句话的意思是 页面加载完成(变量已经赋值) 立刻提交
             《2》 <form    action="https://pay3.chinabank.com.cn/PayGate"  method="post" name="E_FORM">
                 这句话的意思是 提交到网银在线的接口网页(Post方式)
             《3》protected string v_url;   // 返回页地址
                  这个变量的意思: 您可以 指定对 在线支付 结果 的接收页面 (例如:支付成功)
                  网银在线会将反馈结果通过网页Post的方式传给您的网页

    2. 后台代码

    using System;
    using System.Data;
    using System.Configuration;
    using System.Collections;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;
    using HGZP.ERP.BusinessLogic;
    using HGZP.ERP.PublicUnit;

    public partial class Send : System.Web.UI.Page
    {
        //必要的交易信息
        protected string v_amount;       // 订单金额
        protected string v_moneytype;    // 币种
        protected string v_md5info;      // 对拼凑串MD5私钥加密后的值
        protected string v_mid;   // 商户号
        protected string v_url;   // 返回页地址
        protected string v_oid;   // 推荐订单号构成格式为 年月日-商户号-小时分钟秒

        //收货信息
        protected string v_rcvname;      // 收货人
        protected string v_rcvaddr;      // 收货地址
        protected string v_rcvtel;       // 收货人电话
        protected string v_rcvpost;      // 收货人邮编
        protected string v_rcvemail;     // 收货人邮件
        protected string v_rcvmobile;    // 收货人手机号

        //订货人信息
        protected string v_ordername;    // 订货人姓名
        protected string v_orderaddr;    // 订货人地址
        protected string v_ordertel;     // 订货人电话
        protected string v_orderpost;    // 订货人邮编
        protected string v_orderemail;   // 订货人邮件
        protected string v_ordermobile;  // 订货人手机号
        protected string pmode_id;
        //两个备注
        protected string remark1;
        protected string remark2;

        protected void Page_Load(object sender, EventArgs e)
        {

            //商户号,这里为测试商户号1001,替换为自己的商户号即可
            v_mid = GlobalFunctionDataBaseMutuality.GetItemParameter(GlobalFunctionDataBaseMutuality.ProgramParameter.OnLinemid);
            if (v_mid.Trim() == "Error")
            {           
                Response.Write("<script language=javascript>window.open('ErrorMessage.aspx');</script>");
                return;            
            }
            //v_mid = "21669597";
            //商户自定义返回接收支付结果的页面 
            v_url = GlobalFunctionDataBaseMutuality.GetItemParameter(GlobalFunctionDataBaseMutuality.ProgramParameter.OnLineurl);
            if (v_url.Trim() == "Error")
            {
                Response.Write("<script language=javascript>window.open('ErrorMessage.aspx');</script>");
                return;
            }
            //v_url = "http://192.168.200.42/ebank/chinabank/Receive.aspx";
            //MD5密钥要跟订单提交页相同,如Send.asp里的 key = "test" ,修改""号内 test 为您的密钥
            //如果您还没有设置MD5密钥请登陆我们为您提供商户后台,地址:https://merchant3.chinabank.com.cn/
            //登陆后在上面的导航栏里可能找到“B2C”,在二级导航栏里有“MD5密钥设置”
            //建议您设置一个16位以上的密钥或更高,密钥最多64位,但设置16位已经足够了
            string key = GlobalFunctionDataBaseMutuality.GetItemParameter(GlobalFunctionDataBaseMutuality.ProgramParameter.OnLinekey);
            if (key.Trim() == "Error")
            {
                Response.Write("<script language=javascript>window.open('ErrorMessage.aspx');</script>");
                return;
            }       
            //string key = "1H6G0Z0P83D70A1E8AF60F49C143A7B95";

            v_oid = Context.Items["v_oid"].ToString();//定单号

            //if (v_oid == null || v_oid.Equals(""))
            //{
            //    DateTime dt = DateTime.Now;
            //    string v_ymd = dt.ToString("yyyyMMdd"); // yyyyMMdd
            //    string timeStr = dt.ToString("HHmmss"); // HHmmss
            //    v_oid = v_ymd + v_mid + timeStr;
            //}

            v_amount = Context.Items["v_amount"].ToString();//支付金额
            v_moneytype = "CNY";//支付类型
            string text = v_amount + v_moneytype + v_oid + v_mid + v_url + key; // 拼凑加密串
            v_md5info = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(text, "md5").ToUpper();
            remark1 = Context.Items["customId"].ToString(); ;

           
        }
    }

      注解: 代码里面主要作用是给变量赋值  有一些我们项目的逻辑 我没有删除
            您在使用的时候 参照赋值 即可

    二. 建立页面 Receive.aspx

      1. 页面

        <%@ Page Language="C#" MasterPageFile="~/MasterPage.master" AutoEventWireup="true"
        CodeFile="Receive.aspx.cs" Inherits="Receive" Title="Untitled Page" %>

    <asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
        <div style="text-align: center">
            <asp:Literal ID="Literal1" runat="server"></asp:Literal>
          
        </div>
    </asp:Content>


         注解:占位符Literal1 的作用是 显示后台代码的结果

    2. 后台代码

      using System;
    using System.Data;
    using System.Configuration;
    using System.Collections;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;
    using System.Text;

    using HGZP.ERP.PublicUnit;
    using HGZP.ERP.BusinessLogic;
    using HGZP.ERP.DataAccess;
    using System.IO;

    public partial class Receive : System.Web.UI.Page
    {
        protected string v_oid;  // 订单号
        protected string v_pstatus; // 支付状态码 20(支付成功,对使用实时银行卡进行扣款的订单);30(支付失败,对使用实时银行卡进行扣款的订单);
        protected string v_pstring; //支付状态描述
        protected string v_pmode; //支付银行
        protected string v_amount; //支付金额
        protected string v_moneytype;//币种  
        protected string remark1; // 备注1
        protected string remark2; // 备注1
        protected string v_md5str;
        protected string status_msg;
        protected string str;
        StringBuilder sbSql = new StringBuilder();
        StringBuilder sbHtml = new StringBuilder();

        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {

                StreamReader sr = new StreamReader(Request.InputStream, Encoding.GetEncoding(936));
                string query = sr.ReadToEnd();
                System.Collections.Specialized.NameValueCollection reqResult = HttpUtility.ParseQueryString(query, Encoding.GetEncoding(936));

                //MD5密钥要跟订单提交页相同,如Send.asp里的 key = "test" ,修改""号内 test 为您的密钥
                //如果您还没有设置MD5密钥请登陆我们为您提供商户后台,地址:https://merchant3.chinabank.com.cn/
                //登陆后在上面的导航栏里可能找到“B2C”,在二级导航栏里有“MD5密钥设置”
                //建议您设置一个16位以上的密钥或更高,密钥最多64位,但设置16位已经足够了
                string key = GlobalFunctionDataBaseMutuality.GetItemParameter(GlobalFunctionDataBaseMutuality.ProgramParameter.OnLinekey);
                if (key.Trim() == "Error")
                {
                    Response.Write("<script language=javascript>window.open('ErrorMessage.aspx');</script>");
                    return;
                }
                //string key = "1H6G0Z0P83D70A1E8AF60F49C143A7B95";
                v_oid = reqResult["v_oid"];
                v_pstatus = reqResult["v_pstatus"];
                v_pstring = reqResult["v_pstring"];
                v_pmode = reqResult["v_pmode"];
                v_md5str = reqResult["v_md5str"];
                v_amount = reqResult["v_amount"];
                v_moneytype = reqResult["v_moneytype"];
                remark1 = reqResult["remark1"];//客户ID
                //remark2 = Request["remark2"];

                string str = v_oid + v_pstatus + v_amount + v_moneytype + key;
                str = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "md5").ToUpper();
                if (str == v_md5str)
                {
                    if (v_pstatus.Equals("20"))
                    {
                        //支付成功
                        sbSql.Append("Update tBaseOperator set nAccountBalance = nAccountBalance + " + decimal.Parse(v_amount) + " where sGuidID = '" + remark1 + "'");

                        sbSql.Append(@"Insert into tWorkDownloadCharge (sGuidID,sGuidIDUser,sPaymentMode,sGuidIDOperator,nMoney,dChargeDatetime,dCreateDatetime,sComment,sVersion) values
                                    ( '" + v_oid.ToString() + "', '" + remark1 + "', '现金', '" + remark1 + "', " + v_amount + ", '" + GlobalFunctionDataBaseMutuality.GetServerDateTime() + "', '" + GlobalFunctionDataBaseMutuality.GetServerDateTime() + "', '', '" + DateTime.Now + "' )");
                        if (!DataOperation.UpdateDataBySql(sbSql.ToString()))
                        {
                            Public.globalErrorString = DataOperation.globalErrorString;
                            Response.Write("<script language=javascript>window.open('ErrorMessage.aspx');</script>"); //打开新窗口
                            return;
                        }
                        status_msg = "支付成功!";
                        //Response.Write("<script language=javascript>alert('支付成功!');window.location.href='ShoppingCart.aspx'</script>");

                        sbHtml.Append("<table class=\"border\" cellspacing=\"1\" border=\"0\" style=\"border-style: Solid; 50%;text-align: center;\">");
                        sbHtml.Append("<tr><td valign=\"top\" align=\"middle\"><div align=\"left\"><b>订单号:" + v_oid + "</b></div></td></tr>");
                        sbHtml.Append("<tr><td valign=\"top\" align=\"middle\"><div align=\"left\"><b>支付银行:" + v_pmode + "</b></div></td></tr>");
                        sbHtml.Append("<tr><td valign=\"top\" align=\"middle\"><div align=\"left\"><b>支付结果:" + v_pstring + "</b></div></td></tr>");
                        sbHtml.Append("<tr><td valign=\"top\" align=\"middle\"><div align=\"left\"><b>支付金额:" + v_amount + "</b></div></td></tr>");
                        sbHtml.Append("<tr><td valign=\"top\" align=\"middle\"><div align=\"left\"><b>支付币种:" + v_moneytype + "</b></div></td></tr>");
                        sbHtml.Append("<tr style=\"display:none\"><td valign=\"top\" align=\"middle\"><div align=\"left\"><b>备注1:" + remark1 + "</b></div></td></tr>");
                        sbHtml.Append("<tr><td valign=\"top\" align=\"center\">" + status_msg + "<a onclick=\"window.opener=null;window.open('','_self');window.open('ShoppingCart.aspx','');window.close();\" style=\"cursor: hand\">返回</a></td></tr></table>");
                        Literal1.Text = sbHtml.ToString();
                    }
                }
                else
                {
                    status_msg = "校验失败,数据可疑";
                    sbHtml.Append("<table class=\"border\" cellspacing=\"1\" border=\"0\" style=\"border-style: Solid; 50%;text-align: center;\">");
                    sbHtml.Append("<tr><td valign=\"top\" align=\"center\" style=\"180px;\">" + status_msg + "<a onclick=\"window.opener=null;window.open('','_self');window.open('ShoppingCart.aspx','');window.close();\" style=\"cursor: hand\">返回</a></td></tr></table>");
                    Literal1.Text = sbHtml.ToString();
                }
            }
        }
      
    }

                  注解: 代码里面有一些和我们项目相关的表的操作  请自行删除

  • 相关阅读:
    170619、springboot编程之HelloWorld
    170616、解决 java.lang.IllegalArgumentException: No converter found for return value of type: class java.util.ArrayList
    170615、spring不同数据库数据源动态切换
    pytest文档10-命令行传参
    pytest文档9-参数化parametrize
    pytest文档8-html报告报错截图+失败重跑
    pytest文档7-pytest-html生成html报告
    定位对应关系
    ADB 无线连接
    command failed shell "ps 'uiautomator'"的解决方式
  • 原文地址:https://www.cnblogs.com/zhwl/p/1965613.html
Copyright © 2011-2022 走看看