最近自己捉摸着写了一个获取必应每日一图的网址几行代码,很简陋,但是很有用。这也是我第一次写blog,如有错误还请帮我纠正,谢谢。
需要的第三方库,dom4j来解析xml文件。这个包可以自己去网上搜。这里就不重复累赘。
下面这个网址是从bing抓包出来的,打开返回是一个XML文件,主要bing用来记录图片信息的。我们主要就是从这个xml文件中获取图片的后半截地址,而它的前半截地址是:http://s.cn.bing.net/是固定不变的。
打开http://cn.bing.com/HPImageArchive.aspx?format=xml&idx=0&n=1就是这个xml文件,不信你试。
打开的xml文件内容如下:
<images>
<image>
<startdate>20171223</startdate>
<fullstartdate>201712230800</fullstartdate>
<enddate>20171224</enddate>
<url><!--我们主要获取的是这里虚线上的.jpg,就是这里bing图片每日自动更新的网址-->
/az/hprichbg/rb/NorthPole_ZH-CN14730815128_1366x768.jpg
-------------------------------------------------------
</url>
<urlBase>/az/hprichbg/rb/NorthPole_ZH-CN14730815128</urlBase>
<copyright>北极 (© Sue Flood/Getty Images)</copyright>
<copyrightlink>
http://www.bing.com/search?q=%E5%8C%97%E6%9E%81&form=hpcapt&mkt=zh-cn
</copyrightlink>
<drk>1</drk>
<top>1</top>
<bot>1</bot>
<hotspots/>
</image>
<tooltips>
<loadMessage>
<message>正在加载...</message>
</loadMessage>
<previousImage>
<text>上一个图像</text>
</previousImage>
<nextImage>
<text>下一个图像</text>
</nextImage>
<play>
<text>播放视频</text>
</play>
<pause>
<text>暂停视频</text>
</pause>
</tooltips>
</images>
当把后半截网址:/az/hprichbg/rb/NorthPole_ZH-CN14730815128_1366x768.jpg 获取出来再加上
前半截网址http://s.cn.bing.net/。
完整网址就是:http://s.cn.bing.net/az/hprichbg/rb/NorthPole_ZH-CN14730815128_1366x768.jpg
当然要把前半截末尾.net/中的”/” 或 后半截的首段/az中的”/”去掉之一。
主要代码
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Iterator;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
public class GetEverydayBingAdress {
public static String getBingEveryDayPicAdress() {
return getImageAdress();
}
private static String getImageAdress() {
String str = "http://s.cn.bing.net";
String url = "http://cn.bing.com/HPImageArchive.aspx?format=xml&idx=0&n=1";
String xml = null;
try {
xml = getXmlStringFormBingWithHttp(url);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
String reStr = null;
try {
//用dom4j来解析xml文件
Document doc = DocumentHelper.parseText(xml);
Element rootElement = doc.getRootElement();
Iterator iterator2 = rootElement.elementIterator("image");
while(iterator2.hasNext()) {
Element element2 =(Element) iterator2.next();
reStr = element2.elementText("url");
}
return str.trim()+reStr.trim();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
private static String getXmlStringFormBingWithHttp(String urlStr) throws Exception {
URL url = new URL(urlStr);
HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
httpURLConnection.connect();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(httpURLConnection.getInputStream()));
String line;
StringBuffer stringBuffer = new StringBuffer();
while ((line = bufferedReader.readLine())!= null) {
stringBuffer.append(line);
}
bufferedReader.close();
httpURLConnection.disconnect();
return stringBuffer.toString();
}
}
写一个测试类来试试:
public class Test {
public static void main(String[] args) {
System.out.println(GetEachDayBingPicURL.getBingEveryDayPicAdress());
}
}
打印的结果为:
(bingPIC地址)http://s.cn.bing.net/az/hprichbg/rb/NorthPole_ZH-CN14730815128_1366x768.jpg
这里就成功了!