none
webBrowser如何下载图片 RRS feed

  • 问题

  •  HttpWebResponse HttpResponse = (HttpWebResponse)HttpReques.GetResponse();
                HttpResponse.Cookies = myCookieContainer.GetCookies(HttpReques.RequestUri);
                Stream myResponseStream = HttpResponse.GetResponseStream();
                StreamReader myStreamReader = new StreamReader(myResponseStream, Encoding.GetEncoding("gb2312"));
                string outdata = myStreamReader.ReadToEnd();
                myStreamReader.Close();
                myResponseStream.Close(); webBrowser1.DocumentText = outdata;
    webBrowser1中不显示图片,如何让其自动去下载图片显示呢?请教大家
    2010年4月4日 3:00

答案

  • /// <summary>   
    /// 获取WebBrowser指定的图片   
    /// </summary>   
    /// <param name="webBrowser">需要获取图片的WebBrowser</param>   
    /// <param name="imgID">指定的图片的id(优先查找指定id)</param>   
    /// <param name="imgSrc">指定的图片的src,支持模糊查询</param>   
    /// <param name="imgAlt">指定的图片的src, 支持模糊查询</param>   
    /// <returns></returns>   
    public static Image GetRegCodePic(ref WebBrowser webBrowser, String imgID, String imgSrc, String imgAlt)   
    {   
           
        HTMLDocument doc = (HTMLDocument)webBrowser.Document.DomDocument;   
        HTMLBody body = (HTMLBody)doc.body;   
        IHTMLControlRange rang = (IHTMLControlRange)body.createControlRange();   
        IHTMLControlElement img;   
      
        // 如果没有图片的ID,通过Src或Alt中的关键字来取   
        if (imgID.Length == 0)   
        {   
            Int32 ImgNum = GetPicIndex(ref webBrowser, ref imgSrc, ref imgAlt);   
      
            if (ImgNum == -1)   
                return null;   
      
            img = (IHTMLControlElement)webBrowser.Document.Images[ImgNum].DomElement;   
        }   
        else  
            img = (IHTMLControlElement)webBrowser.Document.All[imgID].DomElement;   
      
        rang.add(img);   
        rang.execCommand("Copy", false, null);   
        Image regImg = Clipboard.GetImage();   
        Clipboard.Clear();   
        return regImg;   
    }   
      
    /// <summary>   
    /// 获取WebBrowser指定图片的索引   
    /// </summary>   
    /// <param name="webBrowser">指定的WebBrowser</param>   
    /// <param name="imgSrc">指定的图片src,支持模糊查询</param>   
    /// <param name="imgAlt">指定的图片alt,支持模糊查询</param>   
    /// <returns></returns>   
    public static Int32 GetPicIndex(ref WebBrowser webBrowser, ref String imgSrc, ref String imgAlt)   
    {   
        IHTMLImgElement img;   
      
        // 获取所有的Image元素   
        for (Int32 i = 0; i < webBrowser.Document.Images.Count; i++)   
        {   
            img = (IHTMLImgElement)webBrowser.Document.Images[i].DomElement;   
      
            if (imgAlt.Length == 0)   
            {   
                if (img.src.IndexOf(imgSrc) >= 0)   
                    return i;   
            }   
            else  
            {   
                if (imgSrc.Length == 0)   
                {   
                    // 当imgSrc为空时,只匹配imgAlt   
                    if (img.alt.IndexOf(imgAlt) >= 0)   
                        return i;   
                }   
                else  
                {   
                    // 当imgSrc不为空时,匹配imgAlt和imgSrc任意一个   
                    if (img.alt.IndexOf(imgAlt) >= 0 || img.src.IndexOf(imgSrc) >= 0)   
                        return i;   
                }   
            }   
        }   
        return -1;   
    }  
    
    
    

    努力+方法=成功
    • 已标记为答案 xuzhiqiang 2010年4月7日 0:33
    2010年4月6日 2:24

