A-A+
	管理艾泰路由器WEB认证帐号的脚本
放宿舍隔离pppoe路由器的艾泰路由不可建立单独管理WEB认证的帐号,所以写了个脚本管理WEB认证帐号。
添加WEB认证帐号的核心代码:
Func addHotSpotUser()
;从路由器上获取帐号数
- Dim $webHTML = InetRead('http://' & $RouterAdminName & ':' & $RouterAdminPSW & '@' & $RouterIP & '/WebAuthServer.asp', 9)
 - If $webHTML = "" Then
 - MsgBox(32, "敬告", "连接路由器超时或者登录路由器用户名密码错误。")
 - Exit
 - Else
 - $webHTML = BinaryToString($webHTML)
 - ;匹配出totalrecs=,即获得帐号数量
 - $WebAuthNamesCounts = StringRegExp($webHTML, 'var\stotalrecs\=([^\"]+)\;var', 1)
 - If @error <> 0 Then
 - MsgBox(32, "敬告", "正则匹配WebAuthNamesCounts帐号出错,error=" & @error)
 - Exit
 - Else
 - $WebAuthNamesCount = $WebAuthNamesCounts[0]
 - EndIf
 - EndIf
 
;从日志获取账号数量
- Dim $hotspotUserName = 0, $remainingCount = 0, $logAccouts = 0
 - For $i = 1 To $totalAccount
 - Local $fLine = FileReadLine($LogFile , $i)
 - If @error <> 0 Then
 - MsgBox(32, "敬告", "打开Log文件发生错误." & @error, 10)
 - Exit
 - EndIf
 - Local $fLineDay = StringLeft($fLine, 10)
 - If $fLineDay = @YEAR & "-" & @MON & "-" & @MDAY Then
 - $logAccouts += 1
 - Else
 - ExitLoop
 - EndIf
 - Next
 
;如果路由器上获取的帐号数和日志上获取到的记录数不同,很可能是有人直接登录路由器添加了帐号
- If $WebAuthNamesCount <> $logAccouts Then
 - MsgBox(32, "敬告", "路由器上的记录数和日志的不同,请联系IT部")
 - Exit
 - Else
 - $remainingCount = 49 - $WebAuthNamesCount ;是加了这次帐号后剩余数
 - EndIf
 
;找出最后一个帐号名
- Local $aTemp = StringRegExp($webHTML, "(?<=\(\)\;var\stotalrecs\;\n).*(?=\;var\stotalrecs\=)", 1) ;正则匹配
 - If @error <> 0 And $WebAuthNamesCount = 0 Then ;正则匹配不到表示还没有帐号,则要添加第一个帐号
 - $lastWebAuthName = 0
 - ElseIf IsArray($aTemp) Then
 - Local $aListTemp = StringSplit($aTemp[0], ";")
 - ;For $i = 2 to UBound($aListTemp) -1 Step 6 ;全部帐号
 - ;匹配出最后一个WebAuthName
 - $WebAuthNames = StringRegExp($aListTemp[UBound($aListTemp) - 5], 'WebAuthNames\[\d*\]\s\=\s\"([^\"]+)\"', 1)
 - If @error <> 0 Then
 - MsgBox(32, "敬告", "正则匹配WebAuthNames帐号出错,error=" & @error)
 - Exit
 - Else
 - $lastWebAuthName = $WebAuthNames[0]
 - EndIf
 - Else
 - MsgBox(32, "敬告", "匹配WebAuthNames数组出错")
 - Exit
 - EndIf
 - If StringIsDigit($lastWebAuthName) Then
 - $hotspotUserName = $lastWebAuthName + 1
 - EndIf
 - If $hotspotUserName = 13 Then
 - $hotspotUserName = 15
 - EndIf
 - $hotspotUserPSW = Random(100000, 999999, 1) ;用6位随机数做密码
 
