【机房收费系统 4】:VB获取标准北京时间,免除时间误差
导读:这又是师傅给我指出的一个问题,说实话,其实开始根本没有当回事,觉得麻烦,可是,等我完成了获取标准北京时间后,我发现,这一步,是必须的。谢谢师傅对我的严格要求,让我一步一步的成长起来!
一、事件缘由
去验收机房的时候,当看着查询结果时,我是又傻了一回眼,我在501做的是24小时制,那边511是12小时制,出的日期和时间完全对不上号。我刚开始觉得没什么,因为我知道只是时间的格式不同而已,但是师傅说,你可以把它改为标准时间,你这时间错乱的,让别人怎么看?当时,就跟师傅说,是不是像手机一样,获取全球卫星定位的那个日期时间,不管我怎么折腾,那都是标准时间。
现在,想想也真是,要是账单查询,可就糟了,这日期和时间全对不上号,该是多么悲剧的一件事。
最先,我系统里的全部时间日期,都是这样写的:
txtOffDate.Text = Date
txtOffTime.Text = Time
其实,只要是计算机设定的时间没有误差,那这样写也就没有错,可是,有时候,就会出现时间格式不统一,可能还有日期不对的情况,这样,我获取的这个日期和时间就是错误的,我写进数据库的所有数据都存在着误差,要真是做财务的,相差一天,或者一个小时的账单不统一,我感觉就会出大问题。经过努力查询(问度娘的,作者不知道是谁,所以没法标注,目前,我写不出这样的,只能勉强理解),终于解决了。
二、解决办法
1,VB获取卫星定位时间,还真让我给弄出了一个,那定位课详细了,什么经度纬度都能给获取到,别说什么日期时间了。但这个真的太高大上了,看了半天都理解不了。所以,给放弃了!
2,通过使用Winsock控件,这个也可以实现,但真的代码一大堆,也有一些理解不了。所以,给放弃了。
3,通过Internet获取网络标准时间,这个也有不同的方法,我现在觉得相对简单的有两种,第一种我不知道怎么把日期和时间分开,所以给弃了。
一、Private Function GetHtml(Url As String)
Dim xmlHttp As Object
Set xmlHttp = CreateObject("Microsoft.XMLHTTP")
xmlHttp.open "GET", Url, True
xmlHttp.send (Null)
While xmlHttp.ReadyState <> 4
DoEvents
Wend
GetHtml = xmlHttp.responseText
End Function
Private Function getTime() As Date
Dim Regex As Object, ms As Object, m As Object
Dim HTML As String
Dim t As String
HTML = GetHtml("http://www.time.ac.cn/timeflash.asp?user=flash")
Set Regex = CreateObject("VBSCRIPT.REGEXP")
Regex.IgnoreCase = True
Regex.Pattern = "<year>(\d+)</year><month>(\d+)</month><day>(\d+)</day>.+?<hour>(\d+)</hour><minite>(\d+)</minite><second>(\d+)</second>"
Set ms = Regex.Execute(HTML)
If ms.Count = 0 Then
getTime = Now()
Else
t = ms.Item(0).SubMatches(0) _
& "-" & ms.Item(0).SubMatches(1) _
& "-" & ms.Item(0).SubMatches(2) _
& " " & ms.Item(0).SubMatches(3) _
& ":" & ms.Item(0).SubMatches(4) _
& ":" & ms.Item(0).SubMatches(5)
If IsDate(t) Then getTime = CDate(t) Else getTime = Now()
End If
End Function
Private Sub Command1_Click()
Call getTime
Text1.Text = getTime
End Sub
然后第二种,就相对而言,好理解多了,活不多说,一个单词一个单词去查吧,拼起来,也就是那个意思了。它的日期和时间,是分开的,也就是想用哪个都可以。推荐感兴趣的人了解了解XmlHttp,还有Set XmlHttp = CreateObject中用的create和我们平时用的new的区别,以及里面的StrConv函数。
二、Private Sub Command1_Click()
Call theTime
Text1.Text = theTime
End Sub
Public Function theTime(Optional getDate As Boolean = True, Optional getTime As Boolean = True) As String
Dim XmlHttp As Object
Set XmlHttp = CreateObject("Microsoft.XMLHTTP")
If getDate = True Then
XmlHttp.Open "Get", "http://www.symental.com/time/date.asp", False
XmlHttp.send
theTime = StrConv(XmlHttp.ResponseBody, vbUnicode)
End If
If getTime = True Then
XmlHttp.Open "Get", "http://www.symental.com/time/time.asp", False
XmlHttp.send
theTime = IIf(theTime <> "", theTime & " " & StrConv(XmlHttp.ResponseBody, vbUnicode), StrConv(XmlHttp.ResponseBody, vbUnicode))
End If
Set XmlHttp = Nothing
End Function
三、感受
现在的我,还很弱小,我自己写不出这样的函数,我只能踩着别人的肩膀上,我期望有一天,我的肩膀,也可以让别人踩。我现在还不能完全理解这些代码,但我相信,总有一天,我会的。
我太容易将就,从学生到机房,都是如此,真的很庆幸,我有那么严格要求的师傅。师傅总是很仔细,从用户的使用习惯,用户的实际需求,跟我讲部署,对我的系统进行页面排版上的指导,也能发现我系统中不合理的地方,真的很好,谢谢师傅们的指导。
其实,师傅真的挺关爱我的。那天我说我想当黑客,师傅就跟我说了一个名词:SQL注入,后来,我真的了解了很多,很感兴趣,自己也弄了一个表简单的试了一下,忒恐怖了!也学到了一点点防止SQL注入的方法。谢谢师傅!
2014.8.18修改
对于上述所说的解决方案,我感到深深的惭愧。当时太过兴奋,就往上贴了。其实,这些办法是存在问题的:比如说没有网怎么办?
后来,经过师傅的指导,终于知道,根本不用这么复杂,可以在VB中通过SQL语句获取数据库里的时间,这样也能保证时间统一。这个有专门的函数,获取时间日期,每个也就是一行代码的事儿,函数一搜一大把。比如日期:getdate,时间:convert。
请大家多多指教,谢谢!
【机房收费系统 4】:VB获取标准北京时间,免除时间误差的更多相关文章
- 机房收费系统(VB.NET)——超具体的报表制作过程
之前做机房收费系统用的报表是Grid++Report,这次VB.NET重构中用到了VisualStudio自带的报表控件. 刚開始当然对这块功能非常不熟悉,只是探究了一段时间后还是把它做出来了. 以下 ...
- 机房收费系统(VB.NET)——存储过程实战
最初接触存储过程是在耿建玲老师的视频里,当初仅仅是草草过了一遍.仅仅是有了个印象.知道了这个名词:大二时也有SqlServer数据库这门课,只是老师没讲,自己也没看:真正对存储过程的了解来自于自学考试 ...
- 机房收费系统——在VB中将MSHFlexGrid控件中的数据导出到Excel
机房收费系统中,好多查询的窗体都包含同一个功能:将数据库中查询到的数据显示在MSHFlexGrid控件中,然后再把MSHFlexGrid控件中的数据导出到Excel表格中. 虽然之前做过学生信息管理系 ...
- 机房收费系统之vb报表的模板的制作(一)
机房收费系统有报表的功能,报表对于我们来说有点陌生.这不是会计的事吗?怎么机房收费系统也參合进来了,事实上我们学会了报表的步骤.理解了代码后.报表变得不是非常难,世上无难事,仅仅怕肯登攀 ...
- 机房收费系统(VB.NET)个人版总结
重构版个人机房收费系统大概从暑假开学開始进行.花了不到一个半月的时间才完毕.以下对我在重构过程中的一写理解. 1.系统设计一个非常重要的目的就是重用.而要做到重用,低耦合是最有效的手段回想一下我们C/ ...
- VB.NET版机房收费系统---异常处理
异常处理,英文名为Exceptional Handling, 那时年少,还记得那年一起学习过的VB6.0的时候,常常使用ONError的错误语句.与传统VB6.0中的OnError语句相比.NET平台 ...
- VB.NET版机房收费系统---七仙女之系统登录
VB.NET第一版机房收费系统,告一段落,验收的时候.问题也是大大的存在,没实用上设计模式,什么触发器.存储过程,都没实用上.看看其她小伙伴的,七层实现登录?那是什么东东,相比較我的三层而言,多了两倍 ...
- VB.NET 机房收费系统项目总结
VB.NET机房收费系统项目总结 从2013年5月3日——2013年8月20日历时三个多月的.NET机房收费系统终于完成了.项目做完了,真有一种如释重负的感觉. 下面我将从文档.UML图,代码这三个方 ...
- VB.NET版机房收费系统---导出Excel表格
datagridview,翻译成中文的意思是数据表格显示,使用DataGridView控件,能够显示和编辑来自不同类型的数据源的表格,将数据绑定到DataGridView控件很easy和直观,大多数情 ...
随机推荐
- 定时任务-Timer
Timer类的全限定名 java.util.Timer java.util.Timer类的构造函数 public Timer(); public Timer(boolean isDaemon); pu ...
- WebService学习之旅(六)使用Apache Axis2实现WebService客户端调用
上节介绍了如何使用Axis2 发布一个WebService,Axis2除了为我们编写WebService应用带来了便利,也同样简化的客户端调用的过程,本节在上节的基础上使用Axis2自带的工具生成客户 ...
- 明白这十个故事-->你也就参悟了人生 .
1.断箭 不相信自己的意志,永远也做不成将军. 春秋战国时代,一位父亲和他的儿子出征打仗.父亲已做了将军,儿子还只是马前卒.又一阵号角吹响,战鼓雷鸣了,父亲庄严地托起一个箭囊,其中插着一只箭.父亲郑 ...
- 我的CentOS6.5下及windows7下 安装composer与Yii2的过程
用yii2以来,安装composer老是不成功,所以一直在windows下的php里,用直接解压的方法运行yii2. 后来越来越多的场合,需要用composer,终于下决心,要在Linux下搞掂它! ...
- 如何通过Xcode 5中集成的XCTest框架进行简单的单元测试
XCTest 1.第一个单元测试 XCTest是Xcode 5中自带的测试框架 下面从一个Demo开始.首先用Xcode新建一个工程UnitTestDemo,工程目录结构如下: 可以看到工程下面多了一 ...
- codevs 1742 爬楼梯(水题日常)
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小明家外面有一个长长的楼梯,共N阶.小明的腿很长,一次能跨过一或两阶.有一天,他 ...
- 系统相册中获取gif图片 保证取到的图片不会改变
NSURL *imageRefURL = [info valueForKey:UIImagePickerControllerReferenceURL]; ...
- 2018_oakland_linuxmalware
2018年oakland论文:理解linux恶意软件 论文地址:http://www.s3.eurecom.fr/~yanick/publications/2018_oakland_linuxmalw ...
- WPF中单选框RadioButton
单选框RadioButton的基本使用: <StackPanel Margin="10"> <Label FontWeight="Bold"& ...
- 浏览器输入一个url到整个页面显示出来经历了哪些过程?
https://cloud.tencent.com/developer/article/1396399 https://www.cnblogs.com/haonanZhang/p/6362233.ht ...