首页 > 系统相关 >windows 获取 序列号 wwid方法

windows 获取 序列号 wwid方法

时间:2023-11-29 15:01:43浏览次数:48  
标签:include return windows wwid 序列号 02x BYTE ncb bAddressInt

 

以下任意一条命令都可以:

wmic diskdrive get serialnumber
wmic path win32_physicalmedia get SerialNumber
wmic path Win32_DiskDrive get SerialNumber

运行结果:

 

**注意**:windows 7 下获取的序列号格式可能和 Windows 10 下的不一样


获取硬盘的更多信息

wmic diskdrive get Name, Manufacturer, Model, InterfaceType, MediaType, SerialNumber

相关的字段(属性)可以查看微软官方文档

C# 中获取硬盘信息的代码

需要引用 System.Management 库

复制代码
public static List<String> get_serial_number()
 {
  List<String> serial_number_list = new List<String>();
  try
  {
    ManagementObjectSearcher searcher =
    new ManagementObjectSearcher("SELECT * FROM Win32_DiskDrive");
  
    foreach (ManagementObject info in searcher.Get())
    {
      string interface_type = info["InterfaceType"].ToString().Trim();
      string serial_number = info["SerialNumber"].ToString().Trim(); 
      serial_number_list.Add(serial_number); 
    }
  }
  catch (Exception e)
   {
  }

  return serial_number_list;
 }
复制代码

 

参考:https://winaero.com/blog/find-hard-disk-serial-number-windows-10/

 

使用API:

#include <iostream>
#include <Windows.h>

int main() {
HANDLE hDevice = CreateFile(L"\\\\.\\PhysicalDrive0", GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, NULL);

if (hDevice == INVALID_HANDLE_VALUE) {
std::cerr << "Failed to open disk. Error code: " << GetLastError() << std::endl;
return 1;
}

STORAGE_PROPERTY_QUERY storagePropertyQuery;
ZeroMemory(&storagePropertyQuery, sizeof(STORAGE_PROPERTY_QUERY));
storagePropertyQuery.PropertyId = StorageDeviceProperty;
storagePropertyQuery.QueryType = PropertyStandardQuery;

STORAGE_DESCRIPTOR_HEADER storageDescriptorHeader;
ZeroMemory(&storageDescriptorHeader, sizeof(STORAGE_DESCRIPTOR_HEADER));

DWORD bytesReturned;

if (!DeviceIoControl(hDevice, IOCTL_STORAGE_QUERY_PROPERTY, &storagePropertyQuery, sizeof(STORAGE_PROPERTY_QUERY),
&storageDescriptorHeader, sizeof(STORAGE_DESCRIPTOR_HEADER), &bytesReturned, NULL)) {
std::cerr << "DeviceIoControl failed. Error code: " << GetLastError() << std::endl;
CloseHandle(hDevice);
return 1;
}

STORAGE_DEVICE_DESCRIPTOR* storageDeviceDescriptor = (STORAGE_DEVICE_DESCRIPTOR*)malloc(storageDescriptorHeader.Size);

if (!DeviceIoControl(hDevice, IOCTL_STORAGE_QUERY_PROPERTY, &storagePropertyQuery, sizeof(STORAGE_PROPERTY_QUERY),
storageDeviceDescriptor, storageDescriptorHeader.Size, &bytesReturned, NULL)) {
std::cerr << "DeviceIoControl failed. Error code: " << GetLastError() << std::endl;
free(storageDeviceDescriptor);
CloseHandle(hDevice);
return 1;
}

std::cout << "Disk Serial Number: " << storageDeviceDescriptor->SerialNumberOffset << std::endl;

free(storageDeviceDescriptor);
CloseHandle(hDevice);

return 0;
}

 

 

来自:

http://blog.chinaunix.net/uid-395081-id-4763273.html

 

1. 获取机器的MAC地址真的有很多种方法。可以通过windows api,可以通过wmi服务等。MSDN上面的例子是使用IP helper函数GetAdaptersInfo。其实还有一个api,是GetAdaptersAddresses。NetBios和DDK的方法不推荐使用,低于api层次的调用不保证微软会淘汰掉。建立一个支持MFC的控制台程序:

stdafx.h
  1. #include <vector>
  2. #include <string>
  3. typedef std::vector< std::string > MACAddresses;
  4. typedef MACAddresses::iterator vsIt;
