在VB中如何使用ping命令

2016-02-19 18:10 107 1 收藏

今天图老师小编要跟大家分享在VB中如何使用ping命令,精心挑选的过程简单易学,喜欢的朋友一起来学习吧!

【 tulaoshi.com - 编程语言 】

BASModule模块
  把以下代码回到BASModule模块:

OptionExplicit
  PrivateConstIP_SUCCESSAsLong=0
  PrivateConstIP_STATUS_BASEAsLong=11000
  PrivateConstIP_BUF_TOO_SMALLAsLong=(11000 1)
  PrivateConstIP_DEST_NET_UNREACHABLEAsLong=(11000 2)
  PrivateConstIP_DEST_HOST_UNREACHABLEAsLong=(11000 3)
  PrivateConstIP_DEST_PROT_UNREACHABLEAsLong=(11000 4)
  PrivateConstIP_DEST_PORT_UNREACHABLEAsLong=(11000 5)
  PrivateConstIP_NO_RESOURCESAsLong=(11000 6)
  PrivateConstIP_BAD_OPTIONAsLong=(11000 7)
  PrivateConstIP_HW_ERRORAsLong=(11000 8)
  PrivateConstIP_PACKET_TOO_BIGAsLong=(11000 9)
  PrivateConstIP_REQ_TIMED_OUTAsLong=(11000 10)
  PrivateConstIP_BAD_REQAsLong=(11000 11)
  PrivateConstIP_BAD_ROUTEAsLong=(11000 12)
  PrivateConstIP_TTL_EXPIRED_TRANSITAsLong=(11000 13)
  PrivateConstIP_TTL_EXPIRED_REASSEMAsLong=(11000 14)
  PrivateConstIP_PARAM_PROBLEMAsLong=(11000 15)
  PrivateConstIP_SOURCE_QUENCHAsLong=(11000 16)
  PrivateConstIP_OPTION_TOO_BIGAsLong=(11000 17)
  PrivateConstIP_BAD_DESTINATIONAsLong=(11000 18)
  PrivateConstIP_ADDR_DELETEDAsLong=(11000 19)
  PrivateConstIP_SPEC_MTU_CHANGEAsLong=(11000 20)
  PrivateConstIP_MTU_CHANGEAsLong=(11000 21)
  PrivateConstIP_UNLOADAsLong=(11000 22)
  PrivateConstIP_ADDR_ADDEDAsLong=(11000 23)
  PrivateConstIP_GENERAL_FAILUREAsLong=(11000 50)
  PrivateConstMAX_IP_STATUSAsLong=(11000 50)
  PrivateConstIP_PENDINGAsLong=(11000 255)
  PrivateConstPING_TIMEOUTAsLong=500
  PrivateConstWS_VERSION_REQDAsLong=&H101
  PrivateConstMIN_SOCKETS_REQDAsLong=1
  PrivateConstSOCKET_ERRORAsLong=-1
  PrivateConstINADDR_NONEAsLong=&HFFFFFFFF
  PrivateConstMAX_WSADescriptionAsLong=256
  PrivateConstMAX_WSASYSStatusAsLong=128
  
  PrivateTypeICMP_OPTIONS
  TtlAsByte
  TosAsByte
  FlagsAsByte
  OptionsSizeAsByte
  OptionsDataAsLong
  EndType
  
  PublicTypeICMP_ECHO_REPLY
  AddressAsLong
  statusAsLong
  RoundTripTimeAsLong
  DataSizeAsLong注释:formerlyinteger
  注释:ReservedAsInteger
  DataPointerAsLong
  OptionsAsICMP_OPTIONS
  DataAsString*250
  EndType
  
  PrivateTypeWSADATA
  wVersionAsInteger
  wHighVersionAsInteger
  szDescription(0ToMAX_WSADescription)AsByte
  szSystemStatus(0ToMAX_WSASYSStatus)AsByte
  wMaxSocketsAsLong
  wMaxUDPDGAsLong
  dwVendorInfoAsLong
  EndType
  
  PrivateDeclareFunctionIcmpCreateFileLib"icmp.dll"()AsLong
  
  PrivateDeclareFunctionIcmpCloseHandleLib"icmp.dll"(ByValIcmpHandleAsLong)AsLong
  
  PrivateDeclareFunctionIcmpSendEchoLib"icmp.dll"(ByValIcmpHandleAsLong,ByValDestinationAddressAsLong,ByValRequestDataAsString,ByValRequestSizeAsLong,ByValRequestOptionsAsLong,ReplyBufferAsICMP_ECHO_REPLY,ByValReplySizeAsLong,ByValTimeoutAsLong)AsLong
  
  PrivateDeclareFunctionWSAGetLastErrorLib"WSOCK32.DLL"()AsLong
  
  PrivateDeclareFunctionWSAStartupLib"WSOCK32.DLL"(ByValwVersionRequiredAsLong,lpWSADATAAsWSADATA)AsLong
  
  PrivateDeclareFunctionWSACleanupLib"WSOCK32.DLL"()AsLong
  
  PrivateDeclareFunctiongethostnameLib"WSOCK32.DLL"(ByValszHostAsString,ByValdwHostLenAsLong)AsLong
  
  PrivateDeclareFunctiongethostbynameLib"WSOCK32.DLL"(ByValszHostAsString)AsLong
  
  PrivateDeclareSubCopyMemoryLib"kernel32"Alias"RtlMoveMemory"(xDestAsAny,xSourceAsAny,ByValnbytesAsLong)
  
  PrivateDeclareFunctioninet_addrLib"WSOCK32.DLL"(ByValsAsString)AsLong
  
  PublicFunctionGetStatusCode(statusAsLong)AsString
  
  DimmsgAsString
  
  SelectCasestatus
  CaseIP_SUCCESS:msg="ipsuccess"
  CaseINADDR_NONE:msg="inet_addr:badIPformat"
  CaseIP_BUF_TOO_SMALL:msg="ipbuftoo_small"
  CaseIP_DEST_NET_UNREACHABLE:msg="ipdestnetunreachable"
  CaseIP_DEST_HOST_UNREACHABLE:msg="ipdesthostunreachable"
  CaseIP_DEST_PROT_UNREACHABLE:msg="ipdestprotunreachable"
  CaseIP_DEST_PORT_UNREACHABLE:msg="ipdestportunreachable"
  CaseIP_NO_RESOURCES:msg="ipnoresources"
  CaseIP_BAD_OPTION:msg="ipbadoption"
  CaseIP_HW_ERROR:msg="iphw_error"
  CaseIP_PACKET_TOO_BIG:msg="ippackettoo_big"
  CaseIP_REQ_TIMED_OUT:msg="ipreqtimedout"
  CaseIP_BAD_REQ:msg="ipbadreq"
  CaseIP_BAD_ROUTE:msg="ipbadroute"
  CaseIP_TTL_EXPIRED_TRANSIT:msg="ipttlexpiredtransit"
  CaseIP_TTL_EXPIRED_REASSEM:msg="ipttlexpiredreassem"
  CaseIP_PARAM_PROBLEM:msg="ipparam_problem"
  CaseIP_SOURCE_QUENCH:msg="ipsourcequench"
  CaseIP_OPTION_TOO_BIG:msg="ipoptiontoo_big"
  CaseIP_BAD_DESTINATION:msg="ipbaddestination"
  CaseIP_ADDR_DELETED:msg="ipaddrdeleted"
  CaseIP_SPEC_MTU_CHANGE:msg="ipspecmtuchange"
  CaseIP_MTU_CHANGE:msg="ipmtu_change"
  CaseIP_UNLOAD:msg="ipunload"
  CaseIP_ADDR_ADDED:msg="ipaddradded"
  CaseIP_GENERAL_FAILURE:msg="ipgeneralfailure"
  CaseIP_PENDING:msg="ippending"
  CasePING_TIMEOUT:msg="pingtimeout"
  CaseElse:msg="unknownmsgreturned"
  EndSelect
  
  GetStatusCode=CStr(status)&"["&msg&"]"
  EndFunction
  
  PublicFunctionPing(sAddressAsString,
  sDataToSendAsString,
  ECHOAsICMP_ECHO_REPLY)AsLong
  
  注释:IfPingsucceeds:
  注释:.RoundTripTime=timeinmsforthepingtocomplete,
  注释:.Dataisthedatareturned(NULLterminated)
  注释:.AddressistheIpaddressthatactuallyreplied
  注释:.DataSizeisthesizeofthestringin.Data
  注释:.Statuswillbe0
  注释:
  注释:IfPingfails.Statuswillbetheerrorcode
  
  DimhPortAsLong
  DimdwAddressAsLong
  
  注释:converttheaddressintoalongrepresentation
  dwAddress=inet_addr(sAddress)
  
  注释:ifavalidaddress..
  IfdwAddressINADDR_NONEThen
  
  注释:openaport
  hPort=IcmpCreateFile()
  
  注释:andifsuccessful,
  IfhPortThen
  
  注释:pingit.
  CallIcmpSendEcho(hPort,dwAddress,sDataToSend,Len(sDataToSend),0,ECHO,Len(ECHO),PING_TIMEOUT)
  
  注释:returnthestatusaspingsuccesandclose
  Ping=ECHO.status
  CallIcmpCloseHandle(hPort)
  
  EndIf
  
  Else:
  注释:theaddressformatwasprobablyinvalid
  Ping=INADDR_NONE
  
  EndIf
  
  EndFunction
  
  
  PublicSubSocketsCleanup()
  
  IfWSACleanup()0Then
  MsgBox"WindowsSocketserroroccurredinCleanup.",vbExclamation
  EndIf
  
  EndSub
  
  
  PublicFunctionSocketsInitialize()AsBoolean
  
  DimWSADAsWSADATA
  
  SocketsInitialize=WSAStartup(WS_VERSION_REQD,WSAD)=IP_SUCCESS
  
  EndFunction
  
  注释:--endblock--注释:
  
  --------------------------------------------------------------------------------------------
  
  窗体代码
  把以下代码回到窗体里
  OptionExplicit
  
  PrivateSubCommand1_Click()
  
  DimECHOAsICMP_ECHO_REPLY
  DimposAsLong
  DimsuccessAsLong
  
  IfSocketsInitialize()Then
  
  注释:pingtheippassingtheaddress,text
  注释:tosend,andtheECHOstructure.
  success=Ping((Text1.Text),(Text2.Text),ECHO)
  
  注释:displaytheresults
  Text4(0).Text=GetStatusCode(success)
  Text4(1).Text=ECHO.Address
  Text4(2).Text=ECHO.RoundTripTime&"ms"
  Text4(3).Text=ECHO.DataSize&"bytes"
  
  IfLeft$(ECHO.Data,1)Chr$(0)Then
  pos=InStr(ECHO.Data,Chr$(0))
  Text4(4).Text=Left$(ECHO.Data,pos-1)
  EndIf
  
  Text4(5).Text=ECHO.DataPointer
  
  SocketsCleanup
  
  Else
  
  MsgBox"WindowsSocketsfor32bitWindows"&"environmentsisnotsuccessfullyresponding."
  
  EndIf
  
  EndSub

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)->

