获取必应每日一图网址

1 篇文章 0 订阅
1 篇文章 0 订阅

最近自己捉摸着写了一个获取必应每日一图的网址几行代码,很简陋,但是很有用。这也是我第一次写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
这里就成功了!
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值