• C#实现POST提交方式


    网页自动登录和提交POST信息的核心就是分析网页的源代码(HTML),在C#中,可以用来提取网页HTML的组件比较多,常用的用WebBrowser、WebClient、HttpWebRequest这三个。

    以下就分别用这三种方法来实现:
    1、WebBrowser是个"迷你"浏览器,其特点是Post时不用关心Cookie、内置JS等问题
    WebBrowser是VS2005新提供的组件(其实就是封装了IE接口),实现POST功能一般在webBrowser的DocumentCompleted中分析HtmlDocument 来实现,代码如下:

            

       
    View Code

    2、WebClient封装了HTTP的一些类,操作简单,相较于webBrowser,特点是可以自设代理,缺点是对COOKIE的控制
    WebClient的运行全在后台,并且提供了异步操作的能力,这样很方便并发多个任务,然后等待结果的返回,再逐个处理。多任务异步调用的代码如下:

       

    View Code

    3、HttpWebRequest较为低层,能实现的功能较多,Cookie操作也很简单:


          

    View Code

    HttpWebRequest 实现, 做了一个简单测试程序,在最近的项目中写了一个调用第三方接口短信收发功能,也就是通过网站向手机发送信功能,同时在第三方文档资料只给出了URL、参数列表及返回值.通过C#的HttpWebRequest类很容易实现这个功能。

    这个程序刚好用上,用来当做测试工具使用。

    这个测试程序,做成了动态参数形式,即可以根据不同的服务方设置不同的URL、参数。但前提都得支持通过POST方式服务。

    当然也有一些服务接口是通过构造XML文件,然后提交XML文件服务形式。

    要加上支持构造XML格式也很简单,形式大同小异,这里暂不讨论,通过构建XML文件然后POST文章请看此处post提交XML

    添加参数及对应值,敏感信息可以通过加密后再发送。加密算法是调用系统MD5算法。目前来说MD5算法还是比较安全的。

    例如:

    第三方提供的服务接口类似: http://www.cnblogs.com/service?user=xxx&pass=yyy 

    要实现调用服务提交post数据(注:这里并不是真正服务接口,只是举个说明).

    1.在测试工具只要填写

    服务URL:   http://www.cnblogs.com/serveice

    2.设置参数列表

    参数名称:user,值:xxx;

    参数名称:pass,值:yyy;

    ......

    3.提交就行了,可能不同的服务返回信息不同,这里只做了返回字符串形式。

    用HttpWebRequest实现起来还是比较简单方便,这种方式在webservice中广泛应用。

    另外在自动登录中可以实现类似做法,但是验证码目前暂没有解决,但也可以通过httpWebRequest去请求实现。

    请求获取图片方法:

    HttpWebResponse resp;
            HttpWebRequest req 
    = (HttpWebRequest)HttpWebRequest.Create("http://www.csdn.net/Images/logo_csdn.gif");
            req.Timeout 
    = 150000;
            resp 
    = (HttpWebResponse)req.GetResponse();
            System.Drawing.Image img;
            img 
    = new System.Drawing.Bitmap(resp.GetResponseStream());

    HttpWebRequest自动登录网站并获取网站内容(不包含验证码的网站)
    可以使用 Visual Sniffer(百度搜索) 来捕捉提交的数据信息:
    1. 访问你需要站外提交的页面,比如 CSDN 登陆页 http://www.csdn.net/member/UserLogin.aspx
    2. 填写好需要的资料,比如用户名和密码,
    3. 打开 Visual Sniffer, 点“开始拦截”
    4. 在访问的页面中提交。
    5. 等提交成功之后,在 Visual Sniffer 中“停止拦截”
    6. 在 Visual Sniffer 的左侧栏的加号中依次点开,

    右边是它拦截到的内容:


    POST http://www.csdn.net/member/UserLogin.aspx HTTP/1.0
    Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, application/x-shockwave-flash, **
    Referer: http://www.csdn.net/member/UserLogin.aspx
    Accept-Language: zh-cn
    UA-CPU: x86
    Pragma: no-cache
    User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; SV1; .NET CLR 1.1.4322; InfoPath.1)
    Host: www.csdn.net

    http://www.divmy.com/
  • 相关阅读:
    asp.net 验证输入有效性
    优化SQL SERVER访问性能
    with nocheck ; nocheck
    VB SStab设置当前页
    相互关联的子查询
    mybatis 批量查询参数语句
    转载 mysql函数大全
    Tchar.h 中的一般文本映射
    字节序的概念、判断、及转换
    Windows风格与C/C++风格:UNICODE VS _UNICODE 与 TEXT() VS _T()
  • 原文地址:https://www.cnblogs.com/ArRan/p/2767931.html
Copyright © 2020-2023  润新知