;先写入日志,否则已经添加账号进路由但写入日志出错麻烦,顺便先检查是否允许写入日志,如果不允许写入日志则退出
- _FileWriteLog($LogFile, $UserName & " Add HotSpot Account " & $hotspotUserName & " Password is " & $hotspotUserPSW, 0)
 - If @error <> 0 Then
 - MsgBox(32, "敬告", "打开Log文件发生错误或不可写入。" & @error, 10)
 - Exit
 - EndIf
 
;连接路由器添加账号
- $oHTTP = ObjCreate("Microsoft.xmlhttp")
 - $oHTTP.Open("POST", "http://" & $RouterAdminName & ":" & $RouterAdminPSW & "@" & $RouterIP & "/goform/formWebAuthConfig", False)
 - $oHTTP.setRequestHeader("Cache-Control", "no-cache")
 - $oHTTP.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
 - $oHTTP.setRequestHeader("Referer","http://" & $RouterIP &"/WebAuth_edit.asp")
 - $oHTTP.Send("Action=add&instIndex=&authname=" & $hotspotUserName & "&authnameold=&authpasswd=" & $hotspotUserPSW & "&authip=&authtimestart=yyyy-mm-dd&BeginDate=&authtimestop=yyyy-mm-dd&EndDate=&authtimetotal=0.0&remark=");post关键数据
 - $oText = BinaryToString($oHTTP.responseBody) ;处理responsetext会乱码,用responseBody才可以
 - ;Action=add&instIndex=&authname=test10&authnameold=&authpasswd=abc&authip=
 - ;&authtimestart=yyyy-mm-dd&BeginDate=&authtimestop=yyyy-mm-dd&EndDate=&authtimetotal=9.5&remark=9.5%D0%A1%CA%B1
 - ;ConsoleWrite($oText)
 - If StringInStr($oText, '用户名已存在') <> 0 Then;已经注册过
 - _FileWriteToLine($LogFile, 1, "", 1) ;删除上面的添加Log记录
 - MsgBox(0, "", "发生用户名已存在错误,请重新添加。")
 - ElseIf $oText = "" Then ;返回为空,可以处理为超时了。也有可能是提交的数据有误导致返回为空
 - MsgBox(0, "", "超时错误。可能已经添加账号到路由器,请联系IT部查看。")
 - Else
 - $hDiff = _DateDiff( 'h',_NowCalc(), _DateAdd('d', 1, _NowCalcDate()) & " 00:00:00") ;计算今天还剩余多少小时
 - ;返回账号密码等信息
 - MsgBox(0, "Fiori WIFI", @CRLF & "登录账号名:" & $hotspotUserName & @CRLF & "登录密码是:" & $hotspotUserPSW & @CRLF & @CRLF & "剩余可上网时间:" & $hDiff & "小时" & @CRLF & @CRLF & "今天剩余可用账号数:" & $remainingCount & @CRLF & "账号当天有效,请遵守相关连网规定。")
 - EndIf
 - EndFunc ;==>addHotSpotUser
 
每天定时删除全部WEB认证帐号代码:
;测试路由器是否连通
;此处可考虑添加通知给管理员
- Dim $testConnecttestConnect = testConnect($routerIP, $routerPort)
 - If $testConnect = 0 Then
 - MsgBox(32, "出错", "访问不到路由器!", 10)
 - Exit
 - EndIf
 - #--------------------------------------------------------
 - $ff = InetRead('http://' & $routerAdminName & ':' & $routerAdminPSW & '@' & $routerIP & '/goform/formWebAuthListDelAll', 9)
 - ;$ff = BinaryToString($ff)
 - ;ConsoleWrite($ff)
 - Exit
 - #-----------------------------------------------------------
 - Func testConnect($ip, $port)
 - TCPStartUp()
 - $Socket = TCPConnect($ip, $port)
 - If $socket <> 1 and $socket <> -1 and $socket <> 2 Then
 - Return 1
 - Else
 - Return 0
 - endif
 - TCPCloseSocket($Socket)
 - EndFunc ;==>testConnect