问题

我试图找到Java相当于Groovy的:

String content = "http://www.google.com".toURL().getText();

我想将URL中的内容读入字符串。我不想用缓冲的流和循环来污染我的代码以完成这么简单的任务。我查看了apache的HttpClient,但我也没有看到一行或两行实现。


#1 热门回答(104 赞)

既然原来的答案被接受了一段时间,那么有一个更好的方法:

String out = new Scanner(new URL("http://www.google.com").openStream(), "UTF-8").useDelimiter("\\A").next();

如果你想要一个稍微全面的实现,这不是一行,请执行以下操作:

public static String readStringFromURL(String requestURL) throws IOException
{
    try (Scanner scanner = new Scanner(new URL(requestURL).openStream(),
            StandardCharsets.UTF_8.toString()))
    {
        scanner.useDelimiter("\\A");
        return scanner.hasNext() ? scanner.next() : "";
    }
}

#2 热门回答(91 赞)

这个答案指的是Java的旧版本。你可能想看看ccleve的答案。

以下是执行此操作的传统方法:

import java.net.*;
import java.io.*;

public class URLConnectionReader {
    public static String getText(String url) throws Exception {
        URL website = new URL(url);
        URLConnection connection = website.openConnection();
        BufferedReader in = new BufferedReader(
                                new InputStreamReader(
                                    connection.getInputStream()));

        StringBuilder response = new StringBuilder();
        String inputLine;

        while ((inputLine = in.readLine()) != null) 
            response.append(inputLine);

        in.close();

        return response.toString();
    }

    public static void main(String[] args) throws Exception {
        String content = URLConnectionReader.getText(args[0]);
        System.out.println(content);
    }
}

正如@extraneon所建议的,ioutils允许你以非常雄辩的方式执行此操作,这仍然是Java精神:

InputStream in = new URL( "http://jakarta.apache.org" ).openStream();

 try {
   System.out.println( IOUtils.toString( in ) );
 } finally {
   IOUtils.closeQuietly(in);
 }

#3 热门回答(63 赞)

或者只使用IOUtils.toString(URL url),或者也接受编码参数的变体。


原文链接