GetNetBiosMacAddresses.cpp
  1. #include "stdafx.h" 
  2. #include <windows.h> 
  3. #include <wincon.h> 
  4. #include <stdio.h> 
  5. #include <nb30.h> 
  6. // Netbios is not supported on Windows Vista, Windows Server 2008, and subsequent versions of the operating system]l
  7. // For using NetAPI to get MAC, should include nb30.h
  8. #define MACSESION 6
  9. #pragma warning( disable : 4996 )
  10. #pragma comment(lib,"Netapi32.lib")
  11. typedef struct _ASTAT_ 

  12.     ADAPTER_STATUS adapt; 
  13.     NAME_BUFFER NameBuff [30]; 
  14. }ASTAT, * PASTAT; 
  15.   
  16. ASTAT Adapter; // to store MAC information 
  17. // input parameter: lana_num start from 0, but in windows, not continuously allocated, so not reliable.
  18. std::string getmac_one( int lana_num )

  19.     NCB ncb; 
  20.     UCHAR uRetCode; 
  21.   
  22.     memset( &ncb, 0, sizeof( ncb ) ); 
  23.     ncb.ncb_command = NCBRESET; 
  24.     ncb.ncb_lana_num = lana_num; 
  25.     
  26.     uRetCode = Netbios( &ncb ); 
  27.     //printf( "The NCBRESET return code is:0x%x \n", uRetCode ); 
  28.   
  29.     memset( &ncb, 0, sizeof( ncb ) ); 
  30.     ncb.ncb_command = NCBASTAT; 
  31.     ncb.ncb_lana_num = lana_num; 
  32.   
  33.     strcpy( (char *)ncb.ncb_callname, "* " ); 
  34.     ncb.ncb_buffer = ( unsigned char * ) &Adapter; 
  35.   
  36.     ncb.ncb_length = sizeof( Adapter ); 
  37.     uRetCode = Netbios( &ncb ); 
  38.     // printf( "The NCBASTAT return code is: 0x%x \n", uRetCode );
  39.     std::string s;
  40.     if ( uRetCode == 0 ) 
  41.     {
  42.         int bAddressInt [ MACSESION ];
  43.         char CommarSeperatedAddress[ MACSESION * 3 ]={0};
  44.         for( int i = 0; i < MACSESION; ++i )
  45.         {
  46.             bAddressInt[ i ] = Adapter.adapt.adapter_address[ i ];
  47.             bAddressInt[ i ] &= 0x000000ff; // avoid "ff" leading bytes when "char" is lager then 0x7f
  48.         }
  49.         sprintf( CommarSeperatedAddress, "%02x:%02x:%02x:%02x:%02x:%02x",
  50.                                bAddressInt[ 0 ],
  51.                                bAddressInt[ 1 ],
  52.                                bAddressInt[ 2 ],
  53.                                bAddressInt[ 3 ],
  54.                                bAddressInt[ 4 ],
  55.                                bAddressInt[ 5 ]); // Should use scl::FormatString inside 
  56.         s = CommarSeperatedAddress;
  57.     }
  58.     return s;
  59. }
  60. MACAddresses GetNetBiosMacAddresses()
  61. {
  62.     NCB ncb; 
  63.     UCHAR uRetCode; 
  64.     LANA_ENUM lana_enum; 
  65.     memset( &ncb, 0, sizeof( ncb ) ); 
  66.     ncb.ncb_command = NCBENUM; 
  67.   
  68.     ncb.ncb_buffer = (unsigned char *) &lana_enum; 
  69.     ncb.ncb_length = sizeof( lana_enum ); 
  70.   
  71.     uRetCode = Netbios( &ncb ); 
  72.     //printf( "The NCBENUM return code is:0x%x \n", uRetCode );
  73.     MACAddresses vAdd;
  74.     if ( uRetCode == 0 ) 
  75.     { 
  76.         //printf( "Ethernet Count is : %d\n\n", lana_enum.length); 
  77.         for ( int i=0; i < lana_enum.length; ++i )
  78.         {
  79.             std::string s = getmac_one( lana_enum.lana[i] ); 
  80.             if( ! s.empty() )
  81.             {
  82.                 vAdd.push_back( s );
  83.             }
  84.         }
  85.     }
  86.     return vAdd;
  87. }
