- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章利用vbs自动修改ip的代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
单位机房的系统需要重新安装,一共近300台设备,使用ghost网络克隆后,客户机重新设置ip是个麻烦的事情。我们使用的教学管理软件要求客户机必须有固定ip,单位5个机房如下(DNS:61.134.1.4,掩码为:255.255.255.0):
机房 。 |
起始ip 。 |
ip终止ip 。 |
网关 。 |
机器名 。 |
工作组 。 |
1号 。 |
192.168.1.1 。 |
100 。 |
254 。 |
No_100~No_160 。 |
S01 。 |
2号 。 |
192.168.1.101 。 |
200 。 |
254 。 |
No_200~No_260 。 |
S02 。 |
3号 。 |
192.168.3.1 。 |
80 。 |
254 。 |
No_300~No_360 。 |
S03 。 |
4号 。 |
192.168.3.81 。 |
160 。 |
254 。 |
No_400~No_460 。 |
S04 。 |
5号 。 |
192.168.3.161 。 |
240 。 |
254 。 |
No_500~No_560 。 |
S05 。 |
以下为vbs源码: 1.xp系统(测试通过,用户为Administrator,文件为E:\fxp.vbs,启动组建立快捷方式fxp.lnk以便开机后自动运行一次) 。
复制代码 代码如下
'/////主程序 dim msginf,machname'定义变量:对话框,机器名 msginf=msgbox("该程序只能执行1次,请在XP系统硬件安装完毕后执行!" &chr(13) & "是否继续?",65,"修改机器网络配置") '信息提示 if msginf=1 then ' 如果按确定,则 machname=inputon() ' 用函数inputon()分析 if machname<>"quit" then ' 如果返回值不等于"quit",则 wmitoip(machname) ' 运行函数wmitoip()设置机器信息 mreboot()'重启机器 end if end if '///重启机器 sub mreboot() dim fso,f1,f2 Set fso = CreateObject("Scripting.FileSystemObject") '删除启动组 if fso.fileexists("C:\Documents and Settings\Administrator\「开始」菜单\程序\启动\fxp.lnk") then set f1=fso.getfile("C:\Documents and Settings\Administrator\「开始」菜单\程序\启动\fxp.lnk") f1.delete end if '删除vbs文件 if fso.fileexists("e:\fxp.vbs") then set f2=fso.getfile("e:\fxp.vbs") f2.delete end if Set WshShell = Wscript.CreateObject("Wscript.Shell") 'WshShell.Run ("shutdown.exe -r -t 5") ' 重启 end sub '///生成计算机名 function inputon() ' 函数inputon() dim t ' 变量 while true ' 循环直到退出函数 t=inputbox("按一下规则输入:" & chr(13) & chr(13) & "第1位代表机房号" & chr(13) & "第2、3位代表机器号" & chr(13) & "教师机用00代表" & chr(13) & "如:123代表1号机房23号机" & chr(13) & "请确保输入正确!!","请输入3位机器标识!","") ' 输入机算机名,默认值为空 if t="" then ' 如果t等于空(按了取消键),则 inputon="quit" ' 返回值为"quit" exit function ' 退出程序 end if if len(t)=3 then ' 计算机号的长度为3位 if Cint(t)>=100 and Cint(t)<580 then ' 验证 inputon=t ' 返回需要的计算机名 exit function end if end if wend end function '///修改机器ip、掩码、网关、工作组、机器名 sub wmitoip(t) strComputer="." strmask="255.255.255.0" Dim lt,rt' 变量 dim ipv,gateway,lan 'ip,网关,工作组 lt=cint(left(t,1))'机号左1位数字值 rt=cint(right(t,2)) ' 机号右两位数字值 if lt=1 or lt=2 then'判断网关 gateway="192.168.1.254" else gateway="192.168.3.254" end if if lt=1 then '1号机房 lan="S01" ipv="192.168.1." if rt=0 then '教师机 ipv=ipv+"100" else'学生机 ipv=ipv+Cstr(rt) end if end if if lt=2 then '2号机房 lan="S02" ipv="192.168.1." if rt=0 then '教师机 ipv=ipv+"200" else'学生机 rt=rt+100 ipv=ipv+Cstr(rt) end if end if if lt=3 then '3号机房 lan="S03" ipv="192.168.3." if rt=0 then '教师机 ipv=ipv+"80" else'学生机 ipv=ipv+Cstr(rt) end if end if if lt=4 then '4号机房 lan="S04" ipv="192.168.3." if rt=0 then '教师机 ipv=ipv+"160" else'学生机 rt=rt+80 ipv=ipv+Cstr(rt) end if end if if lt=5 then '5号机房 lan="S05" ipv="192.168.3." if rt=0 then '教师机 ipv=ipv+"240" else'学生机 rt=rt+160 ipv=ipv+Cstr(rt) end if end if Set objWMIService=GetObject("winmgmts:\\" & strComputer & "\root\cimv2") Set colNetAdapters=objWMIService.ExecQuery("Select * from Win32_NetworkAdapterConfiguration where IPEnabled=TRUE") strIPAddress=Array(ipv) strSubnetMask=Array(strmask) strGateway = Array(gateway) '修改网关 'strGatewayMetric = Array(1) '跃点数 strDNS=Array("61.134.1.4") For Each objNetAdapter in colNetAdapters errEnable=objNetAdapter.EnableStatic(strIPAddress, strSubnetMask)'ip,掩码 errGateways = objNetAdapter.SetGateways(strGateway) '网关 errDns=objNetAdapter.SetDNSServerSearchOrder(strDNS)'dns Next Set objWMIService = GetObject("winmgmts:" _ & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2") Set colComputers = objWMIService.ExecQuery _ ("Select * from Win32_ComputerSystem") For Each objComputer in colComputers err = ObjComputer.Rename("No_" & t)'机器名 ReturnValue = objComputer.JoinDomainOrWorkGroup("S0" & left(t,1))'工作组 Next end sub 。
2.98系统 98系统可以生成ip.reg注册表文件,导入后就可以了,源码如下(主体思路,这次没有98系统,所以未完成,可参考xp系统的改进): 。
复制代码 代码如下
'/////主程序 dim msginf,machname'定义变量:对话框,机器名 msginf=msgbox("生成注册表文件,是否继续?",65,"getreg") '信息提示 if msginf=1 then ' 如果按确定,则 machname=inputon() ' 用函数inputon()分析 if machname<>"quit" then ' 如果返回值不等于"quit",则 setreg(machname) ' 运行函数setreg()生成注册表ip.reg end if end if '///生成计算机名 function inputon() ' 函数inputon() dim t ' 变量 while true ' 循环直到退出函数 t=inputbox("按一下规则输入:" & chr(13) & chr(13) & "第1位代表机房号" & chr(13) & "第2、3位代表机器号" & chr(13) & "教师机用00代表" & chr(13) & "如:123代表1号机房23号机" & chr(13) & "请确保输入正确!!","请输入3位机器标识!","") ' 输入机算机名,默认值为空 if t="" then ' 如果t等于空(按了取消键),则 inputon="quit" ' 返回值为"quit" exit function ' 退出程序 end if if len(t)=3 then ' 计算机号的长度为3位 if Cint(t)>=100 and Cint(t)<580 then ' 验证 inputon=t ' 返回需要的计算机名 exit function end if end if wend end function '///生成注册文件 sub setreg(t) ' 生成注册表,t为机器号 Dim fso, f1,f2,lt,rt' 变量 dim ipv,gateway,lan 'ip,网关,工作组 lt=cint(left(t,1))'机号左1位数字值 rt=cint(right(t,2)) ' 机号右两位数字值 if lt=1 or lt=2 then'判断网关 gateway="192.168.1.254" else gateway="192.168.3.254" end if if lt=1 then '1号机房 lan="S01" ipv="192.168.1." if rt=0 then '教师机 ipv=ipv+"100" else'学生机 ipv=ipv+Cstr(rt) end if end if if lt=2 then '2号机房 lan="S02" ipv="192.168.1." if rt=0 then '教师机 ipv=ipv+"200" else'学生机 rt=rt+100 ipv=ipv+Cstr(rt) end if end if if lt=3 then '3号机房 lan="S03" ipv="192.168.3." if rt=0 then '教师机 ipv=ipv+"80" else'学生机 ipv=ipv+Cstr(rt) end if end if if lt=4 then '4号机房 lan="S04" ipv="192.168.3." if rt=0 then '教师机 ipv=ipv+"160" else'学生机 rt=rt+80 ipv=ipv+Cstr(rt) end if end if if lt=5 then '5号机房 lan="S05" ipv="192.168.3." if rt=0 then '教师机 ipv=ipv+"240" else'学生机 rt=rt+160 ipv=ipv+Cstr(rt) end if end if Set fso = CreateObject("Scripting.FileSystemObject") if fso.fileexists("e:\ip.reg") then set f2=fso.getfile("e:\ip.reg") f2.delete end if '如果存在ip.reg,先删了 set f1 = fso.CreateTextFile("e:\ip.reg", True) ' 建立文件ip.cfg 'f1.WriteLine("REGEDIT4") ' 以下为生成注册表 f1.WriteLine("Windows Registry Editor Version 5.00") f1.WriteBlankLines(1) f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\ComputerName\ComputerName]") f1.WriteLine(chr(34) & "ComputerName" & chr(34) & "=" & chr(34) & t & chr(34)) ' 计算机名 f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Class\NetTrans\0000]") f1.WriteLine(chr(34) & "IPAddress" & chr(34) & "=" & chr(34) & ipv & chr(34)) ' IP f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Class\NetTrans\0000]") f1.WriteLine(chr(34) & "DefaultGateway" & chr(34) & "=" & chr(34) & gateway & chr(34)) ' 网关 f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Class\NetTrans\0000]") f1.WriteLine(chr(34) & "IPMask" & chr(34) & "=" & chr(34) & "255.255.255.0" & chr(34)) ' 子网掩码 f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\VxD\VNETSUP]") f1.WriteLine(chr(34) & "Comment" & chr(34) & "=" & chr(34) & t & chr(34)) ' 计算机说明 f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\VxD\VNETSUP]") f1.WriteLine(chr(34) & "ComputerName" & chr(34) & "=" & chr(34) & t & chr(34)) ' 计算机名 f1.WriteLine("[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\VxD\VNETSUP]") f1.Writeline(chr(34) & "Workgroup" & chr(34) & "=" & chr(34) & lan & chr(34)) ' 工作组 end sub 。
最后此篇关于利用vbs自动修改ip的代码的文章就讲到这里了,如果你想了解更多关于利用vbs自动修改ip的代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我使用 IBM Personal Communications 12.0.3.0 的宏记录器制作了一个凭据输入宏。它只是在调用时输入我的用户名和密码。 sub Credentials() Dim
该批处理更改了 vbs 代码,使其无法供 vbs 使用。我该如何解决这个问题? 批号: echo Const HIGH = 128 >> prio.vbs echo strComputer = "."
我有 2 个 vbs 文件。 A.vbs: Class test public a public b End Class B.vbs: Dim objShell Set objShell =
以下是我用来尝试在 IIS 6 中创建虚拟目录的条目: [Run] Filename: {tmp}\cscript.exe mkvirtdir.vbs; Parameters: "-c LocalHo
核心vbs代码 ? 1
对于vbs中ping的实现可以通过两种方式 : 1、调用系统ping命令; 2、使用wmi查询pingstate类处理。 1、调用系统ping命令
在看vb开发,看到二维数组时突发奇想用二维数组作为游戏关卡; 1. 选择操作: 游戏开始时会提示选择注册, 登录, 退出三种选项, 2.注册: 注册成功会将用户账户与密码存入用户数据txt文档中
复制指定文件到指定目录下 核心代码 ? 1
复制代码 代码如下: On Error Resume Next Dim WshShell, QQPath, QQselect set wshshell=createobject("
运行前请确定你的电脑安装了word。 复制代码 代码如下: i=0 set wshshell=createobject("wscript.shell") Set objWo
参考代码一: 复制代码 代码如下: Function DeleteLog( ) Dim objFSO, objFolder, strPath,
挺实用的一段代码,用来深入学习vbs,确实不错咯。 复制代码 代码如下: On Error Resume Next '忽略所有错误 Dim filename '声明变量 Di
话说还是闲来练手,初步实现了自己认为的“多线程”下载。(至于是不是多线程,可以参考12楼链接) 为避免冗余,省了一些错误检查。我觉得没多大实际用途,有兴趣的兄弟一起学习讨论呗。欢迎大家指正: 复制
复制代码 代码如下: set oDOM = WScript.GetObject("http://ipseeker.cn//") flag=0 for i=1 to 10 &n
复制代码 代码如下: on error resume next url = " http://www.bathome.net/logging.php?action=login"
效果图: 代码都封装成函数了,方便调用: 复制代码 代码如下: Key = "www-enun-net" '不要用数字
打开狗狗影视,搜索自己需要的资源,资源类型选:电驴,如下图: 我找到一个 19.75gb 的: 点开它,出现如下图的界面,可以看到正常下载地址已被屏蔽。我们复制地址栏中的网址,备用。
最近相关的备份比较频繁,为了校验文件的完整性,老是要打开某文件HASH校验工具,比较麻烦,于是乎写了这个东东,文件较大时计算有点慢,文件的MD5值保存在剪贴板!效果如图: 使用方法: 1.先
CMD当前路径 复制代码 代码如下: test = createobject("Scripting.FileSystemObject").GetF
For Next 语句的基本结构为: 复制代码 代码如下: For counter = start To end [Step step] [statements] [Exit For] [st
我是一名优秀的程序员,十分优秀!