在实际开发过中,我们需要获取服务器时间,来保证时间的准确性,这里主要介绍使用

使用云函数来获取服务器时间

// 云函数入口文件

const cloud = require('wx-server-sdk')

cloud.init()

// 云函数入口函数

exports.main = async (event, context) => {

return new Date()

}

值得注意的是 云函数里的 new Date ()是utc时间,并不是北京时间,怎么转换为北京时间稍后介绍。

为了避免重复多次调用云函数获取时间, 我把获取方法写在app.js里

这样有两个好处:

A 如果你只获取当前 年/月/日 ,那么只需要调用

globalData.serverDate

B 如果你要获取当前 年/月/日/时/分/秒,那么只需要调用

app.getserverDate()

// 云函数入口文件

//app.js

App({

onLaunch: function () {

if (!wx.cloud) {

console.error('请使用 2.2.3 或以上的基础库以使用云能力')

} else {

wx.cloud.init({

traceUser: true,

})

}

this.globalData = { serverDate: this.getserverDate()}

},

//获取服务器时间

getserverDate:function(){

wx.cloud.callFunction({

name: 'getdate',

success: function (res) {

getApp().globalData.serverDate = res.result

}

})

}

})

下面我们就来实际用下 ,看下能否实现我们想要的效果

import { JumpUtils} from '../jumpUtils.js';

var jumpM= new JumpUtils();

var util = require('../../utils/utils.js');

const app = getApp()

Page({

data: {

date:'' //保存当前日期

},

onLoad: function (options) {

this.setData({ date: util.formatTime(jumpM.utc_beijing(app.globalData.serverDate)) })

},

})

注意: 从云函数获取到时间格式默认格式: 2019-04-26T07:45:38.057Z

这里我引用了3处,app引用就不用介绍了,utils是转换时间用的,

jumpM 实际上我一个模型,下面有个utc_beijing 方法一看就知道是

utc时间转北京时间

utc_beijing

//utc时间转北京时间

utc_beijing(utc_datetime) {

// 转为正常的时间格式 年-月-日 时:分:秒

var T_pos = utc_datetime.indexOf('T');

var Z_pos = utc_datetime.indexOf('Z');

var year_month_day = utc_datetime.substr(0, T_pos);

var hour_minute_second = utc_datetime.substr(T_pos + 1, Z_pos - T_pos - 1);

var new_datetime = year_month_day + " " + hour_minute_second; // 2017-03-31 08:02:06

// 处理成为时间戳

timestamp = new Date(Date.parse(new_datetime));

timestamp = timestamp.getTime();

timestamp = timestamp / 1000;

// 增加8个小时,北京时间比utc时间多八个时区

var timestamp = timestamp + 8 * 60 * 60;

// 时间戳转为时间

// var beijing_datetime = new Date(parseInt(timestamp) * 1000).toLocaleString().replace(/年|月/g, "-").replace(/日/g, " ");

var beijing_datetime = new Date(parseInt(timestamp) * 1000)

return beijing_datetime; // 2017-03-31 16:02:06

}

utils 是小程序自己封装的一个方法(其实可以把utils 和utc_beijing封装在一起 方便简洁一点)

function formatTime(date) {

var year = date.getFullYear()

var month = date.getMonth() + 1

var day = date.getDate()

var hour = date.getHours()

var minute = date.getMinutes()

var second = date.getSeconds()

return [year, month, day].map(formatNumber).join('')

}

function formatNumber(n) {

n = n.toString()

return n[1] ? n : '0' + n

}

module.exports = {

formatTime: formatTime

}

代码已奉上,请君尽情参考!路漫漫其修远兮。