GetMacAddresses.cpp
  1. #include "stdafx.h"
  2. #include <Winsock2.h>
  3. #include <Iphlpapi.h>
  4. #pragma comment(lib,"Iphlpapi")
  5. #pragma warning( disable : 4996 )
  6. #define MACSESION 6
  7. MACAddresses GetINETMacAddresses()
  8. {
  9.     PIP_ADAPTER_ADDRESSES pAddresses = NULL;
  10.     ULONG family = AF_INET;
  11.     ULONG flags = GAA_FLAG_INCLUDE_PREFIX;
  12.     ULONG outBufLen = sizeof( IP_ADAPTER_ADDRESSES );
  13.     // Make an initial call to GetAdaptersAddresses to get the 
  14.     // size needed into the outBufLen variable
  15.     if ( GetAdaptersAddresses( family, flags, NULL, pAddresses, &outBufLen ) == ERROR_BUFFER_OVERFLOW )
  16.     {
  17.         pAddresses = static_cast<PIP_ADAPTER_ADDRESSES>( HeapAlloc( GetProcessHeap(), 0, outBufLen ) );
  18.     }
  19.     _ASSERT( pAddresses );
  20.     // Make a second call to GetAdapters Addresses to get the
  21.     // actual data we want
  22.     DWORD dwRetVal = GetAdaptersAddresses( family, flags, NULL, pAddresses, &outBufLen );
  23.     MACAddresses vAddress;
  24.     if ( dwRetVal != ERROR_SUCCESS )
  25.     {
  26.         return vAddress;
  27.     }
  28.     PIP_ADAPTER_ADDRESSES pFirst = pAddresses;
  29.     while( pAddresses )
  30.     {
  31.         BYTE* pa = pAddresses->PhysicalAddress;
  32.         if ( ! pa || ! pa[ 0 ] )
  33.         {
  34.             break;
  35.         }
  36.         char bAddressBytes[ MACSESION ];
  37.         int bAddressInt [ MACSESION ];
  38.         memset( bAddressBytes, 0, MACSESION );
  39.         size_t nAddressSize = pAddresses->PhysicalAddressLength;
  40.         memcpy( bAddressBytes, pa, ( nAddressSize < MACSESION ? nAddressSize : MACSESION ));
  41.         char CommarSeperatedAddress[ MACSESION * 3 ]={0};
  42.         for( int i = 0; i < MACSESION; ++i )
  43.         {
  44.             bAddressInt[ i ] = bAddressBytes[ i ];
  45.             bAddressInt[ i ] &= 0x000000ff; // avoid "ff" leading bytes when "char" is lager then 0x7f
  46.         }
  47.         sprintf( CommarSeperatedAddress, "%02x:%02x:%02x:%02x:%02x:%02x",
  48.                                bAddressInt[ 0 ],
  49.                                bAddressInt[ 1 ],
  50.                                bAddressInt[ 2 ],
  51.                                bAddressInt[ 3 ],
  52.                                bAddressInt[ 4 ],
  53.                                bAddressInt[ 5 ]); // Should use scl::FormatString inside 
  54.         pAddresses = pAddresses->Next ? pAddresses->Next : NULL;
  55.         vAddress.push_back( std::string( CommarSeperatedAddress ) );
  56.     }
  57.     HeapFree( GetProcessHeap(), 0, pFirst );
  58.     return vAddress;
  59. }
2. 获取硬盘的id, api函数得到的都是和windows安装相关的id,也就是windows硬件管理器分配的id,而不是真正的硬件生产厂商的id. 所以,为了得到真正的和硬盘序列号相关的信息,最好是使用WMI服务查询。 GetPartitionVolumeSerialNumber.cpp
  1. #include "stdafx.h"
  2. DWORD GetPartitionVolumeSerialNumber() // Get Disk partition volumn id, not hard disk id
  3. {
  4.     TCHAR lpRootPathName[]= _T( "\\\\.\\PhysicalDrive0\\" ); // Use physical drive, not C:disk
  5.     TCHAR lpVolumeNameBuffer[ 12 ]; //disk volumn
  6.     DWORD nVolumeNameSize =12; 
  7.     DWORD VolumeSerialNumber; // Serial number
  8.     DWORD MaximumComponentLength; 
  9.     TCHAR lpFileSystemNameBuffer[ 10 ]; 
  10.     DWORD nFileSystemNameSize = 10; 
  11.     DWORD FileSystemFlags; 
  12.     BOOL ret = GetVolumeInformation( lpRootPathName, 
  13.                                      lpVolumeNameBuffer,
  14.                                      nVolumeNameSize, 
  15.                                      &VolumeSerialNumber,
  16.                                      &MaximumComponentLength, 
  17.                                      &FileSystemFlags, 
  18.                                      lpFileSystemNameBuffer,
  19.                                      nFileSystemNameSize); 
  20.     printf( "Partition serial number is %0xd\n", VolumeSerialNumber );
  21.     if( ret )
  22.     {
  23.         return VolumeSerialNumber;
  24.     }
  25.     else
  26.     {
  27.         return FALSE;
  28.     }
  29. }
