在客户端获取服务器端的时间

 

    以前只知道在js中这样写:var date = new Date() ; 但是这得到的是客户浏览器的时间,并不是服务器的时间。

    当然可以通过在java文件中添加属性,再在js中通过document.getElementById().value得到,但是这样又太麻烦。。

    今天找到了一个简单快捷的方法,特地记录下来。

    其实可以像这样 var date = '<%=new java.util.Date()%>'; 但是这样得到的date是这样的:

 

    这样格式的date是没办法调用date对象的方法的,所以我们可以像下面这样:

    var date = '<%=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new java.util.Date())%>;

    先把date转换成“2011-11-11 11:11:11” 这样的字符串,再调用var newDate = new Date(date.replace(/-/,"/"))这个方法是把前面的字符串转换成date对象)。

    这样我们就可以成功地调用date对象的各种方法啦。。

    其中有几点需要注意的地方:

   1.var date = '<%=new java.util.Date()%>'; 这样的js代码只能写在包含这段js代码的jsp中,因为<% %>要在服务器端进行解析。

    2.var date = '<%=new java.util.Date()%>'; 一定要记得加单引号或双引号。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Java的TimeZone类获取客户端时区信息。 在服务器端Java类中,可以通过获取HTTP请求头中的"TimeZone"信息来获取客户端时区。具体实现如下: ```java import java.util.TimeZone; public class TimeZoneUtil { public static String getClientTimeZone(HttpServletRequest request) { String timeZone = request.getHeader("TimeZone"); if (timeZone == null || timeZone.isEmpty()) { return "UTC"; } return timeZone; } public static TimeZone getTimeZone(String timeZone) { if (timeZone == null || timeZone.isEmpty()) { return TimeZone.getTimeZone("UTC"); } return TimeZone.getTimeZone(timeZone); } } ``` 在上面的代码中,getClientTimeZone方法会获取HTTP请求头中的"TimeZone"信息,如果没有该信息则默认返回UTC时区。 getTimeZone方法根据传入的时区信息获取对应的TimeZone对象,如果传入的时区信息为空,则默认返回UTC时区。 使用示例: ```java import java.util.TimeZone; public class Main { public static void main(String[] args) { // 假设客户端时区为东八区 String clientTimeZone = "Asia/Shanghai"; // 获取对应的TimeZone对象 TimeZone timeZone = TimeZoneUtil.getTimeZone(clientTimeZone); System.out.println(timeZone.getID()); // 输出: Asia/Shanghai System.out.println(timeZone.getDisplayName()); // 输出: 中国标准时间 System.out.println(timeZone.getRawOffset()); // 输出: 28800000 } } ``` 在上面的示例中,我们传入客户端时区为"Asia/Shanghai",使用TimeZoneUtil类获取对应的TimeZone对象,并输出相关信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值