使用 HTMLcleaner 清理 HTML 输入
Clean up HTML input using HTMLcleaner
我正在使用 HTMLCleaner
库编写一个 java 项目并将输出保存为 XML 文件这是我编写的代码:
URL urlSB = new URL("http://www.groupon.com/browse/chicago?z=skip");
URLConnection urlConnection = urlSB.openConnection();
urlConnection.addRequestProperty("User-Agent", "google.com");
urlConnection.connect();
HtmlCleaner cleaner = new HtmlCleaner();
CleanerProperties props = cleaner.getProperties();
props.setNamespacesAware(false);
TagNode tagNodeRoot = cleaner.clean(urlConnection.getInputStream());
// serialize to xml file
new PrettyXmlSerializer(props).writeToFile(
tagNodeRoot , "cleaned.xml", "utf-8"
);
问题是 运行 项目后,cleaned.xml
文件为空。
问题是您尝试访问的页面被配置为重定向到 HTTPS。无论出于何种原因,这确实不起作用,因此输入流为空。如果您将 URL 更改为 HTTPS,它工作正常:
URL urlSB = new URL("https://www.groupon.com/browse/chicago?z=skip");
URLConnection urlConnection = urlSB.openConnection();
urlConnection.addRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.3; WOW64; rv:5.0) Gecko/20100101 Firefox/25.0");
urlConnection.connect();
HtmlCleaner cleaner = new HtmlCleaner();
CleanerProperties props = cleaner.getProperties();
props.setNamespacesAware(false);
TagNode tagNodeRoot = cleaner.clean(urlConnection.getInputStream());
new PrettyXmlSerializer(props).writeToFile(tagNodeRoot, "cleaned.xml", "utf-8");
我正在使用 HTMLCleaner
库编写一个 java 项目并将输出保存为 XML 文件这是我编写的代码:
URL urlSB = new URL("http://www.groupon.com/browse/chicago?z=skip");
URLConnection urlConnection = urlSB.openConnection();
urlConnection.addRequestProperty("User-Agent", "google.com");
urlConnection.connect();
HtmlCleaner cleaner = new HtmlCleaner();
CleanerProperties props = cleaner.getProperties();
props.setNamespacesAware(false);
TagNode tagNodeRoot = cleaner.clean(urlConnection.getInputStream());
// serialize to xml file
new PrettyXmlSerializer(props).writeToFile(
tagNodeRoot , "cleaned.xml", "utf-8"
);
问题是 运行 项目后,cleaned.xml
文件为空。
问题是您尝试访问的页面被配置为重定向到 HTTPS。无论出于何种原因,这确实不起作用,因此输入流为空。如果您将 URL 更改为 HTTPS,它工作正常:
URL urlSB = new URL("https://www.groupon.com/browse/chicago?z=skip");
URLConnection urlConnection = urlSB.openConnection();
urlConnection.addRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.3; WOW64; rv:5.0) Gecko/20100101 Firefox/25.0");
urlConnection.connect();
HtmlCleaner cleaner = new HtmlCleaner();
CleanerProperties props = cleaner.getProperties();
props.setNamespacesAware(false);
TagNode tagNodeRoot = cleaner.clean(urlConnection.getInputStream());
new PrettyXmlSerializer(props).writeToFile(tagNodeRoot, "cleaned.xml", "utf-8");