GetPhysicalSerialNumber.cpp
  1. #include "stdafx.h"
  2. #include <Iphlpapi.h>
  3. #pragma comment(lib,"Iphlpapi")
  4. //#pragma warning( disable : 4996 )
  5. // IOCTL command constants
  6. #define DFP_GET_VERSION 0x00074080
  7. #define DFP_RECEIVE_DRIVE_DATA 0x0007c088
  8. // values for IDEREGS.bCommandReg
  9. #define IDE_ATAPI_IDENTIFY 0xA1
  10. #define IDE_ATA_IDENTIFY 0xEC
  11. #define IDENTIFY_BUFFER_SIZE 512
  12. //save disk information
  13. typedef struct _GETVERSIONOUTPARAMS
  14. {
  15.     BYTE bVersion;
  16.     BYTE bRevision;
  17.     BYTE bReserved;
  18.     BYTE bIDEDeviceMap;
  19.     DWORD fCapabilities;
  20.     DWORD dwReserved[4];
  21. } GETVERSIONOUTPARAMS, *PGETVERSIONOUTPARAMS, *LPGETVERSIONOUTPARAMS;
  22. // IDE register information
  23. typedef struct _IDEREGS
  24. {
  25.     BYTE bFeaturesReg;
  26.     BYTE bSectorCountReg;
  27.     BYTE bSectorNumberReg;
  28.     BYTE bCylLowReg;
  29.     BYTE bCylHighReg;
  30.     BYTE bDriveHeadReg;
  31.     BYTE bCommandReg;
  32.     BYTE bReserved;
  33. } IDEREGS, *PIDEREGS, *LPIDEREGS;
  34. // disk command input parameter
  35. typedef struct _SENDCMDINPARAMS
  36. {
  37.     DWORD cBufferSize;
  38.     IDEREGS irDriveRegs;
  39.     BYTE bDriveNumber;
  40.     BYTE bReserved[3];
  41.     DWORD dwReserved[4];
  42.     BYTE bBuffer[1];
  43. } SENDCMDINPARAMS, *PSENDCMDINPARAMS, *LPSENDCMDINPARAMS;
  44. // disk status
  45. typedef struct _DRIVERSTATUS
  46. {
  47.     BYTE bDriverError;
  48.     BYTE bIDEStatus;
  49.     BYTE bReserved[2];
  50.     DWORD dwReserved[2];
  51. } DRIVERSTATUS, *PDRIVERSTATUS, *LPDRIVERSTATUS;
  52. // sent param for disk commands
  53. typedef struct _SENDCMDOUTPARAMS
  54. {
  55.     DWORD cBufferSize;
  56.     DRIVERSTATUS DriverStatus;
  57.     BYTE bBuffer[1];
  58. } SENDCMDOUTPARAMS, *PSENDCMDOUTPARAMS, *LPSENDCMDOUTPARAMS;
  59. void GetDiskPhysicalSN(char pchDiskPhysicalSN[14])
  60. {
  61.     BYTE IdOutCmd[530];
  62.     HANDLE drive=CreateFile(L"\\\\.\\PhysicalDrive0", GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, NULL );
  63.     if ( drive == INVALID_HANDLE_VALUE )
  64.     {
  65.         pchDiskPhysicalSN[ 0 ] = 0;
  66.         return ;
  67.     }
  68.     GETVERSIONOUTPARAMS VersionParams;
  69.     DWORD cbBytesReturned = 0;
  70.     memset( ( void* ) &VersionParams, 0, sizeof( VersionParams ) );
  71.     if ( ! DeviceIoControl( drive, DFP_GET_VERSION, NULL, 0, &VersionParams, sizeof( VersionParams ), &cbBytesReturned, NULL ) )
  72.     {
  73.         pchDiskPhysicalSN[ 0 ] = 0;
  74.         return ;
  75.     }
  76.     if (VersionParams.bIDEDeviceMap<=0)
  77.     {
  78.         pchDiskPhysicalSN[ 0 ] = 0;
  79.         return ;
  80.     }
  81.     BYTE bIDCmd = 0;
  82.     SENDCMDINPARAMS scip;
  83.     bIDCmd = ( VersionParams.bIDEDeviceMap >> 0 & 0x10 ) ? IDE_ATAPI_IDENTIFY : IDE_ATA_IDENTIFY;
  84.     memset( &scip, 0, sizeof( scip) );
  85.     memset( IdOutCmd, 0, sizeof( IdOutCmd ) );
  86.     scip.cBufferSize = IDENTIFY_BUFFER_SIZE;
  87.     scip.irDriveRegs.bFeaturesReg = 0;
  88.     scip.irDriveRegs.bSectorCountReg = 1;
  89.     scip.irDriveRegs.bSectorNumberReg = 1;
  90.     scip.irDriveRegs.bCylLowReg = 0;
  91.     scip.irDriveRegs.bCylHighReg = 0;
  92.     scip.irDriveRegs.bDriveHeadReg= 0xA0 | ( ( ( BYTE ) drive & 1 ) << 4 );
  93.     scip.irDriveRegs.bCommandReg = bIDCmd;
  94.     scip.bDriveNumber = ( BYTE ) drive;
  95.     scip.cBufferSize = IDENTIFY_BUFFER_SIZE;
  96.     if ( ! DeviceIoControl( drive, DFP_RECEIVE_DRIVE_DATA, &scip, sizeof( SENDCMDINPARAMS)- 1, ( LPVOID )&IdOutCmd, sizeof( SENDCMDOUTPARAMS ) + IDENTIFY_BUFFER_SIZE - 1, &cbBytesReturned, NULL ) )
  97.     {
  98.         pchDiskPhysicalSN[ 0 ] = 0;
  99.         return ;
  100.     }
  101.     USHORT *pIdSector = ( USHORT * )( ( PSENDCMDOUTPARAMS )IdOutCmd )->bBuffer;
  102.     int nPosition = 0;
  103.     for( int nIndex = 13; nIndex < 20; nIndex++ )
  104.     {
  105.         pchDiskPhysicalSN[ nPosition++ ]=( unsigned char )( pIdSector[ nIndex ] / 256 );
  106.         pchDiskPhysicalSN[ nPosition++ ]=( unsigned char )( pIdSector[ nIndex ] % 256 );
  107.     }
  108. }
  109. void GetDiskPhysicalSerialNumber( char* pchSerialNumber )
  110. {
  111.     char pchDiskPhysicalSN[ 14 ];
  112.     GetDiskPhysicalSN( pchDiskPhysicalSN );
  113.     int nSerial[ 14 ];
  114.     for( int i = 0 ; i < 14; ++ i )
  115.     {
  116.         nSerial[ i ] = pchDiskPhysicalSN[ i ];
  117.         nSerial[ i ] &= 0x000000ff;
  118.     }
  119.     sprintf( pchSerialNumber, "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x",
  120.                                nSerial[ 0 ],
  121.                                nSerial[ 1 ],
  122.                                nSerial[ 2 ],
  123.                                nSerial[ 3 ],
  124.                                nSerial[ 4 ],
  125.                                nSerial[ 5 ],
  126.                                nSerial[ 6 ],
  127.                                nSerial[ 7 ],
  128.                                nSerial[ 8 ],
  129.                                nSerial[ 9 ],
  130.                                nSerial[ 10 ],
  131.                                nSerial[ 11 ],
  132.                                nSerial[ 12 ],
  133.                                nSerial[ 13 ]); // Should use scl::FormatString inside 
  134. }
