2012-04-25 89 views
0

我想从互联网网址下载csv文件。 我已经尝试了我可以在网上找到并且无法下载的所有代码。无法从java下载网络文件中的url

  URL google = new URL("myurl"); 
      ReadableByteChannel rbc = Channels.newChannel(google.openStream()); 
      FileOutputStream fos = new FileOutputStream("C://excelsheet.csv"); 
      fos.getChannel().transferFrom(rbc, 0, 1 << 24); 

此代码不能正常工作

我用这个功能,它不是工作压力太大。

public stacvoid saveUrl(String filename, String urlString) throws MalformedURLException, IOException 
    { 
     BufferedInputStream in = null; 
     FileOutputStream fout = null; 
     try 
     { 
       in = new BufferedInputStream(new URL(urlString).openStream()); 
       fout = new FileOutputStream(filename); 

       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(); 
     } 
    } 

我尝试了一个简单的输入流在我的网址,这不工作了。

  URL oracle = new URL("myurl"); 
      URLConnection yc = oracle.openConnection(); 

     BufferedReader br = new BufferedReader(new InputStreamReader(
              yc.getInputStream())); 

现在不是myurl,如果我输入任何其他url,bufferedreader确实会获取数据。 如果我在浏览器中输入myurl,我会弹出一个窗口来保存或下载csv文件。 所以问题不在于不正确的“myurl”

“myurl”上运行的servlet /代码是否有可能实际检查请求是否来自浏览器,然后才发送数据。

谢谢大家。使用httpclient,它适用于我。下载一个csv文件的代码,将其保存在本地,然后读取它并解析所有的令牌。

 HttpClient httpclient = new DefaultHttpClient(); 
     HttpGet httpget = new HttpGet("your url to download"); 
     HttpResponse response = httpclient.execute(httpget); 

      System.out.println(response.getProtocolVersion()); 
      System.out.println(response.getStatusLine().getStatusCode()); 
      System.out.println(response.getStatusLine().getReasonPhrase()); 
      System.out.println(response.getStatusLine().toString()); 
      HttpEntity entity = response.getEntity(); 
      if (entity != null) { 
       FileOutputStream fos = new java.io.FileOutputStream("C://excelsheet.csv"); 
       entity.writeTo(fos); 
       fos.close(); 
      } 

      //create BufferedReader to read csv file 
     BufferedReader br = new BufferedReader(new FileReader("C://excelsheet.csv")); 
     String strLine = ""; 
     StringTokenizer st = null; 
     int lineNumber = 0, tokenNumber = 0; 
     while((strLine = br.readLine()) != null) 
           { 
             lineNumber++; 

             //break comma separated line using "," 
             st = new StringTokenizer(strLine, ","); 

             while(st.hasMoreTokens()) 
             { 
               //display csv values 
               tokenNumber++; 
               System.out.println("Line # " + lineNumber + 
                   ", Token # " + tokenNumber 
                   + ", Token : "+ st.nextToken()); 
             } 

             //reset token number 
             tokenNumber = 0; 

           } 
     } 
     catch (Exception e) { 
      System.out.println("insdie the catch part"); 
      System.out.println(e.toString()); 
     } 
+0

如果您未登录到网站,您是否可以使用浏览器访问该文件? – 2012-04-25 19:28:21

+0

什么不适用'Channels',你会得到一个异常吗?您可能没有对C驱动器根目录的写权限。 – tenorsax 2012-04-25 19:35:54

+0

Meta建议:在你的问题中用每个出现的“不工作”替换为1.它在做什么和2.你期望它做什么。 – 2012-04-27 17:17:44

回答

0

您是否试过HttpClient lib? 我以前用它自动从网站下载一组考试。

+0

是使用浏览器,我可以在没有任何登录的情况下访问该文件,虽然它需要一些时间 – Rpant 2012-04-25 20:11:04

+0

是的,但是当它工作时,很好。我的应用程序下载考试是:[PCI下载](http://www.davidfeitosa.com/p/downloads.html)。不开心,我失去了源代码,但它仍然有效。 – 2012-04-25 20:18:36

+0

我试过Apache commons FileUtils.copyURLToFile(oracle,f);但是这不起作用 – Rpant 2012-04-25 21:28:15