放宿舍隔离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 $testConnect = 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