获取必应每日一图网址

最近自己捉摸着写了一个获取必应每日一图的网址几行代码,很简陋,但是很有用。这也是我第一次写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>20171223startdate>
<fullstartdate>201712230800fullstartdate>
<enddate>20171224enddate>
<url>

/az/hprichbg/rb/NorthPole_ZH-CN14730815128_1366x768.jpg
-------------------------------------------------------

url>
<urlBase>/az/hprichbg/rb/NorthPole_ZH-CN14730815128urlBase>
<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>1drk>
<top>1top>
<bot>1bot>
<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());
    }
}

打印的结果为:

获取必应每日一图网址_第1张图片

(bingPIC地址)http://s.cn.bing.net/az/hprichbg/rb/NorthPole_ZH-CN14730815128_1366x768.jpg
这里就成功了!

你可能感兴趣的:(java,android,xml解析,必应图片,dom4j)