我正在尝试使用以下代码使用DOM解析器来解析Java中的XML文件:
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
[...]
File file = new File("some/path");
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document document = db.parse(file);
最后一行(在调用.parse()函数时)给出了错误:
java.io.IOException: Server returned HTTP response code: 403 for URL: http://testng.org/testng-1.0.dtd
我如何着手修复这个错误?
发布于 2018-05-31 08:42:00
它正在尝试加载testng-1.0.dtd
,即您的XML文档的DTD。
您可以从任何地方下载它,并通过提供到DocumentBuilder.setEntityResolver()
的EntityResolver
来配置DocumentBuilder
以在那里查找它。
或者修复你的HTTP代理。文档本身不受授权保护,这就是403的意思。
发布于 2018-05-31 07:36:14
您是否正在尝试访问代码中的某个URL。HTTP 403状态码表示访问被禁止,当未设置用户代理头时通常会发生这种情况。您可以按如下方式设置:
URLConnection connection = new URL("https://www.google.com/search?q=" + query).openConnection();
connection.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.95 Safari/537.11");
请参考this了解更多详细信息。
https://stackoverflow.com/questions/50614655
复制相似问题