我们在开发中,很多应用需要读取当前时间来对业务逻辑进行相对可靠的校验,但是我们服务器或者个人电脑上的时间又不一定足够用准确,所以我们需要获取网络时间来进行相对可靠的校验。
下面是Java中读取当前时区的时间时间的代码:
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.TimeZone;
public class DBOP
{
public static void main(String [] arg)
{
TimeZone time = TimeZone.getTimeZone("GMT+8"); //设置为东八区
time = TimeZone.getDefault();// 这个是国际化所用的
System.out.println(time);
TimeZone.setDefault(time);// 设置时区
Calendar calendar = Calendar.getInstance();// 获取实例
DateFormat format1 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");//构造格式化模板
Date date = calendar.getTime(); //获取Date对象
String str = new String();
str = format1.format(date);//对象进行格式化,获取字符串格式的输出
System.out.println(str);
}
}
输出结果为:
sun.util.calendar.ZoneInfo[id="Asia/Shanghai",offset=28800000,dstSavings=0,useDaylight=false,transitions=19,lastRule=null]
2018-09-19 09:32:47
下面是Java中读取网络时间的代码:
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Locale;
/**
* 读取网络时间
*
* @author SHANHY(365384722@QQ.COM)
* @date 2015年11月27日
*/
public class GetNetworkTime {
public static void main(String[] args) {
String webUrl1 = "http://www.baidu.com";//百度
String webUrl2 = "http://www.taobao.com";//淘宝
String webUrl3 = "http://www.ntsc.ac.cn";//中国科学院国家授时中心
String webUrl4 = "http://www.360.cn";//360
String webUrl5 = "http://www.beijing-time.org";//beijing-time
System.out.println(getWebsiteDatetime(webUrl1) + " [百度]");
System.out.println(getWebsiteDatetime(webUrl2) + " [淘宝]");
System.out.println(getWebsiteDatetime(webUrl3) + " [中国科学院国家授时中心]");
System.out.println(getWebsiteDatetime(webUrl4) + " [360安全卫士]");
System.out.println(getWebsiteDatetime(webUrl5) + " [beijing-time]");
}
/**
* 获取指定网站的日期时间
*
* @param webUrl
* @return
* @author SHANHY
* @date 2015年11月27日
*/
private static String getWebsiteDatetime(String webUrl){
try {
URL url = new URL(webUrl);// 取得资源对象
URLConnection uc = url.openConnection();// 生成连接对象
uc.connect();// 发出连接
long ld = uc.getDate();// 读取网站日期时间
Date date = new Date(ld);// 转换为标准时间对象
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.CHINA);// 输出北京时间
return sdf.format(date);
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
}
输出结果如下:
2018-09-19 09:35:22 [百度]
2018-09-19 09:35:22 [淘宝]
2018-09-19 09:35:22 [中国科学院国家授时中心]
2018-09-19 09:35:22 [360安全卫士]
2018-09-19 09:35:22 [beijing-time]
显而易见,几个知名互联网公司的时间是一致的,所以获取网络时间的时候,建议大家选用相对比较靠谱的网站,上面测试的几个已经足够备选了(百度、淘宝、国家授时中心)。
另外值得一提的是,该方法获取时间,只需要建立连接就可以了,不需要请求(request)与响应(response),所以比单独写接口效率要高。