找回密码
 加入
搜索
楼主: 木纳

获取局域网内服务器上的时间

  [复制链接]
发表于 2008-5-15 17:41:09 | 显示全部楼层
楼上的WMI是本地的。远程访问需要权限。请看中文资料区的“远程控制计算机”
发表于 2008-5-15 17:55:11 | 显示全部楼层
所以我说:需要权限……
发表于 2008-5-15 18:26:19 | 显示全部楼层
我是火星人……我shab……
如果真的要说底层的方法,那就是纯粹TCP/IP协议的实现了,发送一个含Timestamp的数据包过去,对方会返回一个包含Timestamp的数据包,分析数据包即可得到对方的时间。粗略可以查看这里:
http://www.cnpaf.net/class/tcpandip/05329185327162.html

很抓狂?的确,这些底层的事都比较痛苦……使用winsock API吧,那样会简单那么一点点……
例如如:
FC 41 A7 45 1D BA 06 00 3E 00 00 00 3E 00 00 00

01/12/2007 16:08:28
(01/12/2007 16:08:28顺序已经调整了,这样更适合人类看……)
 楼主| 发表于 2008-5-15 18:40:16 | 显示全部楼层
http://www.autoitx.com/forum.php ... &extra=page%3D1
这篇有个连接的例子,可是提示出错.

Dim      $computer     ="pc"
Dim      $Remoteuser   ="admin"
Dim      $Remotepass   = "sanhen"
$objWMIService=$objlocator.connectserver($computer,"root/cimv2",$Remoteuser,$Remotepass)

$objlocator.connectserver 这个,提示:variable used without being declared.



我有$computer     ="pc"的administrators用户名和密码,
 楼主| 发表于 2008-5-15 19:36:26 | 显示全部楼层
asdf 哥哥,表要这样说嘛..

俺是菜菜,向您学习,期待您给个api的例子...
发表于 2008-5-15 21:54:38 | 显示全部楼层

回复 18# asdf 的帖子

这样需要一定的TCP/IP基础了。。。最简单的如果不用NET TIME的话,是用C/S结构了。
这样客户端发包过来,服务发回一个包给客户端。。。直接对着帮助都可以画出来了。
 楼主| 发表于 2008-5-16 12:32:49 | 显示全部楼层
求教,
c/s结构,有顾虑,如果s开着,有N>300个c端去连接的话,这样的s.......

还望各位大大们,能给wmi或者api的例子,或者s端
发表于 2008-5-25 20:28:15 | 显示全部楼层
原帖由 木纳 于 2008-5-16 12:32 发表
求教,
c/s结构,有顾虑,如果s开着,有N>300个c端去连接的话,这样的s.......

还望各位大大们,能给wmi或者api的例子,或者s端

同步时间只是开机的时候同步,      我想应该不可能会300一起开机去同步吧!     就算300台一起同步也不会对服务端有太大影响的   又不是一直不停同步
发表于 2008-5-26 00:00:05 | 显示全部楼层
以前也做过这方面的实验,发代码上来大家研究一下,代码是修改的 titer 兄弟发的 局域网内客户端自动连接服务端  所以客户机不需要指定服务器IP地址 [url]http://www.autoitx.com/forum.php?mod=viewthread&tid=811&extra=page%3D2[url]
服务器代码:
[au3]UDPStartup()
$socket = UDPBind(@IPAddress1, 8410)
If @error <> 0 Then Exit
While 1
    $data = UDPRecv($socket, 50)
    If $data <> "" Then
                If StringInStr($data,"client:") Then
                        $ip=StringSplit($data,":")
                        $socket1=UDPOpen($ip[2],8411)
                        $send=UDPSend($socket1,@HOUR & "," & @MIN & "," & @SEC & "," & @YEAR & "," & @MON & "," & @MDAY)
                        Sleep(100)
                        UDPCloseSocket($socket1)
                EndIf
    EndIf
    sleep(10)
WEnd
Func OnAutoItExit()
    UDPCloseSocket($socket)
    UDPShutdown()
EndFunc[/au3]

