将以下命令保存为 HostsModify.ps1,然后执行即可
1 #该脚本用来添加hosts解析记录。脚本在执行的时候会判断当前用户是否为管理员,如果不是则弹出提示框口,要求输入相应密码 2 If (-NOT ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] "Administrator")) 3 { 4 $arguments = "& '" + $myinvocation.mycommand.definition + "'" 5 Start-Process powershell -Credential administrator -WindowStyle Hidden -ArgumentList $arguments 6 Break 7 } 8 9 #下面为要执行的命令 10 #在hosts中添加解析记录 11 $line = "127.0.0.1 www.sapien.com" 12 $file = "$env:windir\system32\drivers\etc\hosts" 13 out-file -InputObject $line -filepath $file -append -Encoding default
删除hosts中添加的解析记录
1 #删除hosts中添加的解析记录 2 $line = "127.0.0.1 www.sapien.com" 3 $file = "$env:windir\system32\drivers\etc\hosts" 4 #$contents = gc $file | ? {!($_.contains($line))} #选择不包含$line的行 5 $contents = gc $file | ? {$_ -ne $line} #选择不等于$line的行 6 clear-content $file 7 out-file -InputObject $contents -filepath $file -append -Encoding default
###################################################
脚本直接以管理员权限运行(将管理员账户和密码写入脚本中)
1 #该脚本用来在hosts文件中添加解析记录。如果当前用户不是管理员,则会直接以管理员权限运行(可以将管理员账户和密码写入脚本中) 2 If (-NOT ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] "Administrator")) 3 { 4 $UserName = "administrator" #定义管理员账户名称 5 $serverpass = "cmr" #定义管理员账户密码 6 $Password = ConvertTo-SecureString $serverpass -AsPlainText –Force 7 $cred = New-Object System.Management.Automation.PSCredential($UserName,$Password) 8 $arguments = "& '" + $myinvocation.mycommand.definition + "'" 9 Start-Process powershell -Credential $cred -WindowStyle Hidden -ArgumentList $arguments 10 Break 11 } 12 13 #下面为要执行的脚步命令 14 #在hosts中添加解析记录 15 $line = "127.0.0.1 www.sapien.com" 16 $file = "$env:windir\system32\drivers\etc\hosts" 17 out-file -InputObject $line -filepath $file -append -Encoding default
Start-Process -Verb runas 这里的 runas是以管理员权限运行,但是前提是当前用户必须已经是管理员,效果等同于:
参考:http://www.pstips.net/force-script-run-as-admin.html