VB.NET获取网卡地址代码实现过程

开发 后端
VB.NET获取网卡地址的实现主要就是为了满足IPX和NETBIOS接口需要的网络地址需求。我们可以通过本文介绍的内容对此进行一个详细的解读。

VB.NET开发语言是一款面向对象的功能强大的编程语言。它的应用可以帮助开发人员实现许多功能需求。比如VB.NET获取网卡地址等。下面就会针对这一方法进行一个详细的解读,希望对大家有所帮助。#t#

程序语言: Microsoft Visual Basic 4.0,5.0,6.0

运行平台: WINDOWS

功能描述: IPX和NETBIOS接口需要网络地址。该文通过详细的步骤演示了如何通过VB.NET获取网卡地址。

VB.NET获取网卡地址步骤:

1)在Visual Basic生成标准的EXE文件。缺省创建 Form1。

2)在Form1中添加一命令按钮,缺省名为Command1。

3)把下列代码放到Form1中说明部分。

  1. Option Explicit   
  2. Private Const NCBASTAT = &H33   
  3. Private Const NCBNAMSZ = 16   
  4. Private Const HEAP_ZERO_MEMORY = &H8   
  5. Private Const HEAP_GENERATE_EXCEPTIONS = &H4   
  6. Private Const NCBRESET = &H32   
  7. Private Type NCB   
  8. ncb_command As Byte 'Integer   
  9. ncb_retcode As Byte 'Integer   
  10. ncb_lsn As Byte 'Integer   
  11. ncb_num As Byte ' Integer   
  12. ncb_buffer As Long 'String   
  13. ncb_length As Integer   
  14. ncb_callname As String * NCBNAMSZ   
  15. ncb_name As String * NCBNAMSZ   
  16. ncb_rto As Byte 'Integer   
  17. ncb_sto As Byte ' Integer   
  18. ncb_post As Long   
  19. ncb_lana_num As Byte 'Integer   
  20. ncb_cmd_cplt As Byte 'Integer   
  21. ncb_reserve(9) As Byte ' Reserved, must be 0   
  22. ncb_event As Long   
  23. End Type   
  24. Private Type ADAPTER_STATUS   
  25. adapter_address(5) As Byte 'As String * 6   
  26. rev_major As Byte 'Integer   
  27. reserved0 As Byte 'Integer   
  28. adapter_type As Byte 'Integer   
  29. rev_minor As Byte 'Integer   
  30. duration As Integer   
  31. frmr_recv As Integer   
  32. frmr_xmit As Integer   
  33. iframe_recv_err As Integer   
  34. xmit_aborts As Integer   
  35. xmit_success As Long   
  36. recv_success As Long   
  37. iframe_xmit_err As Integer   
  38. recv_buff_unavail As Integer   
  39. t1_timeouts As Integer   
  40. ti_timeouts As Integer   
  41. Reserved1 As Long   
  42. free_ncbs As Integer   
  43. max_cfg_ncbs As Integer   
  44. max_ncbs As Integer   
  45. xmit_buf_unavail As Integer   
  46. max_dgram_size As Integer   
  47. pending_sess As Integer   
  48. max_cfg_sess As Integer   
  49. max_sess As Integer   
  50. max_sess_pkt_size As Integer   
  51. name_count As Integer   
  52. End Type   
  53. Private Type NAME_BUFFER   
  54. name As String * NCBNAMSZ   
  55. name_num As Integer   
  56. name_flags As Integer   
  57. End Type   
  58. Private Type ASTAT   
  59. adapt As ADAPTER_STATUS   
  60. NameBuff(30) As NAME_BUFFER   
  61. End Type   
  62. Private Declare Function Netbios 
    Lib "netapi32.dll" (pncb As NCB) As Byte   
  63. Private Declare Sub CopyMemory Lib 
    "kernel32" Alias "RtlMoveMemory" _   
  64. (hpvDest As Any, ByVal hpvSource 
    As Long, ByVal cbCopy As Long)   
  65. Private Declare Function GetProcessHeap 
    Lib "kernel32"() As Long   
  66. Private Declare Function HeapAlloc
     Lib "kernel32" _   
  67. (ByVal hHeap As Long, ByVal 
    dwFlags As Long, _   
  68. ByVal dwBytes As Long) As Long   
  69. Private Declare Function HeapFree Lib 
    "kernel32" (ByVal hHeap As Long, _   
  70. ByVal dwFlags As Long, lpMem As Any) As Long  

 

