HttpWebRequest和C#中的表单身份validation

我是一个系统人员,目前正在做一个兼职的Web开发项目,所以我很新。 我正在尝试为www.portapower.com编写一个http客户端。

对于在网站上发布的某些项目,如果它们符合特定要求,它将打印一条消息。

在尝试访问此页面时:

http://www.portapower.com/getbainfo.php?fclasscode=1&code=CB1831B.40H&fbrand=QUNFUg==

该网站将我重定向到默认注册页面:

http://www.portapower.com/defaregit.php

这是我编码的片段:

CookieContainer myContainer = new CookieContainer(); HttpWebRequest request = (HttpWebRequest) WebRequest.Create("http://www.portapower.com/" + urlpart); request.Credentials = new NetworkCredential("****", "******"); request.CookieContainer = myContainer; request.PreAuthenticate = true; request.Method = "POST"; HttpWebResponse response = (HttpWebResponse) request.GetResponse(); Console.WriteLine(response.StatusCode); Stream resStream = response.GetResponseStream(); Console.WriteLine(resStream.ToString()); 

我有用户名和密码,从浏览器使用时工作正常。 请告诉我这是否是访问经过身份validation的页面的正确方法。

这取决于网站如何validation用户身份。 如果他们使用基本身份validation或Windows身份validation,那么您可以将HttpWebRequest类的Credentials属性设置为用户名/密码/域信息,它应该可以工作。

但是,听起来您必须在网站上输入用户名/密码,这意味着您必须先登录该网站。 查看主页面,这是我在处理登录的

元素中找到的内容:

 

我只包括相关部分。

鉴于此,您必须首先使用HttpWebRequest转到./defalogin.php页面,然后POST emtextpstext值。 此外,请确保将CookieContainer属性设置为CookieContainer的实例。 当对POST的调用返回时,很可能会填充一个cookie,您必须将其发送回该站点。 只需继续将CookieContainer属性设置在任何后续的HttpWebRequest实例上,以确保cookie被传递给该CookieContainer

然后,您将转到链接中指示的页面。

值得关注的还有logincheck javascript函数,但是看一下脚本源代码,它没有什么值得注意的。

您传递的凭据用于Windows身份validation。 您需要使用模拟提交表单的数据提交post数据,然后限制响应中设置的会话cookie,并使用该cookie以备将来请求

看一下这个代码的答案:

使用HttpWebRequest登录页面

你不能这样做; 您传递的凭据可以与基本身份validation方案一起使用(即,在浏览器中,您会弹出一个用户名/密码对话框。)您必须模拟数据在该表单中的条目并捕获登录cookie并使用它。

NetworkCredential类实际上用于控制常规Windows凭据(NTLM,Kerberos等)。

该站点是在Apache上运行的PHP站点,因此我认为他们不使用NTLM或kerberos。

你想要做的是将一些FORM字段发布到网站,然后保留你回来的cookie。 确保在后续请求中将cookie推回到站点,以便它知道您已经登录。