客户机代码:
[au3]$objWMIService = ObjGet("winmgmts:\\localhost\root\CIMV2")
$colItems = $objWMIService.ExecQuery("SELECT * FROM Win32_NetworkAdapterConfiguration WHERE IPEnabled != 0", "WQL", 0x10 + 0x20)
If IsObj($colItems) then
For $objItem In $colItems
        Dim $netmask=""
        $localIP=$objItem.IPAddress(0)
        $ip=StringSplit($localIP,".")
        $net=StringSplit($objItem.IPSubnet(0),".")
        For $i=1 To $ip[0]
                If $i = $ip[0] Then
                        $netmask=$netmask&BitOR($ip[$i],BitXOR($net[$i],255))
                Else
                        $netmask=$netmask&BitOR($ip[$i],BitXOR($net[$i],255))&"."
                EndIf
        Next
        If Ping($netmask,10) Then
                UDPStartup()               
                $socket = UDPOpen($netmask, 8410)
                $socket1 = UDPBind($localIP,8411)
                $status = UDPSend($socket, "client:"&$localIP )
                If $status <> 0 then
                        UDPCloseSocket($socket)
                        While 1
                                $data = UDPRecv($socket1, 50)
                                If $data <> "" Then
                                        UDPCloseSocket($socket1)
                                        UDPShutdown()                                       
                                        $Timen=StringSplit($data,",")
                                        SetLocalTime($Timen[1],$Timen[2],$Timen[3],$Timen[4],$Timen[5],$Timen[6])
                                EndIf
                        WEnd
                EndIf
        EndIf
Next
EndIf

Func SetLocalTime($Hour, $Min, $Sec =0,$Year = 0,$Month = 0,$Day = 0)
    Local $Error = 0
    Local $Return = False
    If $Hour < 0 Or $Hour > 23 Then $Error = 1
    If $Min < 0 Or $Min > 59 Then $Error = 1
    If $Sec < 0 Or $Sec > 59 Then $Error = 1
    If @NumParams > 3 And ($Day < 1 Or $Day > 31) Then $Error = 1
    If @NumParams > 4 And ($Month < 1 Or $Month > 12) Then $Error = 1
    If @NumParams > 5 And ($Year < 1601 Or $Year > 30827) Then $Error = 1
    If Not $Error Then
        Local $Struct = DLLStructCreate('Short;Short;Short;Short;Short;Short;Short;Short')
        Local $StructPtr = DLLStructGetPtr($Struct)
        If @NumParams < 6 Then
            DLLCall('Kernel32', 'None', 'GetLocalTime', 'Ptr', $StructPtr)
            If @Error Then $Error = 2
        EndIf
        If Not $Error Then
            DLLStructSetData($Struct, 5, $Hour)
            DLLStructSetData($Struct, 6, $Min)
            DLLStructSetData($Struct, 7, $Sec)
            DLLStructSetData($Struct, 8, 0)
            If @NumParams > 3 Then DLLStructSetData($Struct, 4, $Day)
            If @NumParams > 4 Then DLLStructSetData($Struct, 2, $Month)
            If @NumParams > 5 Then DLLStructSetData($Struct, 1, $Year)
            DLLCall('Kernel32', 'None', 'SetLocalTime', 'Ptr', $StructPtr)
            Local $Result = DLLCall('Kernel32', 'Int', 'SetLocalTime', 'Ptr', $StructPtr)
            If @Error Then
                $Error = 2
            Else
                $Return = ($Result[0] <> 0)
            EndIf
        EndIf        
    EndIf
    SetError($Error)
    Return $Return
EndFunc[/au3]

[ 本帖最后由 bing614 于 2008-5-26 00:02 编辑 ]

评分

参与人数 1金钱 +2 收起 理由
木纳 + 2 谢谢分享...

查看全部评分

 楼主| 发表于 2008-5-26 14:53:06 | 显示全部楼层
原帖由 bing614 于 2008-5-26 00:00 发表
以前也做过这方面的实验,发代码上来大家研究一下,代码是修改的 titer 兄弟发的 局域网内客户端自动连接服务端  所以客户机不需要指定服务器IP地址 http://www.autoitx.com/forum.php ... 1&extra=page%3D ...



感谢.
我测试的时候,cpu占用率很高.
发表于 2008-5-28 14:07:14 | 显示全部楼层
其实还可以这样做时间同步的

就是在服务器上装个mssql,然后客户机去连接这个数据库,就可以获得时间了

这样的好处是,就算客户端有几百个,也不会有太大的问题

[ 本帖最后由 ken0137 于 2008-5-28 14:08 编辑 ]

评分

参与人数 1金钱 +1 收起 理由
木纳 + 1 谢谢提供这个创意

查看全部评分

