我是一个系统人员,目前正在做兼职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());
解决方法
这取决于网站如何验证用户.如果他们使用基本身份验证或Windows身份验证,那么您可以将
HttpWebRequest
class的
Credentials
property设置为用户名/密码/域信息,它应该可以工作.
但是,听起来您必须在网站上输入用户名/密码,这意味着您必须先登录该网站.查看主页面,这是我在< 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>
我只包括相关部分.
鉴于此,您必须首先使用HttpWebRequest转到./defalogin.PHP页面,然后发送emtext和pstext值.此外,请确保将CookieContainer
property设置为CookieContainer
的实例.当对POST的调用返回时,很可能会填充一个cookie,您必须将其发送回该站点.只需继续将CookieContainer属性设置在任何后续的HttpWebRequest实例上,以确保Cookie被传递到该CookieContainer.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。