nix*_*shi 6 c# forms-authentication httpwebrequest
我是一个系统人员,目前正在做兼职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());
Run Code Online (Sandbox Code Playgroud)
我有用户名和密码,从浏览器使用时工作正常.请告诉我这是否是访问经过身份验证的页面的正确方法.
这取决于网站如何验证用户.如果他们使用基本身份验证或Windows身份验证,那么你可以在设置Credentials属性的的HttpWebRequest类的用户名/密码/域的信息,它应该工作.
但是,听起来您必须在网站上输入用户名/密码,这意味着您必须先登录该网站.查看主页面,这是我在<form>处理登录的元素中找到的内容:
<form name="formlogin" method="post" action="./defalogin.php" >
<input name="emtext" type="text" id="emtext" size="12">
<input name="pstext" type="password" id="pstext" size="12">
<input type="submit" name="Submit" value="Logn in"
onClick="return logincheck()" >
</form>
Run Code Online (Sandbox Code Playgroud)
我只包括相关部分.
鉴于此,您必须./defalogin.php首先使用HttpWebRequest和POST emtext和pstext值转到页面.此外,请确保将CookieContainer属性设置为实例CookieContainer.当对POST的调用返回时,很可能会填充一个cookie,您必须将其发送回该站点.只需继续CookieContainer在任何后续HttpWebRequest实例上设置属性,CookieContainer以确保传递cookie.
然后,您将转到链接中指示的页面.
值得关注的还有logincheckjavascript函数,但是看一下脚本来源,它没有什么值得注意的.
| 归档时间: |
|
| 查看次数: |
23817 次 |
| 最近记录: |