获取服务器时间的软件如何修改时间,小程序云开发获取服务器时间相关推荐

  1. 小程序云开发无服务器实现实时通信

    我的第一篇博客--小程序云开发无服务器实现实时通信 小程序云开发初体验 实时变化界面的函数setInterval() 需要注意的点 我的代码 写在最后 小程序云开发初体验 我在本学期的软件工程课的大作 ...

  2. 微信小程序云开发获取用户openid

    下面带领大家借助小程序云开发获取用户唯一标识openid 首先在磁盘建立一个文件夹,存放此项目 在目录这里选择自己创建的文件夹位置,AppID输入自己申请的小程序AppID,然后选择不使用云服务,我们 ...

  3. 小程序云开发获取手机号完整代码 云函数中网络请求第三方接口

    小程序云开发获取手机号完整代码 效果图: 小程序代码 <button open-type="getPhoneNumber" bindgetphonenumber=" ...

  4. 微信小程序云开发获取手机号

    微信小程序云开发获取手机号 一.页面中button组件open-type配置项 open-type="getPhoneNumber" 获取用户手机号,可以从 bindgetphon ...

  5. 小程序问题记录:小程序云开发获取不到数据库的记录

    问题描述 尝试小程序使用云数据库获取记录,进行调试的时候,控制台结果一直返回这个,如图: 代码如下: wx.cloud.init(); const db = wx.cloud.database()Pa ...

  6. 微信小程序云开发获取上传图片后https的url链接地址

    话不多说,直接上代码: // 点击上传图片 触发函数 changeBigImg(){let that = this;wx.chooseImage({count: 1,sizeType: ['origi ...

  7. 小程序云开发获取不到数据库的记录

    问题描述 尝试小程序使用云数据库获取记录,进行调试的时候,控制台结果一直返回这个,如图: wx.cloud.init(); const db = wx.cloud.database()Page({da ...

  8. 微信小程序云开发 serverData() 服务器时间 本地解析

    服务器端时间用serverData()构造. 云数据库端的date类型数据,获取后的类型为object,无法直接显示到前端, 需要使用.get()方法读取查询的数据,格式化后显示到前端. 1.数据库添 ...

  9. php访问微信云数据库,第三方服务器php获取微信小程序云开发access_token和云数据库...

    微信小程序云开发开放了http api,可以从第三方访问云服务了.方便很多.云服务的后台,可以用PC端写了. 流程大概就是通过appid,appkey获得access_token,这个access_t ...

最新文章

  1. Python 之 matplotlib (六)tick能见度
  2. C++中定义对象的语法,带括号与不带括号有什么区别?
  3. UOJ #578. 收集卡片
  4. 可转债的投资价值算法
  5. 记录——《C Primer Plus (第五版)》第九章编程练习第一题
  6. 【NLP】近期必读ICLR 2021相关论文
  7. 【硬核课】最新《图卷积神经网络GCN》2020概述,76页ppt,NTU-Xavier Bresson,纽约大学深度学习课程...
  8. Xception: DeepLearning with Depthwise Separable Convolutions2017Google【论文理解】
  9. 如何应用Matlab plot画点
  10. 每天一个PS技巧(原理+实践)——简单背景的抠图与毛发抠图
  11. Java-Scala编程规范超精简
  12. 九种NPP\GPP数据集介绍和下载
  13. 2019年上半年英语四、六级成绩查询方式和时间
  14. SonarQube最全使用教程
  15. Python 数据挖掘之电力窃漏电用户自动识别
  16. 用python制作条形图时出现“posx and posy should be finite values”问题的解决方法
  17. 并发编程JUC深度学习(七)无锁(乐观锁)
  18. 又一里程碑,阿里首推Java技术成长笔记,业内评级“钻石级”
  19. 基于javaweb的红酒朔源管理系统(java+ssm+jsp+layui+jquery+mysql)
  20. centos安装向日葵

热门文章

  1. 华为 HarmonyOS 2.0 全面升级,构建中国软件的“根”!
  2. Kafka 和 RocketMQ 底层存储之那些你不知道的事
  3. 当芯片教父遇上伊隆马斯克:自动驾驶路在何方
  4. TCP 半连接队列和全连接队列满了,怎么破?
  5. 1 月以来 Tether 增发 47 亿 USDT,美元都去哪儿了?
  6. ​苹果WWDC20确定6月22日线上举办;任天堂遭史上最大规模黑客攻击 ;Inkscape 1.0 发布 | 极客头条...
  7. 播放内核的“瘦身”,你只需要这样做!
  8. “不会Linux,怎么当程序员?”骨灰级程序员:你的代码正在毁掉你!
  9. JavaScript 败北,TypeScript 大势所趋?
  10. Uber 提出损失变化分配方法 LCA,揭秘神经网络“黑盒” 60s测试:你是否适合转型人工智能? https://edu.csdn.net/topic/ai30?utm_source=csdn_bw