使用VBS实现Hosts文件一键配置实现代码(vbs调用vba函数)怎么可以错过

随心笔谈2年前发布 admin
155 0 0

文章摘要

文章介绍了名为HostHelper的Host文件配置工具,其主要功能是根据输入的参数(Host文件地址、IP地址、主机名和操作类型)对Host文件进行配置。操作类型分为“覆盖”和“追加”两种模式。 工具通过Option Explicit声明,确保所有变量显式声明。用户需要通过命令行提供四个参数:Host文件地址、IP地址、主机名和操作类型。操作类型中,“覆盖”表示替换已有主机名对应的IP地址,“追加”表示在文件末尾新增IP地址与主机名的对应关系。 工具首先判断是否已有目标主机名,并提示用户或退出程序。接着根据操作类型,分别对文件进行修改或追加。在覆盖模式下,会修改现有主机名对应的行,并在文件末尾追加新行;在追加模式下,直接在文件末尾添加新的IP地址和主机名对。 总结:HostHelper工具通过参数化实现对Host文件的高效配置,支持两种操作模式,操作简单且功能实用。


””””””””””””””””””””””””””””””””””””””””””
‘ HostHelper Hosts文件配置工具
‘ 作者:Tsybius2014
‘ 时间:2015年10月20日
‘ 描述:HostHelper 是一个Host文件配置工具,输入为Host文件地址、IP地址、域名
””””””””””””””””””””””””””””””””””””””””””

‘强制显式声明模块中的所有变量
Option Explicit

‘读取参数
Dim strHostAddr ‘Host文件地址
Dim strIpAddr ‘IP地址
Dim strName ‘主机名
Dim strOper ‘操作类型 cover:写入 append:追加
If WScript.Arguments.Count <> 4 Then
WScript.Echo “参数错误”
WScript.Quit
Else
‘读入参数
strHostAddr=WScript.Arguments(0) ‘参数1:Host文件地址
strIpAddr=WScript.Arguments(1) ‘参数2:IP地址
strName=WScript.Arguments(2) ‘参数3:主机名
strOper=WScript.Arguments(3) ‘参数4:写入策略 cover:覆盖 append:追加
‘覆盖:排他性加入
‘追加:在文件末尾添加IP地址与主机名对应关系
‘判断写入策略
Dim strOperName
If strOper=”cover” Then
strOperName=”覆盖”
ElseIf strOper=”append” Then
strOperName=”追加”
Else
WScript.Echo “非法的写入策略!”
WScript.Quit
End If
‘展示输入信息
WScript.Echo “Host文件地址:” & strHostAddr
WScript.Echo “IP地址:” & strIpAddr
WScript.Echo “主机名:” & strName
WScript.Echo “写入策略:” & strOperName
WScript.Echo “”
End If

Dim FSO
Set FSO=CreateObject(“Scripting.FileSystemObject”)
Const ForReading=1, ForWriting=2, ForAppending=8

‘遍历Host文件,判断是否已有指定的Host值
Dim file
Set file=FSO.OpenTextFile(strHostAddr)
Dim strLine
Dim bHostAlreadyExist
bHostAlreadyExist=False
Do While file.AtEndOfStream <> True
strLine=LTrim(file.ReadLine)
If Not Left(strLine, 1)=”#” Then
Dim Array
Array=Split(strLine, ” “, -1, 1)
If UBound(Array) >=1 Then
‘IP一样且域名一样,则认为要配置的Host已存在
If Array(0)=strIpAddr And Array(1)=strName Then
bHostAlreadyExist=True
Exit Do
End If
Else
End If
‘WScript.Echo strLine
Else
End If
Loop
file.Close

If bHostAlreadyExist Then
WScript.Echo “您要配置的Host已存在!”
WScript.Quit
End If

‘将IP地址与域名的对应关系写入到Host
If strOper=”cover” Then

‘写入策略:覆盖
Dim fileRead
Set fileRead=FSO.OpenTextFile(strHostAddr)
Dim strContent
strContent=fileRead.ReadAll()
fileRead.Close
Dim ArrayLine
ArrayLine=Split(strContent, vbCrlf, -1, 1)
Dim i
Dim strArrayEachLine
For i=0 To UBound(ArrayLine)
ArrayLine(i)=Trim(ArrayLine(i))
If Not Left(ArrayLine(i), 1)=”#” Then
strArrayEachLine=Split(ArrayLine(i), ” “, -1, 1)
If UBound(strArrayEachLine) >=1 Then
If strArrayEachLine(1)=strName Then
ArrayLine(i)=”#” & ArrayLine(i)
End If
End If
End If
Next
strContent=Join(ArrayLine, vbCrlf)
strContent=strContent & vbCrlf & strIpAddr & ” ” & strName
Dim fileCover
Set fileCover=FSO.OpenTextFile(strHostAddr, ForWriting, False)
fileCover.Write strContent
fileCover.Close
WScript.Echo “覆盖完毕”

ElseIf strOper=”append” Then

‘写入策略:追加
Dim fileAppend
Set fileAppend=FSO.OpenTextFile(strHostAddr, ForAppending, False)
fileAppend.WriteLine
fileAppend.WriteLine strIpAddr & ” ” & strName
WScript.Echo “追加完毕”
fileAppend.Close

End If

© 版权声明

相关文章