重启网卡的几种方法(命令行,API,

1.重启windows网卡命令

rem 禁用网卡
netsh interface set interface 本地连接 disabled
rem 启用网卡

netsh interface set interface 本地连接 enabled

2.根据相关信息作出如下修改

rem 禁用网卡
netsh interface set interface 以太网 disabled
rem 启用网卡

netsh interface set interface 以太网 enabled

三、以下是网上找到的C++代码,

调试OK,需要管理员模式,requireAdministrator (/level=‘requireAdministrator‘),不知道原文地址了,着时尴尬

方法一,VS2015 ANSI

[cpp] view plain copy

print?

  1. // lan2.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #include <stdio.h>
  5. #include <windows.h>
  6. #include <Setupapi.h>
  7. #include <objbase.h>
  8. #pragma comment(lib, "Setupapi.lib")
  9. void EnumDevices(HDEVINFO hDevInfo)
  10. {
  11. SP_DEVINFO_DATA DeviceInfoData = { sizeof(SP_DEVINFO_DATA) };
  12. LPOLESTR guid;
  13. char devName[128];
  14. char instanceId[128];
  15. for (int i = 0; SetupDiEnumDeviceInfo(hDevInfo, i, &DeviceInfoData); i++)
  16. {
  17. StringFromCLSID(DeviceInfoData.ClassGuid, &guid);
  18. SetupDiClassNameFromGuid(&DeviceInfoData.ClassGuid, devName, 128, NULL);
  19. //printf("%s\n", devName);
  20. ;       if (!strcmp(devName, "Net"))
  21. {
  22. SetupDiGetDeviceInstanceId(hDevInfo, &DeviceInfoData, instanceId, 128, NULL);
  23. //printf("instanceId1:%s\n", instanceId);
  24. if (!strncmp(instanceId, "PCI", 3))
  25. {
  26. //wprintf(L"guid:%s\n", guid);
  27. //  printf("devName:%s\n", devName);
  28. //  printf("instanceId2:%s\n", instanceId);
  29. SP_PROPCHANGE_PARAMS params = { sizeof(SP_CLASSINSTALL_HEADER) };
  30. params.ClassInstallHeader.InstallFunction = DIF_PROPERTYCHANGE;
  31. params.Scope = DICS_FLAG_CONFIGSPECIFIC;
  32. <span style="color:#ff0000;">                params.StateChange = DICS_DISABLE;
  33. </span><span style="color:#33ff33;">                //params.StateChange = DICS_ENABLE;
  34. </span>             params.HwProfile = 0;
  35. SetupDiSetClassInstallParams(hDevInfo, &DeviceInfoData, (SP_CLASSINSTALL_HEADER*)¶ms, sizeof(SP_PROPCHANGE_PARAMS));
  36. SetupDiChangeState(hDevInfo, &DeviceInfoData);
  37. }
  38. }
  39. CoTaskMemFree(guid);
  40. }
  41. }
  42. int main(int argc, char* argv[])
  43. {
  44. HDEVINFO hDevInfo = INVALID_HANDLE_VALUE;
  45. hDevInfo = SetupDiGetClassDevs(NULL, NULL, NULL, DIGCF_PRESENT | DIGCF_ALLCLASSES);
  46. if (INVALID_HANDLE_VALUE == hDevInfo)
  47. return GetLastError();
  48. EnumDevices(hDevInfo);
  49. SetupDiDestroyDeviceInfoList(hDevInfo);
  50. return 0;
  51. }

UNICODE mode

[cpp] view plain copy

print?

  1. // lan2.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #include <stdio.h>
  5. #include <windows.h>
  6. #include <Setupapi.h>
  7. #include <objbase.h>
  8. #pragma comment(lib, "Setupapi.lib")
  9. int main(int argc, char* argv[])
  10. {
  11. HDEVINFO hDevInfo = INVALID_HANDLE_VALUE;
  12. hDevInfo = SetupDiGetClassDevs(NULL, NULL, NULL, DIGCF_PRESENT | DIGCF_ALLCLASSES);
  13. if (INVALID_HANDLE_VALUE == hDevInfo)
  14. return GetLastError();
  15. //EnumDevices(hDevInfo);
  16. SP_DEVINFO_DATA DeviceInfoData = { sizeof(SP_DEVINFO_DATA) };
  17. LPOLESTR guid;
  18. wchar_t devName[128];
  19. wchar_t instanceId[128];
  20. for (int i = 0; SetupDiEnumDeviceInfo(hDevInfo, i, &DeviceInfoData); i++)
  21. {
  22. StringFromCLSID(DeviceInfoData.ClassGuid, &guid);
  23. SetupDiClassNameFromGuid(&DeviceInfoData.ClassGuid, devName, 128, NULL);
  24. // printf("%s\n", devName);
  25. if (!wcscmp(devName, _T("Net")))
  26. {
  27. SetupDiGetDeviceInstanceId(hDevInfo, &DeviceInfoData, instanceId, 128, NULL);
  28. //printf("instanceId1:%s\n", instanceId);
  29. if (!wcsncmp(instanceId, _T("PCI"), 3))
  30. {
  31. //wprintf(L"guid:%s\n", guid);
  32. //  printf("devName:%s\n", devName);
  33. //  printf("instanceId2:%s\n", instanceId);
  34. SP_PROPCHANGE_PARAMS params = { sizeof(SP_CLASSINSTALL_HEADER) };
  35. params.ClassInstallHeader.InstallFunction = DIF_PROPERTYCHANGE;
  36. params.Scope = DICS_FLAG_CONFIGSPECIFIC;
  37. <span style="color:#ff0000;">                // params.StateChange = DICS_DISABLE;
  38. </span><span style="color:#009900;">                params.StateChange = DICS_ENABLE;
  39. </span>             params.HwProfile = 0;
  40. SetupDiSetClassInstallParams(hDevInfo, &DeviceInfoData, (SP_CLASSINSTALL_HEADER*)¶ms, sizeof(SP_PROPCHANGE_PARAMS));
  41. SetupDiChangeState(hDevInfo, &DeviceInfoData);
  42. }
  43. }
  44. CoTaskMemFree(guid);
  45. }
  46. SetupDiDestroyDeviceInfoList(hDevInfo);
  47. return 0;
  48. }

方法二.VS2015 UNICODE

SetupDiCallClassInstaller函数需要编译64位程序运行64位系统

[cpp] view plain copy

print?

  1. // LAN.cpp : 定义控制台应用程序的入口点。
  2. //
  3. #include "stdafx.h"
  4. #include <windows.h>
  5. #include <SetupAPI.h>
  6. #include <stdio.h>
  7. #include <tchar.h>
  8. #define ERROR_IN_WOW64 (APPLICATION_ERROR_MASK|ERROR_SEVERITY_ERROR|0x235)
  9. #pragma comment(lib,"setupapi.lib")
  10. DWORD CtrlNetcard(BOOL bStatus);
  11. void _tmain(int arg, TCHAR** argv)
  12. {
  13. BOOL b = FALSE;
  14. DWORD err = 0;
  15. if (2 == arg)
  16. {
  17. argv++;
  18. if (!_tcsicmp(TEXT("enable"), *argv))
  19. {
  20. b = TRUE;
  21. err = CtrlNetcard(TRUE);
  22. }
  23. else if (!_tcsicmp(TEXT("disable"), *argv))
  24. {
  25. b = FALSE;
  26. err = CtrlNetcard(FALSE);
  27. }
  28. else
  29. {
  30. goto main_end;
  31. }
  32. _tprintf(_T("\n%s NetAdapter %s !\n"),
  33. b ? TEXT("Enable") : TEXT("Disable"),
  34. err ? TEXT("fail") : TEXT("success"));
  35. return;
  36. }
  37. main_end:
  38. _tprintf(TEXT("\nenable NetCard: enable"));
  39. _tprintf(TEXT("\ndisable NetCard: disable\n"));
  40. }
  41. DWORD CtrlNetcard(BOOL bStatus)
  42. {
  43. LPCTSTR HardwareId = TEXT("{4D36E972-E325-11CE-BFC1-08002BE10318}");
  44. GUID g = { 0X4D36E972, 0XE325, 0X11CE,{ 0XBF, 0XC1, 0X08, 0X00, 0X2B, 0XE1, 0X03, 0X18 } };
  45. DWORD NewState = 0;
  46. //调用ddk函数,来禁用网卡
  47. DWORD i = 0, err = 0;
  48. HDEVINFO hDevInfo = NULL;
  49. SP_DEVINFO_DATA spDevInfoData = { 0 };
  50. NewState = bStatus ? DICS_ENABLE : DICS_DISABLE;
  51. //访问系统的硬件库
  52. hDevInfo = SetupDiGetClassDevs(NULL, TEXT("PCI"), NULL, DIGCF_ALLCLASSES | DIGCF_PRESENT);
  53. if (INVALID_HANDLE_VALUE == hDevInfo)
  54. {
  55. _tprintf(TEXT("访问系统硬件出错!"));
  56. return GetLastError();
  57. }
  58. //枚举硬件,获得需要的接口
  59. spDevInfoData.cbSize = sizeof(SP_DEVINFO_DATA);
  60. memcmp(&(spDevInfoData.ClassGuid), &g, sizeof(GUID));
  61. for (i = 0; SetupDiEnumDeviceInfo(hDevInfo, i, &spDevInfoData); i++)
  62. {
  63. PBYTE PropertyBuffer = NULL;
  64. DWORD PropertyBufferSize = 0;
  65. //获得硬件的属性值
  66. while (!SetupDiGetDeviceRegistryProperty(
  67. hDevInfo,
  68. &spDevInfoData,
  69. SPDRP_CLASSGUID,
  70. NULL,
  71. PropertyBuffer,
  72. PropertyBufferSize,
  73. &PropertyBufferSize))
  74. {
  75. if (ERROR_INSUFFICIENT_BUFFER == GetLastError())
  76. {
  77. if (PropertyBuffer)
  78. {
  79. free(PropertyBuffer);
  80. }
  81. PropertyBuffer = (PBYTE)malloc(PropertyBufferSize);
  82. }
  83. else
  84. {
  85. break;
  86. }
  87. }
  88. if (!PropertyBuffer)
  89. {
  90. continue;
  91. }
  92. //MessageBox(NULL, (LPCTSTR)PropertyBuffer, L"提示", MB_OK);
  93. if (!_tcsicmp(HardwareId, (LPTSTR)PropertyBuffer))
  94. {
  95. SP_PROPCHANGE_PARAMS spPropChangeParams;
  96. //printf("PropertyBuffer ok\n");
  97. free(PropertyBuffer);
  98. spPropChangeParams.ClassInstallHeader.cbSize = sizeof(SP_CLASSINSTALL_HEADER);
  99. spPropChangeParams.ClassInstallHeader.InstallFunction = DIF_PROPERTYCHANGE;
  100. spPropChangeParams.Scope = DICS_FLAG_GLOBAL;
  101. spPropChangeParams.StateChange = NewState;
  102. if (!SetupDiSetClassInstallParams(hDevInfo, &spDevInfoData, (SP_CLASSINSTALL_HEADER*)&spPropChangeParams, sizeof(spPropChangeParams)))
  103. {
  104. err = GetLastError();
  105. printf("SetupDiSetClassInstallParams:%d\n", GetLastError());
  106. goto cleanup_DeviceInfo;
  107. }
  108. if (!SetupDiCallClassInstaller(DIF_PROPERTYCHANGE, hDevInfo, &spDevInfoData))
  109. {
  110. err = GetLastError();
  111. printf("SetupDiCallClassInstaller:%x\n", GetLastError());
  112. goto cleanup_DeviceInfo;
  113. }
  114. }
  115. else
  116. {
  117. //printf("PropertyBuffer error\n");
  118. free(PropertyBuffer);
  119. }
  120. }
  121. cleanup_DeviceInfo:
  122. SetupDiDestroyDeviceInfoList(hDevInfo);
  123. return err;
  124. }

方法三.网上相关:http://blog.csdn.net/buyicn/article/details/6438635

此前,提到为了实现修改IP(一网卡对应多个IP,不重启电脑让修改立即生效),我尝试在VC6.0上调试采用WMI实现的修改IP的程序,编译不过的情况屡屡出现,在网上搜索了很久就是没有找到彻底的解决方法,最后只好放弃通过WMI来设置IP了!

那么,另一个思路(修改注册表中IP项,然后重启网卡)是否能行呢?于是,继续寻求重启网卡的方法,没想到居然找到了一些不错的资料。现整理如下,供日后参考。

(1)《vc++ 修改IP地址DNS 附带源码》实例代码,来自csdn下载频道,我下载下来调试过了,貌似和我上面提及的思路一致:通过重启网卡来让设置的IP立即生效。

(2)《程序禁用启用网络/网卡》是一个封装好的函数,我复制到本地并适当修改之后,就调试通过了!正好是我想要的:)关于函数中的配置文件ConfigInfo.ini,其内容貌似如下所示:

[cpp] view plain copy

  1. [NETCARD]
  2. TYPE=PCI
  3. NAME=NVIDIA nForce Networking Controller

(3)《实战DeviceIoControl 之五:列举已安装的存储设备》这篇文章详细地介绍了如何访问设备,有代码有注释(作者另外的几篇《实战DeviceIoControl 》也很不错),是很好的入门教材!

(4)《Windows下不重启机器程序修改IP的三种方法》一篇总结性的文章,对几种实现方法做了简介,让我们有一个全局的认识。

网上应该还有好资料,等以后遇到了再整理!

http://blog.csdn.net/greless/article/details/70236969

时间: 2024-10-14 11:17:08

重启网卡的几种方法(命令行,API,的相关文章

Ubuntu14.04重启网卡的三种方法:

$ ifconfig -a 展示全部网卡 $ ifconfig enp2s0 up 启用网卡enp2s0 $ sudo vi /etc/network/interfaces auto enp2s0iface enp2s0 inet staticaddress 192.168.2.10network 255.255.255.0gateway 192.168.2.1 一.network利用root帐户 service networking restart 或者/etc/init.d/networki

Ubuntu重启网卡的三种方法

一.network利用root帐户# service network restart 或者/etc/init.d/networking restart 二.ifdown/ifup# ifdown eth0# ifup eth0 三.ifconfig# ifconfig eth0 down# ifconfig eth0 up Ubuntu14.04修改配置,重启网卡没有生效,出现如下问题: service  networking restart //重启网络服务stop: Job failed w

win7休眠的开启与关闭方法命令行操作和图文结合的鼠标操作

win7休眠的开启与关闭方法 从开始菜单中找到"附件→命令提示符",手工输入如下命令:powercfg -a,从这里可以清楚的看到,计算机是支持休眠的,显示"尚未启用休眠".仍然在命令提示符下进行操作,     开始休眠方法:手工键入如下命令: powercfg -hibernate on(关闭则为powercfg -hibernate off) 命令执行之后立即就可以生效,无需要重新启动系统,再次执行"powercfg -a"命令,这里会提示当

js调试系列: 控制台命令行API

上次初步介绍了什么是控制台<js调试系列: 初识控制台>,以及简单的 console.log 输出信息.最后还有两个小问题,我们就当回顾,来看下怎么操作吧. 先打开百度,然后按 F12 打开后,如果不是 Console 项的就点击 Console 这项,因为我们要在控制台操作..看到如下内容:好了我们先清空内容,可以右击选 Clear console 菜单,或者输入 clear() 都行.接着,我们输入 document.getElementById('kw1'); 然后回车,就可以看到 id

在红帽RHEL7.0里配置网卡的四种方法

第一种方法 :采用vim编辑器来配置: 1.  如下图的步骤所示: 2.  输入这个命令后进行配置成下方图片里的内容: 3.  然后退出vim 编辑器,然后重新启动一下网络服务配置: 4.这些配置完后,我们现在可以来看看是否能够来连通主机,在这之前,我要在物理机上进行网络适配器更改: 5.出现步骤四中的第三张图片所示的情况,这就说明网卡配置成功了.注意这里我配置网卡是网络适配器在仅主机模式下进行实验的. 第二种方法:1.使用nmtui命令来配置 2.配置好上述图示的步骤后,最好是检查一下ONBO

Mac OS X 中一些常用的命令行技巧

一.网络设置相关 1.网卡的物理地址的动态重置 出于某些需求,例如网络中的 IP 地址或网络帐号与网卡物理地址绑定,使得多个设备无法切换上网,可尝试临时更改物理地址.不过,系统偏好设置是不能修改网卡物理地址的,这就是命令行的用武之地了.具体来说,若心中已有想修改的物理地址,例如 00:1f:3c:93:b5:99,可执行 $ sudo ifconfig en1 ether 00:1f:3c:93:b5:99 来临时修改网卡的物理地址:若没有物理地址,只是想临时启用尝试一下,可用 openssl

Linux命令行简介

1 Linux系统命令操作语法的格式 命令_[参数选项]_[文件或路径]    其中 _ 至少一个空格    如:rm -f /etc/hosts    其中/etc/hosts完整路径不带空格   中括号表示可选的,即命令的参数和路径文件都是可选的,参数选项表示使用一个命令的不同功能,比如,可以删除一个文件和创建一个文件 2 # 是超级管理员的提示符root对应的提示符   $   普通用户oldboy对应的提示符   @  是一个提示符  ~ 当前用户所在的家目录 [[email prote

聊聊默认支持的各种配置源[内存变量,环境变量和命令行参数]

聊聊默认支持的各种配置源[内存变量,环境变量和命令行参数] 较之传统通过App.config和Web.config这两个XML文件承载的配置系统,.NET Core采用的这个全新的配置模型的最大一个优势就是针对多种不同配置源的支持.我们可以将内存变量.命令行参数.环境变量和物理文件作为原始配置数据的来源,如果采用物理文件作为配置源,我们可以选择不同的格式(比如XML.JSON和INI等) .如果这些默认支持的配置源形式还不能满足你的需求,我们还可以通过注册自定义ConfigurationSour

为maven插件设置参数的三种方法

很多的maven插件都提供了丰富的可选参数,用户可以通过设置特定的参数值来控制maven插件的行为.设置插件参数的方法主要有三种,分别是命令行设置,POM文件中为插件设置全局参数和POM文件中为插件设置任务参数. 第一种,命令行设置.这种设置方式是在使用命令行调用maven生命周期阶段或者插件目标时设置插件参数的方法,其形式是"-D参数键=参数值",可以设置多个,每个参数键值对都要使用"-D"参数,相互之间以空格分隔.这种设置方式将参数设置为Java系统属性,mav