电脑问题:利用c#获取局域网服务器的ip以及对应的数据库

电脑问题:利用c#获取局域网服务器的ip以及对应的数据库,第1张

在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无线服务等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/9320147.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存