把下面的VB.NET获取网卡地址的代码放入Command1_Click的事件中:

 

  1. Private Sub Command1_Click()   
  2. Dim myNcb As NCB   
  3. Dim bRet As Byte   
  4. myNcb.ncb_command = NCBRESET   
  5. bRet = Netbios(myNcb)   
  6. myNcb.ncb_command = NCBASTAT   
  7. myNcb.ncb_lana_num = 0   
  8. myNcb.ncb_callname = "* "   
  9. Dim myASTAT As ASTAT, tempASTAT As ASTAT   
  10. Dim pASTAT As Long   
  11. myNcb.ncb_length = Len(myASTAT)   
  12. Debug.Print Err.LastDllError   
  13. pASTAT = HeapAlloc(GetProcessHeap(), 
    HEAP_GENERATE_EXCEPTIONS _   
  14. Or HEAP_ZERO_MEMORY, myNcb.ncb_length)   
  15. If pASTAT = 0 Then   
  16. Debug.Print "memory allcoation failed!"   
  17. Exit Sub   
  18. End If   
  19. myNcb.ncb_buffer = pASTAT   
  20. bRet = Netbios(myNcb)   
  21. Debug.Print Err.LastDllError   
  22. CopyMemory myASTAT, myNcb.
    ncb_buffer, Len(myASTAT)   
  23. MsgBox Hex(myASTAT.adapt
    .adapter_address(0)) & " " & _   
  24. Hex(myASTAT.adapt.adapter_
    address(1)) _   
  25. & " " & Hex(myASTAT.adapt
    .adapter_address(2)) & " " _   
  26. & Hex(myASTAT.adapt.adapter_address(3)) _   
  27. & " " & Hex(myASTAT.adapt.
    adapter_address(4)) & " " _   
  28. & Hex(myASTAT.adapt.adapter_address(5))   
  29. HeapFree GetProcessHeap(), 
    0, pASTAT   
  30. End Sub  

 

4)按F5,运行该程序。

5)点击Command1。注意,网卡地址将在一信息框中显示出来。至此,VB.NET获取网卡地址的操作就结束了。

责任编辑:曹凯 来源: 中国IT实验室
相关推荐

2009-10-16 09:08:35

VB.NET获取网卡地

2010-01-08 15:41:36

VB.NET窗口关闭

2009-11-03 10:18:46

VB.NET继承

2010-01-20 13:42:10

VB.NET访问INIGetPrivateP

2009-10-29 09:57:16

VB.NET实现数据绑

2010-01-22 15:09:11

VB.NET下载程序

2010-01-15 15:39:14

VB.NET Sub过

2010-01-12 11:17:21

VB.NET文字特效

2010-01-22 17:12:08

VB.NET访问Ifr

2010-01-12 10:29:51

VB.NET对象串行化

2010-01-19 14:42:43

VB.NET调用过程重

2009-11-02 16:55:50

VB.NET Smar

2010-01-19 17:26:37

VB.NET创建过程

2009-11-02 10:36:16

VB.NET Sub

2010-01-13 09:31:39

VB.NET窗体打印

2010-01-15 11:31:02

VB.NET接口实现多

2010-01-11 11:02:27

VB.NET调用存储过

2009-10-13 10:21:58

VB.NET实现Web

2010-01-12 10:48:54

VB.NET LIST

2010-01-22 16:48:54

VB.NET调用SQL
点赞
收藏

51CTO技术栈公众号