在net中提供了一些类来显示和控制Windows系统上的服务,并可以实现对远程计算机服务服务的访问,如SystemServiceProcess命名空间下面的ServiceController 类,SystemManagement下面的一些WMI *** 作的类。虽然用ServiceController可以很方便的实现对服务的控制,而且很直观、简洁和容易理解。但是我认为他的功能同通过WMI来 *** 作服务相比,那可能就有些单一了,并且对多个服务的 *** 作可能就比较麻烦,也无法列出系统中的所有服务的具体数据。这里要讲的就是如何使用SystemManagement组件来 *** 作远程和本地计算机上的服务。
WMI作为Windows 2000 *** 作系统的一部分提供了可伸缩的,可扩展的管理架构公共信息模型(CIM)是由分布式管理任务标准协会(DMTF)设计的一种可扩展的、面向对象的架构,用于管理系统、网络、应用程序、数据库和设备。Windows管理规范也称作CIM for Windows,提供了统一的访问管理信息的方式。如果需要获取详细的WMI信息请读者查阅MSDN。SystemManagement组件提供对大量管理信息和管理事件集合的访问,这些信息和事件是与根据 Windows 管理规范 (WMI) 结构对系统、设备和应用程序设置检测点有关的。
但是上面并不是我们最关心的,下面才是我们需要谈的话题。毫无疑问,我们要引用SystemManagementDll程序集,并要使用SystemManagement命名空间下的类,如ManagementClass,ManagementObject等。下面用一个名为Win32ServiceManager的类把服务的一些相关 *** 作包装了一下,代码如下:
using System;
using SystemManagement;
namespace ZZWmi
{
public class Win32ServiceManager
{ private string strPath;private ManagementClass managementClass;public Win32ServiceManager():this("",null,null){
}
public Win32ServiceManager(string host,string userName,string password)
{thisstrPath = "\\\\"+host+"\\root\\cimv2:Win32_Service";
thismanagementClass = new ManagementClass(strPath);if(userName!=null&&userNameLength>0)
{
ConnectionOptions connectionOptions = new ConnectionOptions();connectionOptionsUsername = userName;
connectionOptionsPassword = password;
ManagementScope managementScope = new ManagementScope( "\\\\" +host+ "\\root\\cimv2",connectionOptions) ;
thismanagementClassScope = managementScope;
}
}
// 验证是否能连接到远程计算机
public static bool RemoteConnectValidate(string host,string userName,string password){
ConnectionOptions connectionOptions = new ConnectionOptions();connectionOptionsUsername = userName;
connectionOptionsPassword = password;
ManagementScope managementScope = new ManagementScope( "\\\\" +host+ "\\root\\cimv2",connectionOptions) ;
try
{
managementScopeConnect();}
catch
{
}
return managementScopeIsConnected;}
// 获取指定服务属性的值
public object GetServiceValue(string serviceName,string propertyName){
ManagementObject mo = thismanagementClassCreateInstance();moPath = new ManagementPath(thisstrPath+"Name=\""+serviceName+"\"");return mo[propertyName];}
// 获取所连接的计算机的所有服务数据
public string [,] GetServiceList()
{
string [,] services = new string [thismanagementClassGetInstances()Count,4];int i = 0;
foreach(ManagementObject mo in thismanagementClassGetInstances())
{
services[i,0] = (string)mo["Name"];services[i,1] = (string)mo["DisplayName"];
services[i,2] = (string)mo["State"];
services[i,3] = (string)mo["StartMode"];
i++;
}
return services;}
// 获取所连接的计算机的指定服务数据
public string [,] GetServiceList(string serverName)
{
return GetServiceList(new string []{serverName});}
// 获取所连接的计算机的的指定服务数据
public string [,] GetServiceList(string [] serverNames)
{
string [,] services = new string [serverNamesLength,4];
ManagementObject mo = thismanagementClassCreateInstance();
for(int i = 0;i<serverNamesLength;i++)
{
moPath = new ManagementPath(thisstrPath+"Name=\""+serverNames[i]+"\"");
services[i,0] = (string)mo["Name"];
services[i,1] = (string)mo["DisplayName"];
services[i,2] = (string)mo["State"];
services[i,3] = (string)mo["StartMode"];
} return services;}
// 停止指定的服务
public string StartService(string serviceName)
{ string strRst = null;
ManagementObject mo = thismanagementClassCreateInstance();moPath = new ManagementPath(thisstrPath+"Name=\""+serviceName+"\"");
try
{if((string)mo["State"]=="Stopped")//!(bool)mo["AcceptStop"]moInvokeMethod("StartService",null);
}
catch(ManagementException e){ strRst =eMessage; }
return strRst;
}
// 暂停指定的服务
public string PauseService(string serviceName)
{
string strRst = null;
ManagementObject mo = thismanagementClassCreateInstance();moPath = new ManagementPath(thisstrPath+"Name=\""+serviceName+"\"");
try{
//判断是否可以暂停
if((bool)mo["acceptPause"]&&(string)mo["State"]=="Running")moInvokeMethod("PauseService",null);}
catch(ManagementException e){
strRst =eMessage; }
return strRst;}
// 恢复指定的服务
public string ResumeService(string serviceName)
{
string strRst = null;
ManagementObject mo = thismanagementClassCreateInstance();
moPath = new ManagementPath(thisstrPath+"Name=\""+serviceName+"\"");
try
{
//判断是否可以恢复
if((bool)mo["acceptPause"]&&(string)mo["State"]=="Paused")moInvokeMethod("ResumeService",null);}
catch(ManagementException e){strRst =eMessage;
}
return strRst;}
// 停止指定的服务
public string StopService(string serviceName)
{ string strRst = null;
ManagementObject mo = thismanagementClassCreateInstance();
moPath = new ManagementPath(thisstrPath+"Name=\""+serviceName+"\"");
try
{//判断是否可以停止
if((bool)mo["AcceptStop"])//(string)mo["State"]=="Running"
moInvokeMethod("StopService",null);
}
catch(ManagementException e)
{
strRst =eMessage; }
return strRst;
}
}
}
在Win32ServiceManager中通过RemoteConnectValidate静态方法来测试连接成功与否;另外提供了GetServiceValue方法和GetServiceList方法以及它的重载来获取服务信息;后面的四个方法就是对服务的状态控制了。
/give @p 276 1 0
{AttributeModifiers:[{Operation:0,UUIDLeast:1,UUIDMost:1,Amount:90000000000,AttributeName:genericattackDamage,Name:Attack}],{display:{Name:"神之钻石剑",Lore:["仿佛有着神的力量"]},Unbreakable:1b
}
1、按下“Win + R”快捷键打开“运行”窗口,输入“servicesmsc ”并按下回车打开服务;
2、在服务列表中找到“WLAN AutoConfig”服务并双击打开服务属性;
3、将“启动类型”修改为“自动”,点击“启动”按钮打开该服务,然后点击确定即可。
服务无法启动:
1、如果出现无法开启的情况,我们可以进行修复,再次打开“运行”,输入“regedit”并按下回车打开注册表;
2、进入“注册表编辑器”窗口后,在左侧依次进入“HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\Ndisuio”,在右侧中找到“DisplayName”字符串值和“Start”DWORD值,没有的话自己新建;
3、双击打开“DisplayName”字符串值,将“数值数据”设置为“NDIS Usermode I/O Protocol”,点击确定;
4、然后打开“Start”值,将数值数据”更改为“2”,确保基数是“十六进制”,点击确定;
5、按下“Win + R”快捷键打开“运行”窗口,输入“cmd”按下回车打开命令提示符;
6、输入“netsh winsock reset”命令,按下回车执行,出现“成功地重置 Winsock 目录”提示后,重启电脑即可。
导入单个AD用户命令
New-ADUser -Name "周八" -Surname "周" -GivenName "八"-SamAccountName "20160219008" -UserPrincipalName " zhouba@KFGSCOMCN " -DisplayName "周八" -Description "周八" -Path "OU=资金处,OU=财务部,OU=开发公司,DC=KFGS,DC=COM,DC=CN" -AccountPassword(ConvertTo-SecureString "567@test" -AsPlainText -force ) -Enabled false
New-ADUser -Name "周八" -Surname "周" -GivenName "八" -UserPrincipalName " zhouba@KFGSCOMCN " -Path "OU=资金处,OU=财务部,OU=开发公司,DC=KFGS,DC=COM,DC=CN" -AccountPassword(ConvertTo-SecureString "567@test" -AsPlainText -force ) -Enabled false
批量导入用户
Import-Csv 'C:\usercsv' | ForEach-Object{New-ADUser -SamAccountName Surname -GivenName Name -Group UserPrincipalName -Path AccountPassword -Force) -Enabled 1 -ChangePasswordAtLogon 1}
表格的格式
注意点:CSV要以UTF-8保存,不然中文会乱码,执行命令会报错,我就深受其害(一定是将文档放到你需要执行命令的地方,然后在改文件的编码UTF-8,如果先改保存后,在移动到你执行命令的地方编码格式是无效的,执行命令会报错)。自己要清楚模版所对应的参数,不要填写错误。Enable 1,数字1表示启用账户,ChangePasswordAtLogon 1,数字1表示下一次登录需要修改密码。如果都改为数字0表示禁用账户,下一次登录不需要修改密码
附录:AD各字段的属性
Get-ADUser -Filter -SearchBase "ou=小的ou,ou=大的ou,dc=小的dc,dc=大的dc" | Select-Object -Property Name | Export-Csv -Encoding unicode xxcsv
获取AD用户 过滤 搜索底部 组织单位 组织单位 域控 选择对象 属性 用户名 导出csv 编码 csv档案名
批量导出AD用户
Get-ADUser -Filter -SearchBase "DC=KFGS, DC=COM, DC=CN" |Select-Object -Property SamAccountName, Surname, GivenName, Name, Group, UserPrincipalName, Path, AccountPassword, Enabled, ChangePasswordAtLogon | Export-Csv -Encoding unicode ADusercsv
注:导出的文件在当前用户目录下,如:C:\Users\Administrator
1、首先第一步就是进行启动Windows Server 2008 R2 *** 作系统,如图所示。点击任务栏"开始"按钮,用于打开任务栏开始菜单,如下图所示。
2、接着就是如图所示,唤出任务栏开始菜单。拖动右侧垂直滚动条,选择"计算机管理"项即可。
3、然后就是进行唤出"计算机管理"程序窗口,如图所示。选择"服务和应用程序"项,下步将进行禁用Remote Registry服务的 *** 作,如下图所示。
4、接着就是如图所示,选择"服务"项。鼠标右击"Remote Registry"图标,d出快捷菜单选择"属性"项即可。
5、然后就是d出"Remote Registry的属性"对话框,如图所示。点击"常规→启动类型"右侧向下箭头,如果启用则远程用户能修改此计算机上的注册表设置即可。
6、最后这时候注意的是会d出下拉列表选项。选择"启动"项,设置完成点击"确定"按钮,如下图所示。
建议使用这个getElementsByid( )来获取DIV的ID,getElementsByName( )是一般用来得到html自带的标签的,而且ID有惟一性不容易出错。直接:documentgetElementsByID("ID" )className。是用来改变这个DIV样式名称的
以上就是关于电脑问题:利用c#获取局域网服务器的ip以及对应的数据库全部的内容,包括:电脑问题:利用c#获取局域网服务器的ip以及对应的数据库、我的世界1.7.2如何用命令方块获取无法破坏,自定义名字,自定义属性的物品、此计算机没有运行Windows无线服务等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)