main.cpp
  1. #include "stdafx.h" 
  2. MACAddresses GetINETMacAddresses();
  3. MACAddresses GetNetBiosMacAddresses();
  4. DWORD GetPartitionVolumeSerialNumber();
  5. void GetDiskPhysicalSerialNumber( char* pchDiskPhysicalSN );
  6. int main(int argc, char* argv[]) 
  7. {
  8.     DWORD VolumeSerialNumber = 0;
  9.     if( ! GetPartitionVolumeSerialNumber() )
  10.     {
  11.         TRACE( "(Get Disk Partition ID met error : %d)\n", GetLastError() );
  12.     }
  13.     else
  14.     {
  15.         printf( "Disk Partition ID = %0xd\n", VolumeSerialNumber );
  16.     }
  17.     char pchSerialNumber[ 50 ];
  18.     GetDiskPhysicalSerialNumber( pchSerialNumber );
  19.     printf("PhysicalSerialNumber is %s\n", pchSerialNumber );
  20.     printf("--------\n");
  21.     MACAddresses& vAddresses = GetINETMacAddresses();
  22.     for( vsIt it = vAddresses.begin(); it != vAddresses.end(); ++ it )
  23.     {
  24.         printf( "INET MAC addresses = %s\n", it->c_str() );
  25.     }
  26.     MACAddresses& vAddresses2 = GetNetBiosMacAddresses();
  27.     for( vsIt it = vAddresses2.begin(); it != vAddresses2.end(); ++ it )
  28.     {
  29.         printf( "NetBios MAC addresses = %s\n", it->c_str() );
  30.     }
  31.     return 0; 
  32. }

 

 

 