发表于 2008-5-29 01:45:50 | 显示全部楼层
没有加退出,肯定占用CPU.重新发
[au3]$objWMIService = ObjGet("winmgmts:\\localhost\root\CIMV2")
$colItems = $objWMIService.ExecQuery("SELECT * FROM Win32_NetworkAdapterConfiguration WHERE IPEnabled != 0", "WQL", 0x10 + 0x20)
If IsObj($colItems) then
For $objItem In $colItems
        Dim $netmask=""
        $localIP=$objItem.IPAddress(0)
        $ip=StringSplit($localIP,".")
        $net=StringSplit($objItem.IPSubnet(0),".")
        For $i=1 To $ip[0]
                If $i = $ip[0] Then
                        $netmask=$netmask&BitOR($ip[$i],BitXOR($net[$i],255))
                Else
                        $netmask=$netmask&BitOR($ip[$i],BitXOR($net[$i],255))&"."
                EndIf
        Next
        If Ping($netmask,10) Then
                UDPStartup()               
                $socket = UDPOpen($netmask, 8410)
                $socket1 = UDPBind($localIP,8411)
                $status = UDPSend($socket, "client:"&$localIP )
                If $status <> 0 then
                        UDPCloseSocket($socket)
                        While 1
                                $data = UDPRecv($socket1, 50)
                                If $data <> "" Then
                                        UDPCloseSocket($socket1)
                                        UDPShutdown()                                       
                                        $Timen=StringSplit($data,",")
                                        SetLocalTime($Timen[1],$Timen[2],$Timen[3],$Timen[4],$Timen[5],$Timen[6])
                                        Exit
                                EndIf
                        WEnd
                EndIf
        EndIf
Next
EndIf

Func SetLocalTime($Hour, $Min, $Sec =0,$Year = 0,$Month = 0,$Day = 0)
    Local $Error = 0
    Local $Return = False
    If $Hour < 0 Or $Hour > 23 Then $Error = 1
    If $Min < 0 Or $Min > 59 Then $Error = 1
    If $Sec < 0 Or $Sec > 59 Then $Error = 1
    If @NumParams > 3 And ($Day < 1 Or $Day > 31) Then $Error = 1
    If @NumParams > 4 And ($Month < 1 Or $Month > 12) Then $Error = 1
    If @NumParams > 5 And ($Year < 1601 Or $Year > 30827) Then $Error = 1
    If Not $Error Then
        Local $Struct = DLLStructCreate('Short;Short;Short;Short;Short;Short;Short;Short')
        Local $StructPtr = DLLStructGetPtr($Struct)
        If @NumParams < 6 Then
            DLLCall('Kernel32', 'None', 'GetLocalTime', 'Ptr', $StructPtr)
            If @Error Then $Error = 2
        EndIf
        If Not $Error Then
            DLLStructSetData($Struct, 5, $Hour)
            DLLStructSetData($Struct, 6, $Min)
            DLLStructSetData($Struct, 7, $Sec)
            DLLStructSetData($Struct, 8, 0)
            If @NumParams > 3 Then DLLStructSetData($Struct, 4, $Day)
            If @NumParams > 4 Then DLLStructSetData($Struct, 2, $Month)
            If @NumParams > 5 Then DLLStructSetData($Struct, 1, $Year)
            DLLCall('Kernel32', 'None', 'SetLocalTime', 'Ptr', $StructPtr)
            Local $Result = DLLCall('Kernel32', 'Int', 'SetLocalTime', 'Ptr', $StructPtr)
            If @Error Then
                $Error = 2
            Else
                $Return = ($Result[0] <> 0)
            EndIf
        EndIf        
    EndIf
    SetError($Error)
    Return $Return
EndFunc
[/au3]
 楼主| 发表于 2008-7-10 11:45:20 | 显示全部楼层
结贴...
还是打回原形,用dos命令行了...
发表于 2008-7-10 12:03:51 | 显示全部楼层
奇思妙想诚可贵,任督两脉亦要通!
发表于 2009-10-9 16:07:44 | 显示全部楼层
net time  ..也看看。
您需要登录后才可以回帖 登录 | 加入

本版积分规则

QQ|手机版|小黑屋|AUTOIT CN ( 鲁ICP备19019924号-1 )谷歌 百度

GMT+8, 2024-11-18 01:51 , Processed in 0.067243 second(s), 14 queries .

Powered by Discuz! X3.5 Licensed

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表