全部回复

  • 顶上去

    2010年4月4日 5:19
  • 继续顶上去

    2010年4月5日 11:34
  • Hi,

    你需要在outdata做parsing。把所以图片的链接都加上完整的URL,如http://www.microsoft.com/logo.jpg

    2010年4月5日 11:48
  • 您好~~请问如何加?代码如何写?

    2010年4月5日 12:02
  • Hi,

    蛮多东西需要判断。你需要找<img 然后去改src的值。 如<img src='logo.jpg' /src>改成<img src='http://www.microsoft.com/logo.jpg' /src>.....

    但想问一下,为何你不让webBrowser直接去下载文件(那它就会自动下载图片了)?

    2010年4月5日 12:40
  • /// <summary>   
    /// 获取WebBrowser指定的图片   
    /// </summary>   
    /// <param name="webBrowser">需要获取图片的WebBrowser</param>   
    /// <param name="imgID">指定的图片的id(优先查找指定id)</param>   
    /// <param name="imgSrc">指定的图片的src,支持模糊查询</param>   
    /// <param name="imgAlt">指定的图片的src, 支持模糊查询</param>   
    /// <returns></returns>   
    public static Image GetRegCodePic(ref WebBrowser webBrowser, String imgID, String imgSrc, String imgAlt)   
    {   
           
        HTMLDocument doc = (HTMLDocument)webBrowser.Document.DomDocument;   
        HTMLBody body = (HTMLBody)doc.body;   
        IHTMLControlRange rang = (IHTMLControlRange)body.createControlRange();   
        IHTMLControlElement img;   
      
        // 如果没有图片的ID,通过Src或Alt中的关键字来取   
        if (imgID.Length == 0)   
        {   
            Int32 ImgNum = GetPicIndex(ref webBrowser, ref imgSrc, ref imgAlt);   
      
            if (ImgNum == -1)   
                return null;   
      
            img = (IHTMLControlElement)webBrowser.Document.Images[ImgNum].DomElement;   
        }   
        else  
            img = (IHTMLControlElement)webBrowser.Document.All[imgID].DomElement;   
      
        rang.add(img);   
        rang.execCommand("Copy", false, null);   
        Image regImg = Clipboard.GetImage();   
        Clipboard.Clear();   
        return regImg;   
    }   
      
    /// <summary>   
    /// 获取WebBrowser指定图片的索引   
    /// </summary>   
    /// <param name="webBrowser">指定的WebBrowser</param>   
    /// <param name="imgSrc">指定的图片src,支持模糊查询</param>   
    /// <param name="imgAlt">指定的图片alt,支持模糊查询</param>   
    /// <returns></returns>   
    public static Int32 GetPicIndex(ref WebBrowser webBrowser, ref String imgSrc, ref String imgAlt)   
    {   
        IHTMLImgElement img;   
      
        // 获取所有的Image元素   
        for (Int32 i = 0; i < webBrowser.Document.Images.Count; i++)   
        {   
            img = (IHTMLImgElement)webBrowser.Document.Images[i].DomElement;   
      
            if (imgAlt.Length == 0)   
            {   
                if (img.src.IndexOf(imgSrc) >= 0)   
                    return i;   
            }   
            else  
            {   
                if (imgSrc.Length == 0)   
                {   
                    // 当imgSrc为空时,只匹配imgAlt   
                    if (img.alt.IndexOf(imgAlt) >= 0)   
                        return i;   
                }   
                else  
                {   
                    // 当imgSrc不为空时,匹配imgAlt和imgSrc任意一个   
                    if (img.alt.IndexOf(imgAlt) >= 0 || img.src.IndexOf(imgSrc) >= 0)   
                        return i;   
                }   
            }   
        }   
        return -1;   
    }  
    
    
    

    努力+方法=成功
    • 已标记为答案 xuzhiqiang 2010年4月7日 0:33
    2010年4月6日 2:24
  • 因為是HttpResponse返回給我的数据。。。我没法让控件自动下载
    2010年4月6日 4:01
  • Hi,

    没想过可以用HtmlDocument,但开心的方法蛮方便的。

    2010年4月6日 4:31
  • 爲什麽用Replace無法將XXX/XX.JPG替換成WWW.XXX.COM/XXX/XXJPG呢?這個我觉得有点奇怪,为什么不处理文本的方式无法实现???

    2010年4月6日 4:54
  •  太感谢了。

    指明了我一条光明之路。

    execCommand

    2010年10月2日 23:06