参考:

https://www.cnblogs.com/tommy-huang/p/10682660.html

http://blog.chinaunix.net/uid-22754909-id-332321.html

 

标签:include,return,windows,wwid,序列号,02x,BYTE,ncb,bAddressInt
From: https://www.cnblogs.com/rebrobot/p/17864859.html

相关文章

  • Windows10+Qt+OpenCV出现“ACCESS_MASK”: 不明确的符号
    一、概述背景:Qt+OpenCV一模一样的代码在Mac上运行是正常的,在Windows10上运行就会报一下错误。“ACCESS_MASK”:不明确的符号二、原因及解决方案原因:OpenCV4.5.3的命名空间usingnamespacecv;和windows中的ACCESS_MASK定义冲突,在windows.h头文件中。......
  • 入门Windows驱动程序
    来自:https://www.anquanke.com/post/id/85972入门Windows驱动程序:0x1 背景笔者在学习中发现,关于Windows驱动编程的文章多不胜数,但是其中很多文章的内容繁杂不便于了解与学习,缺少对内容精准的概括与总结,所以本篇文章将对Windows驱动编程进行一次总结性介绍。文章将分为两个部......
  • Windows电脑上的多开工具与云桌面有何异同
    在Windows电脑上,多开工具和云桌面是两种常见的应用方式,它们各自具有一些特点和优势。本文将就多开工具和云桌面在实际使用中的异同进行比较。多开工具多开工具是指能够帮助用户同时打开多个相同软件或游戏的应用程序。在Windows操作系统中,有许多第三方多开工具可以实现这一功能,......
  • windows
     在64位系统system32是64位程序,Syswow64是32位程序。     参考:https://blog.51cto.com/u_15287666/5805954 ......
  • Windows下使用wget获取内容
    在根据Pytorch从0开始实现YOLOV3指南part2——搭建网络结构层-cwpeng-博客园(cnblogs.com) 尝试实现yolo的目标检测项目时,文中配置文件部分提到若在linux下可以用mkdircfgcdcfgwgethttps://raw.githubusercontent.com/pjreddie/darknet/master/cfg/yolov3.cfg在w......
  • nvm环境安装(windows篇)
    一、NVM版本管理环境安装配置1.nvmforwindows安装包下载地址:地址:https://github.com/coreybutler/nvm-windows/releases点击nvm-setup.exe进行下载 2.安装nvm 选择NVM安装路径,路径名称不要有空格,然后点击nextnode.js安装路径,然后点击next 根据个人习惯下载set......
  • # 在Windows中使用VMware安装Linux
    ##简介在计算机专业的学习过程中,熟练掌握不同操作系统是至关重要的一部分。本篇博客将介绍如何在Windows操作系统上使用虚拟机软件VMware来安装Linux系统。##准备工作在开始之前,确保你已经完成以下准备工作:-**VMware安装:**从官方网站[https://www.vmware.com/](https://ww......
  • Windows 11 version 22H2 中文版、英文版 (x64、ARM64) 下载 (released Nov 2023)
    Windows11version22H2中文版、英文版(x64、ARM64)下载(releasedNov2023)Windows11,version23H2,2023年10月31日发布(本月暂未更)请访问原文链接:https://sysin.org/blog/windows-11/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.orgWindows11目前版......
  • Windows PBR Reset在62%处不动
    晚上在调查一个问题,需要做WindowsPBRReset,Windows的版本号是22621.2751在启动PBRReset时,一直停留在62%的进度条上(图片忘记保存了)我想通过重启系统来解决,可是重启过程也被卡住了。于是,我尝试着做WindowsUpdate,将系统更新到最新的状态,果然,完成WindowsUpdate之后,PBRReset就......
  • 在 Windows 系统上运行 VIC 水文模型
    目录配置WSL2和Ubuntu系统启用WSL2安装Linux发行版配置Ubuntu安装VIC并测试Stehekin数据集VIC模型安装samples测试VIC模型(VariableInfiltrationCapacityModel)是一个被广泛使用的大尺度分布式水文模型,该模型可同时对水循环过程中的能量平衡和水量平衡进行模......