如何下载放置在图像按钮中的文件 - HTMLUNIT

时间:2015-10-08 16:47:56

标签: javascript java download jsoup htmlunit

点击图片按钮下载文件。

我有link

我一直在尝试下载文件(两个保存图标图像按钮)。当我点击图像时,它会提示下载zip文件。

这是按钮的页面 VIEWSOURCE 中显示的标记

<input type="image" name="ctl00$m$g_b265ad4d_cd49_41f3_a9f2_0090f0aa5504$ctl00$gvBidSetsFile$ctl02$ImageButton1" id="ctl00_m_g_b265ad4d_cd49_41f3_a9f2_0090f0aa5504_ctl00_gvBidSetsFile_ctl02_ImageButton1" title="Download" src="/SiteAssets/images/saveitem.gif" style="height:18px;width:18px;border-width:0px;">

    WebClient client = new WebClient(BrowserVersion.FIREFOX_38);
    HtmlPage homePage = null;
   // Document doc = null;  
    String base="https://bidset.nycsca.org/SitePages/Obtain%20Solicitation.aspx?SN=16-15323D-1&ReqType=Solicitation&IsDlg=1&IsDlg=1";

    try {
        client.getOptions().setUseInsecureSSL(true);
    client.setAjaxController(new NicelyResynchronizingAjaxController());
    client.waitForBackgroundJavaScript(1000);
    client.waitForBackgroundJavaScriptStartingBefore(1000);
    client.getOptions().setThrowExceptionOnFailingStatusCode(false);
    client.getOptions().setThrowExceptionOnScriptError(false);

    homePage = client.getPage(base);
    synchronized (homePage) {
        homePage.wait(5000);
    }
    System.out.println("file Page : " + homePage.getUrl());
   // Document dd = Jsoup.parse(homePage.asXml());
    HtmlInput docs= homePage.getFirstByXPath("//input[@id='ctl00_m_g_b265ad4d_cd49_41f3_a9f2_0090f0aa5504_ctl00_gvBidSetsFile_ctl02_ImageButton1']");

        homePage = bidDocs.click();

问题: 当我得到

HtmlInput docs =  homePage.getFirstByXPath
 ("//input[@id='ctl00_m_g_b265ad4d_cd49_41f3_a9f2_0090f0aa5504_ctl00_gvBidSetsFile_ctl02_ImageButton1']");

执行是否可以,

homePage = bidDocs.click();

点击保存图标下载文件。

  1. 我很困惑如何在HTMLUNIT的帮助下下载此文件。 我想在本地驱动器中下载文件。

  2. 是否可以获取主页的url链接(homePage = bidDocs.click();)

  3. 即。商店链接,String docurl=get homePage's link . ????

    1. 如果我能获得链接,我可以使用BufferedStream下载文件。

          File file = new File("C:/TRY/file/abc.zip");
          BufferedInputStream in = null;
          FileOutputStream fout = null;
          try {
              in = new BufferedInputStream(new URL(docUrl).openStream());
              fout = new FileOutputStream(file);
      
              final byte data[] = new byte[1024];
              int count;
              while ((count = in.read(data, 0, 1024)) != -1) {
                  fout.write(data, 0, count);
              }
          } finally {
              if (in != null) {
                  in.close();
              }
              if (fout != null) {
                  fout.close();
              }
          }
      
    2. 我在这里使用HTMLUNIT因为它是javascriptiframe网站。 我很感谢你的帮助。

      非常感谢你。

1 个答案:

答案 0 :(得分:1)

选择文件标签

 HtmlInput download = pageCheck.getByXPath("//input[@title='Download']");

和流媒体

 download.click().getWebResponse().getContentAsStream()