C# 前台和后台POST提交信息的实现方法
一、系统A(官网)与系统B(第三方支付平台)数据交换的方式
1.1 页面浏览器方式:系统A以构造Form表单的方式,通过系统A客户的浏览器重定向到系统B(向系统B发送请求),B系统完成交易后,将交易结果送给A系统。eg:A系统用户完成注册后在B系统开户
1.2 后台数据流方式:后台数据流方式分为表单和Json格式返回两种数据格式,开户和交易接口都是使用表单,查询类接口使用JSON;A系统服务器,构造Http协议报文,直接访问B系统,将Http报文发送到B系统,并获取返回的满足Http报文协议的字符流。在数据流的方式下,A系统以表单的方式将数据发送到B系统,B系统收到后进行相应的处理。
现已第三方提供的Pos机自动代扣的接口为例,分别讲解前台和回台数据交换:
二、页面浏览器方式
2.1 以Form表单的形式提交
A、 transfer.aspx页面,body内容如下,其中注意body标签的onload事件,form的Action在后台指定;transfer只是中转页面,以供在系统中其他页面只需抛数据到transfer页面,而不关注与第三方的交互,与第三方交互主要由transfer页面完成
<body onload="sub();">
<form id="formMain" runat="server">
<input type="hidden" name="Version" value="<%=Version%>" />
<input type="hidden" name="CmdId" value="<%=CmdId%>" />
<input type="hidden" name="MerCustId" value="<%=MerCustId%>" />
<input type="hidden" name="UsrCustId" value="<%=UsrCustId%>" />
<input type="hidden" name="OpenAcctId" value="<%=OpenAcctId%>" />
<input type="hidden" name="TransAmt" value="<%=TransAmt%>" />
<input type="hidden" name="OrdId" value="<%=OrdId%>" />
<input type="hidden" name="OrdDate" value="<%=OrdDate%>" />
<input type="hidden" name="CheckDate" value="<%=CheckDate%>" />
<input type="hidden" name="RetUrl" value="<%=RetUrl%>" />
<input type="hidden" name="BgRetUrl" value="<%=BgRetUrl%>" />
<input type="hidden" name="MerPriv" value="<%=MerPriv%>" />
<input type="hidden" name="ChkValue" value="<%=ChkValue%>" />
</form>
<script type="text/javascript">
function sub() {
document.getElementById("formMain").submit();
}
</script>
</body>
B、 transfer.aspx.cs内容如下:
public partial class Interface_POSWithoutCard_Transfer
{
public readonly string PnrUrl = ChinaPnrInterfaces.GetConfigValue("pnrurl");
public readonly string Version = ChinaPnrInterfaces.GetConfigValue("pnrversion");
public readonly string CmdId = "PosWhSave"; //函数名称
public string MerCustId = string.Empty; //商户ID
public string UsrCustId = string.Empty; //用户ID(PNRID)
public string OpenAcctId = string.Empty; //开户银行账号
public string TransAmt = string.Empty; //交易金额
public string OrdId = string.Empty; //订单号
public string OrdDate = string.Empty; //订单日期
public string CheckDate = string.Empty; //校验日期
public string RetUrl = string.Empty; //页面返回
public string BgRetUrl = string.Empty; //商户后台应答地址
public string MerPriv = string.Empty; //商户私有域
public string ChkValue = string.Empty;protected void Page_Load(object sender, EventArgs e)
{
MerCustId = CurMerCustId;
UsrCustId = DESEncrypt.Decrypt(Request["UsrCustId"]);
OpenAcctId = DESEncrypt.Decrypt(Request["OpenAcctId"]);
TransAmt = DESEncrypt.Decrypt(Request["TransAmt"]);
CheckDate = DESEncrypt.Decrypt(Request["CheckDate"]);OrdId = bll.GetNextOrdId();
OrdDate = DateTime.Now.ToString("yyyyMMdd");//CurWebUrl
RetUrl = string.Format("{0}/Interface/POSWithoutCard_Return.aspx?action=frontend&ordid={1}&transamt={2}", CurWebUrl, DESEncrypt.Encrypt(OrdId), DESEncrypt.Encrypt(TransAmt));//第三方支付平台根据此字段获取前后回应地址,注意,由第三方处理完后回传的这部分数据其他内容需要通过Request.Form["Name"]获取,但对于地址后面的action,ordid和transamt需要使用get方式获取; 公路养护车,双排座自卸车,散装饲料运输车厂家价格(http://www.glyhche.com/)
BgRetUrl = string.Format("{0}/Interface/POSWithoutCard_Return.aspx?action=backend&ordid={1}&transamt={2}", CurWebUrl, DESEncrypt.Encrypt(OrdId), DESEncrypt.Encrypt(TransAmt));//后台预防返回地址
formMain.Action = PnrUrl;//地址为第三方提供的接收页面if (bll.CreateLog(new dw_poswksave_log_model()
{
OrdId = OrdId,
PnrId = UsrCustId,
BankId = OpenAcctId,
TransAmt = float.Parse(TransAmt),
OrdDate = OrdDate,
CheckDate = CheckDate
}))
{
ChkValue = ChinaPnrInterfaces.SignChkValue(Version + CmdId + MerCustId + UsrCustId
+ OpenAcctId + TransAmt + OrdId + OrdDate + CheckDate + RetUrl + BgRetUrl + MerPriv);
}Response.ContentEncoding = Encoding.GetEncoding("gb2312");
}protected string DateToString(string strDate)
{
DateTime date;
if (!DateTime.TryParse(strDate, out date))
date = DateTime.Now;return date.ToString("yyyyMMdd");
}protected string MoneyToString(string strMoney)
{
if (string.IsNullOrEmpty(strMoney))
strMoney = "0";return float.Parse(strMoney).ToString("F2");
}
}C、Return.aspx 页面用于接收第三方支付平台回传的结果
<body>
<% if (ShowUserTip) { %>
<div class="err">
<div class="info">
<div>
响应信息
</div>
<div>
<div>代码:<%=RespHFCode%></div>
<div>描述:<%=RespHFDesc%></div>
</div>
<div><%=RespHFCode.Equals(HFOK) ? "" : "请重新提交!"%></div>
</div>
<div class="bot">
<input type="button" value="关闭此窗口" onclick="window.close();" />
</div>
</div>
<% } %>
</body>D、Return.aspx.cs文件如下:
public readonly string HFOK = "000";
public string RespHFString = string.Empty;
public string RespHFCode = string.Empty;
public string RespHFDesc = string.Empty;
public string OrdId = string.Empty;
public string TransAmt = string.Empty;
public bool ShowUserTip = false;protected void Page_Load(object sender, EventArgs e)
{
string action = Request["action"];//对应transfer传递参数时放在地址后的参数
if (!string.IsNullOrEmpty(action))
{
RespHFString = "RECV_ORD_ID_" + Request.Form["TrxId"];//在页面显示
RespHFCode = Request.Form["RespCode"];
RespHFDesc = Request.Form["RespDesc"];
OrdId = DESEncrypt.Decrypt(Request["ordid"]);
TransAmt = DESEncrypt.Decrypt(Request["transamt"]);switch (action)
{
case "frontend":
ShowUserTip = true;//前台回复,将结果显示在页面上
UpdatePosLog();
break;
case "backend"://后台响应直接存储就可以了,但需要判断前台是否已经处理,否则会造成数据重复处理
string checkValue = Request.Form["CmdId"].Trim()
+ Request.Form["RespCode"].Trim()
+ Request.Form["MerCustId"].Trim()
+ Request.Form["UsrCustId"].Trim()
+ Request.Form["OpenAcctId"].Trim()
+ Request.Form["TransAmt"].Trim()
+ Request.Form["OrdId"].Trim()
+ Request.Form["OrdDate"].Trim()
+ Request.Form["CheckDate"].Trim()
+ Request.Form["TrxId"].Trim()
+ Request.Form["RetUrl"].Trim()
+ Request.Form["BgRetUrl"].Trim()
+ Request.Form["MerPriv"].Trim();if (ChinaPnrInterfaces.DecChkValue(checkValue, Request.Form["ChkValue"]).Equals("0"))
{
UpdatePosLog();
}
break;
}
}
}
三、后台数据流方式
3.1、使用HttpWebRequest对象,Post数据:
string TransferUrl = string.Empty;
string postData = string.Empty;
string userPnrID = dr["pnrid"].ToString();
string bankID = dr["BankId"].ToString();
string checkDate = dr["CheckDate"].ToString();
string repayment_account = Decimal.Round(Convert.ToDecimal(TransNullOrEmpty(dr["repayment_account"].ToString())), 2).ToString();
TransferUrl = string.Format("{0}/Interface/POSWithoutCard_Transfer.aspx", strWebSiteUrl);//需要请求的页面
postData = string.Format("UsrCustId={0}&OpenAcctId={1}&TransAmt={2}&CheckDate={3}",
DESEncrypt.Encrypt(userPnrID), DESEncrypt.Encrypt(bankID), DESEncrypt.Encrypt(repayment_account), DESEncrypt.Encrypt(checkDate));//传递的参数
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(TransferUrl);//后台请求页面
string s = postData;
Encoding encoding = Encoding.GetEncoding("GB2312");//GB2312,注意页面的编码,否则会出现乱码
byte[] requestBytes = encoding.GetBytes(postData);
req.Method = "POST";
req.ContentType = "application/x-www-form-urlencoded";
req.ContentLength = requestBytes.Length;
Stream requestStream = req.GetRequestStream();
requestStream.Write(requestBytes, 0, requestBytes.Length);
requestStream.Close();
HttpWebResponse res = (HttpWebResponse)req.GetResponse();
StreamReader sr = new StreamReader(res.GetResponseStream(), System.Text.Encoding.GetEncoding("GB2312"));
string backstr = sr.ReadToEnd();//可以读取到从页面返回的结果,以数据流的形式。
// Response.Write(backstr);
sr.Close();
res.Close();
3.2、使用WebClient对象:
string postData = string.Format("UsrCustId={0}&OpenAcctId={1}&TransAmt={2}&CheckDate={3}",
DESEncrypt.Encrypt(userPnrID), DESEncrypt.Encrypt(bankID), DESEncrypt.Encrypt(repayment_account), DESEncrypt.Encrypt(checkDate));//这里即为传递的参数,可以用工具抓包分析,也可以自己分析,主要是form里面每一个name都要加进来byte[] postData = Encoding.UTF8.GetBytes(postString);//编码,尤其是汉字,事先要看下抓取网页的编码方式
string TransferUrl= string.Format("{0}/Interface/POSWithoutCard_Transfer.aspx", strWebSiteUrl);//需要请求的页面
WebClient webClient = new WebClient();
webClient.Headers.Add("Content-Type", "application/x-www-form-urlencoded");//采取POST方式必须加的header,如果改为GET方式的话就去掉这句话即可
byte[] responseData = webClient.UploadData(TransferUrlurl, "POST", postData);//得到返回字符流
string srcString = Encoding.UTF8.GetString(responseData);//解码
3.3、WebBrowser对象(没用过,暂时不讨论,具体可参考http://www.cnblogs.com/peterzb/archive/2009/07/12/1521787.html)
转自:http://blog.itpub.net/28699126/viewspace-1127499/
C# 前台和后台POST提交信息的实现方法的更多相关文章
- ASP.NET前台html页面AJAX提交数据后台ashx页面接收数据
摘要:最近在写网站,好不容易弄好了需求又变了,没错企业的门户网站硬要弄成后台管理系统一样,没办法作为小工的我只能默默的改.前台HTML页面需要提交数据到后台处理,又不能用form表单,于是乎研究了1天 ...
- Yii创建前台和后台登录表单和通过扩展 CWebUser 增加信息到 Yii::app()->user
我参考了这篇文章来构建项目的前台和后台的目录结构.感谢Andy的这篇文章.按照所有的步骤,您将有单独的前台和后台面板,如: http://localhost/index.php // 前台 http: ...
- 【总结-前台发送后台接收表单】MVC提交表单的四种方式
https://www.cnblogs.com/chenwolong/p/Form.html#commentform 后台控制器接收前台表单参数三种方法: 一.普通参数 HTML标签name 和参数名 ...
- 由ASP.NET所谓前台调用后台、后台调用前台想到HTTP——理论篇
工作两年多了,我会经常尝试给公司小伙伴儿们解决一些问题,几个月下来我发现初入公司的小朋友最爱问的问题就三个 1. 我想前台调用后台的XXX方法怎么弄啊? 2. 我想后台调用前台的XXX JavaScr ...
- js前台与后台数据交互-后台调前台(后台调用、注册客户端脚本)
转自:http://blog.csdn.net/wang379275614/article/details/17049721 客户端脚本一般都在前台,这里讲的是(1)在后台调用前台定义的脚本(2)在后 ...
- js前台与后台数据交互
客户端脚本一般都在前台,这里讲的是(1)在后台调用前台定义的脚本(2)在后台如何注册客户端脚本 用途 何时使用服务器代码向页中添加客户端脚本: u 当客户端脚本的内容依赖于直到运行时才可用的信息时 u ...
- ASP.NET中使用JSON方便实现前台与后台的数据交换
ASP.NET中使用JSON方便实现前台与后台的数据交换 发表于2014/9/13 6:47:08 8652人阅读 分类: ASP.NET Jquery extjs 一.前台向后台请求数据 在页面加 ...
- 由ASP.NET所谓前台调用后台、后台调用前台想到HTTP——实践篇(二)
在由ASP.NET所谓前台调用后台.后台调用前台想到HTTP——理论篇中描述了一下ASP.NET新手的三个问题及相关的HTTP协议内容,在由ASP.NET所谓前台调用后台.后台调用前台想到HTTP—— ...
- asp.net 前台绑定后台变量方法总结:<%= %> 和<%# %>的区别
经常会碰到在前台代码中要使用(或绑定)后台代码中变量值的问题.一般有<%= str%>和<%# str %>两种方式,这里简单总结一下.如有错误或异议之处,敬请各位指教. 一 ...
随机推荐
- PHP手册在7.1迁移页面给出了替代方案,就是用OpenSSL取代MCrypt.
/** * [AesSecurity aes加密,支持PHP7.1] */ class AesSecurity { /** * [encrypt aes加密] * @p ...
- 剑指offer 剪绳子
题目描述 给你一根长度为n的绳子,请把绳子剪成m段(m.n都是整数,n>1并且m>1),每段绳子的长度记为k[0],k[1],...,k[m].请问k[0]xk[1]x...xk[m]可能 ...
- Git生成公钥.pub 及秘钥 命令
Git生成公钥.pub 及秘钥 命令 ssh-keygen -t rsa -C "******@qq.com" 将.pub公钥里面内容复制到github或者将这文件交给git管理员 ...
- webpack4导入jQuery的新方案
本文的目的 拒绝全局导入jQuery!! 拒绝script导入jQuery!! 找到一种只在当前js组件中引入jQuery,并且使用webpack切割打包的方案! 测试环境 以下测试在webpack3 ...
- 为什么现在UML很少用了
新霸哥发现UML在面向对象的设计中的需求,相关行为.一些体系结构的实现提供了一套综合完整的表示法,但是由于使用的人比较少,初学者不容易快速入门,所以就导致了UML不是那么的受欢迎. UML在开发中有什 ...
- laravel 的lnmp 的配置
装了lnmp后,一般用 lnmp vhost add 添加网站 一般 只用重写和ssl功能 再发laravel官方的配置 server { listen 80; server_name example ...
- JDK12的安装搭建
JDK12的安装搭建 一.JDK下载 1.JDK官网下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk12-down ...
- 如何修改wordpress博客默认管理员用户名称
打开你的WordPress数据库,点击结构后面的SQL,输入下面一段命令执行 UPDATE wp_users SET user_login = '新用户名', user_nicename = '新用户 ...
- aes前台加密后台解密
aes加密npm地址:https://www.npmjs.com/package/crypto-js aes加密git地址/下载: https://github.com/brix/crypto-js ...
- 【洛谷P2894】Hotel 线段树+二分查询
题目大意:给定一个长度为 N 的序列,每个点有两种状态 1/0,表示占有和空闲,现支持 first-fit 查询是否有一段连续的长度为 X 的空闲子序列和区间赋值操作. 题解:get到了线段树新技能. ...