CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
可用分押宝游戏火热进行中... 专题改版:Java Web 专题
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  VB >  API

怎样才能或得局域网内某个指定IP的计算机的名字

楼主liuyan4794(青牛)2004-08-03 12:29:20 在 VB / API 提问

怎样才能或得局域网内某个指定IP的计算机的名字 问题点数:20、回复次数:5Top

1 楼computer17(黄昏之路づ流浪汉)回复于 2004-08-03 12:56:46 得分 0

还没搞清楚,网页里面很容易实现,看看那里面或许有所帮助Top

2 楼D99(没有)回复于 2004-08-03 12:59:16 得分 0

nslookup   xxx.xxx.xxx.xxx     ?Top

3 楼liuyan4794(青牛)回复于 2004-08-03 13:08:11 得分 0

upTop

4 楼of123()回复于 2004-08-03 13:15:47 得分 20

Option   Explicit  
               
  ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''  
  '   Copyright   ©1996-2004   VBnet,   Randy   Birch,   All   Rights   Reserved.  
  '   Some   pages   may   also   contain   other   copyrights   by   the   author.  
  ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''  
  '   Distribution:   You   can   freely   use   this   code   in   your   own  
  '                               applications,   but   you   may   not   reproduce    
  '                               or   publish   this   code   on   any   web   site,  
  '                               online   service,   or   distribute   as   source    
  '                               on   any   media   without   express   permission.  
  ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''  
  Private   Const   WSADescription_Len   As   Long   =   256  
  Private   Const   WSASYS_Status_Len   As   Long   =   128  
  Private   Const   WS_VERSION_REQD   As   Long   =   &H101  
  Private   Const   IP_SUCCESS   As   Long   =   0  
  Private   Const   SOCKET_ERROR   As   Long   =   -1  
  Private   Const   AF_INET   As   Long   =   2  
   
  Private   Type   WSADATA  
      wVersion   As   Integer  
      wHighVersion   As   Integer  
      szDescription(0   To   WSADescription_Len)   As   Byte  
      szSystemStatus(0   To   WSASYS_Status_Len)   As   Byte  
      imaxsockets   As   Integer  
      imaxudp   As   Integer  
      lpszvenderinfo   As   Long  
  End   Type  
   
  Private   Declare   Function   WSAStartup   Lib   "wsock32"   _  
      (ByVal   VersionReq   As   Long,   _  
        WSADataReturn   As   WSADATA)   As   Long  
       
  Private   Declare   Function   WSACleanup   Lib   "wsock32"   ()   As   Long  
   
  Private   Declare   Function   inet_addr   Lib   "wsock32"   _  
      (ByVal   s   As   String)   As   Long  
   
  Private   Declare   Function   gethostbyaddr   Lib   "wsock32"   _  
      (haddr   As   Long,   _  
        ByVal   hnlen   As   Long,   _  
        ByVal   addrtype   As   Long)   As   Long  
   
  Private   Declare   Sub   CopyMemory   Lib   "kernel32"   _  
        Alias   "RtlMoveMemory"   _  
      (xDest   As   Any,   _  
        xSource   As   Any,   _  
        ByVal   nbytes   As   Long)  
         
  Private   Declare   Function   lstrlen   Lib   "kernel32"   _  
        Alias   "lstrlenA"   _  
      (lpString   As   Any)   As   Long  
       
       
       
  Private   Sub   Command1_Click()  
   
        Text2.Text   =   GetHostNameFromIP(Text1.Text)  
         
  End   Sub  
   
       
  Private   Function   SocketsInitialize()   As   Boolean  
   
        Dim   WSAD   As   WSADATA  
         
        SocketsInitialize   =   WSAStartup(WS_VERSION_REQD,   WSAD)   =   IP_SUCCESS  
           
  End   Function  
   
   
  Private   Sub   SocketsCleanup()  
         
        If   WSACleanup()   <>   0   Then  
                MsgBox   "Windows   Sockets   error   occurred   in   Cleanup.",   vbExclamation  
        End   If  
           
  End   Sub  
   
   
  Private   Function   GetHostNameFromIP(ByVal   sAddress   As   String)   As   String  
   
        Dim   ptrHosent   As   Long  
        Dim   hAddress   As   Long  
        Dim   nbytes   As   Long  
         
        If   SocketsInitialize()   Then  
   
            'convert   string   address   to   long  
              hAddress   =   inet_addr(sAddress)  
               
              If   hAddress   <>   SOCKET_ERROR   Then  
                     
                  'obtain   a   pointer   to   the   HOSTENT   structure  
                  'that   contains   the   name   and   address  
                  'corresponding   to   the   given   network   address.  
                    ptrHosent   =   gethostbyaddr(hAddress,   4,   AF_INET)  
         
                    If   ptrHosent   <>   0   Then  
                     
                        'convert   address   and  
                        'get   resolved   hostname  
                          CopyMemory   ptrHosent,   ByVal   ptrHosent,   4  
                          nbytes   =   lstrlen(ByVal   ptrHosent)  
                     
                          If   nbytes   >   0   Then  
                                sAddress   =   Space$(nbytes)  
                                CopyMemory   ByVal   sAddress,   ByVal   ptrHosent,   nbytes  
                                GetHostNameFromIP   =   sAddress  
                          End   If  
                     
                    Else  
                          MsgBox   "Call   to   gethostbyaddr   failed."  
                    End   If   'If   ptrHosent  
               
              SocketsCleanup  
               
              Else  
                    MsgBox   "String   passed   is   an   invalid   IP."  
              End   If   'If   hAddress  
         
        Else  
              MsgBox   "Sockets   failed   to   initialize."  
        End   If     'If   SocketsInitialize  
               
  End   Function  
  Top

5 楼liuyan4794(青牛)回复于 2004-08-03 13:20:15 得分 0

谢谢Top

相关问题

  • 怎样获得局域网中所有IP,和计算机名?
  • 我想一上局域网就自动获取局域网里所有计算机的IP
  • "我想一上局域网就自动获取局域网里所有计算机的IP"
  • "我想一上局域网就自动获取局域网里所有计算机的IP"
  • 求救:局域网通过计算机名无法访问局域网内机器,但是通过IP可以。
  • 请问:如何enum出局域网上的计算机名称或ip!
  • 请问,关于局域网内部计算机在internet上的ip地址
  • 已知局域网内一计算机名,怎么得到它的ip?
  • 如何获得一个局域网内所有计算机的ip地址
  • 网卡ip本机能ping通,其他局域网内计算机ping不通

关键词

  • sockets
  • ip
  • ptrhosent
  • haddress
  • saddress
  • nbytes
  • byval
  • xxx
  • as long
  • private const

得分解答快速导航

  • 帖主:liuyan4794
  • of123

相关链接

  • Visual Basic类图书
  • Visual Basic类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo