C#.NET 伪造 referer 提交数据

以下代码是对限制站外提交数据的网站,进行伪造referer以达到提交数据的目的。

 

 

 1 private string SendRequest(string account, string cardNumber, string cardPass)
 2     {
 3         string targetUrl = https://xxx.com/;//要提交数据的目标网站

            //提交的数据
 4         string postData = string.Format("ursName={0}&userName2={0}&cardNo={1}&cardPass={2}", account, cardNumber, cardPass);
 5 
 6         HttpWebRequest request = (HttpWebRequest)WebRequest.Create(targetUrl);
 7         request.Method = "POST";
 8         request.Referer = http://www.xxx.com/jsp/xxx.jsp;
 9         byte[] bytes = Encoding.UTF8.GetBytes(postData);
10         request.ContentType = "application/x-www-form-urlencoded";
11         request.ContentLength = bytes.Length;
12         Stream requestStream = request.GetRequestStream();
13         requestStream.Write(bytes, 0, bytes.Length);
14 
15         HttpWebResponse response = (HttpWebResponse)request.GetResponse();
16         StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.Default);
17         string responseText = reader.ReadToEnd();
18 
19         string res = "成功!";
20         if (responseText.Contains("errorID"))
21         {
22             string errorDetailPage = new System.Text.RegularExpressions.Regex(@"URL=(?<url>.*?)"">",
23                 System.Text.RegularExpressions.RegexOptions.IgnoreCase | System.Text.RegularExpressions.RegexOptions.Multiline
24                 ).Match(responseText).Groups["url"].Value;
25 
26             HttpWebRequest requestErrorInfo = (HttpWebRequest)WebRequest.Create(errorDetailPage);
27             requestErrorInfo.Method = "GET";
28             requestErrorInfo.Proxy = request.Proxy;
29             HttpWebResponse responseErrorInfo = (HttpWebResponse)requestErrorInfo.GetResponse();
30             StreamReader readerErrorInfo = new StreamReader(responseErrorInfo.GetResponseStream(), Encoding.Default);
31             string responseTextErrorInfo = readerErrorInfo.ReadToEnd();
32             string errorDetailMessage = new System.Text.RegularExpressions.Regex(@"<h3>(?<info>.*?)<.*?</h3>",
33                 System.Text.RegularExpressions.RegexOptions.IgnoreCase | System.Text.RegularExpressions.RegexOptions.Multiline
34                 ).Match(responseTextErrorInfo).Groups["info"].Value.Replace("&nbsp;""");
35 
36 
37             res = string.Format(@"失败!<br />错误信息:{0}<br /><a href=""{1}"" target=""_blank"">查看错误详情</a>", errorDetailMessage, errorDetailPage);
38         }
39 
40         return res;
41     }

进行测试

 

protected   void  Button1_Click( object  sender, EventArgs e)
    {
        
string  text  =  SendRequest( " zhangbao0712@163.com " " 2312312312321 " " 2312312312321 " );
        Response.Write(text);
    }

在这里要感谢SEVEN,Gabry两位的帮助。

 

转载于:https://www.cnblogs.com/NickOne/archive/2009/06/11/1501098.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值