昨天作一个爬网站的程序使用Jsoup.connect(String url) 时报java.nio.charset.IllegalCharsetNameException:utf-8错误 html
错误内容是: java
java.nio.charset.IllegalCharsetNameException: UTF-8
at java.nio.charset.Charset.checkName(Charset.java:284)
at java.nio.charset.Charset.lookup2(Charset.java:458)
at java.nio.charset.Charset.lookup(Charset.java:437)
at java.nio.charset.Charset.isSupported(Charset.java:476)
at org.jsoup.helper.DataUtil.getCharsetFromContentType(DataUtil.java:132)
at org.jsoup.helper.HttpConnection$Response.execute(HttpConnection.java:448)
at org.jsoup.helper.HttpConnection$Response.execute(HttpConnection.java:393)
at org.jsoup.helper.HttpConnection.execute(HttpConnection.java:159)
at org.jsoup.helper.HttpConnection.post(HttpConnection.java:154)
at domain.Working.main(Working.java:18)
对于这个错误一开始莫名奇妙,一开始觉得是SDK编码问题就去改Edit编码 Eclipse默认编码反正各类编码都试了一遍,结果错误一点都没变;后来请教大神,神说:加个请求头进去。因而在请求里添加了个相似这样的玩意
Accept-Language:
zh-CN,zh;q=0.8
,结果仍是同样,过程各类复杂下午折腾了近三个小时,结果我去查api
发现这样一个方法
parse(InputStream in, String charsetName, String baseUri) api
修改代码 dom
url = new URL(htmlUrl);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
InputStream is = connection.getInputStream();
doc=Jsoup.parse(is,"utf-8",htmlUrl);
问题解决了- -... post