来源:https://www.tulaoshi.com/n/20160219/1616952.html

延伸阅读
众所周知,VisualBasic是功能非常强大的多媒体开发工具,它有丰富的函数和方法处理各种各样的多媒体信息,能够很灵活的操作图形、声音、动画、影象等多媒体素材。但有时我们使用VisualBasic开发非多媒体应用程序,并不需要在应用程序中大量的使用声音,而只是需要在特定的场合出现。如Windows的警告声。这就要求程序员在恰当的环境中恰当的使用...
尽管Windows的API函数在当今Visual成风的时代正渐渐被人们忘却,但是正如当年开发高技巧的DOS软件离不开汇编语言和DOS系统功能调用一样,无论开发平台高级到什么地步,只要Windows还在最底层运作,就要用到API函数。无论VB的开发手段多么高明,功能多么强大,但是在现实应用中,总有一些功能的实现是VB无能为力的。微软也早意识到这一点,...
标签: 电脑入门
通过Linux下的history命令我们可以查看用过的命令,即历史命令,今天本文将详细介绍Linux下history的具体用法,一起来了解下吧。 一、什么是history 在bash功能中,它能记忆使用过的命令,这个功能最大的好处就是可以查询曾经做过的举动! 从而可以知道你的运行步骤,那么就可以追踪你曾下达过的命令,以作为除错的工具! 二、Histor...
Win7系统使用Ping命令时提示“Ping不是内外部命令”怎么办   1、在计算机图标上右键选择属性,在打开的计算机属性设置窗口中选择高级系统设置; 2、在弹出的系统属性窗口中,切换到高级标签页,点击环境变量,进入另一个窗口; 3、在Win7环境变量窗口中,找到系统变量,在变量项中找到path的路径设置,点击下方的编辑按...
标签: 电脑入门
Linux中sed命令主要用于文本的处理,可处理文本的行和列,下面图老师小编就给大家详细介绍下Linux中sed命令的用法,有兴趣的朋友不妨来了解下吧。 sed命令行格式为: sed [-nefri] ‘command’ 输入文本 常用选项: -n∶使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上。但...

经验教程

496

收藏

42
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部