透析ICMP协议(3): 应用篇ping(ICMP.dll)

2016-02-19 17:13 41 1 收藏

下面图老师小编要向大家介绍下透析ICMP协议(3): 应用篇ping(ICMP.dll),看起来复杂实则是简单的,掌握好技巧就OK,喜欢就赶紧收藏起来吧!

【 tulaoshi.com - 编程语言 】

  原理简介:

  --------

  这个例子演示了应用微软的ICMP.DLL怎样"ping"另一台机器. 这个DLL是没有文档话的发送ICMP回送包API接口, 也称为"pings," 就像潜水员对声纳信号的术语一样. 这段代码出自一个被一个名叫MarkG的家伙的GUI程序, 他的网页已经消失了.

  ICMP.DLL API 现在在Windows平台上与微软的Winsocks工作的很好, 但是微软说更好的产品一出来他们将替换它. 微软说这个自从Windows 95时代就在用, 这些功能在在Windows 2000上仍然存在.

  For more information on the ICMP.DLL API, check out sockets.com's ICMP API page.

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

  更详细的ICMP.DLL API的信息到sockets.com的ICMP API网页获取.

  具体实现:

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

  --------

  

// Borland C++ 5.0: bcc32.cpp ping.cpp// Visual C++ 5.0: cl ping.cpp wsock32.lib//// This sample program is hereby placed in the public domain.#include iostream.h#include winsock.h#include windowsx.h#include "icmpdefs.h"

  ==================ping的实现部分==================

  

int doit(int argc, char* argv[]){//[bugfree] 建议将这个argc和argv的处理拿到main函数中// 检查命令行参数if (argc  2) {cerr  "usage: ping host"  endl;return 1;}// 装载ICMP.DLL连接库HINSTANCE hIcmp = LoadLibrary("ICMP.DLL");if (hIcmp == 0) {cerr  "Unable to locate ICMP.DLL!"  endl;return 2;}// 查找给定机器的IP地址信息struct hostent* phe;if ((phe = gethostbyname(argv[1])) == 0) {cerr  "Could not find IP address for "  argv[1]  endl;return 3;}// 定义函数三个指针类型typedef HANDLE (WINAPI* pfnHV)(VOID);typedef BOOL (WINAPI* pfnBH)(HANDLE);typedef DWORD (WINAPI* pfnDHDPWPipPDD)(HANDLE, DWORD, LPVOID, WORD,PIP_OPTION_INFORMATION, LPVOID, DWORD, DWORD); // evil, no?//定义三个指针函数pfnHV pIcmpCreateFile;pfnBH pIcmpCloseHandle;pfnDHDPWPipPDD pIcmpSendEcho;//从ICMP.DLL中得到函数入口地址pIcmpCreateFile = (pfnHV)GetProcAddress(hIcmp, "IcmpCreateFile");pIcmpCloseHandle = (pfnBH)GetProcAddress(hIcmp, "IcmpCloseHandle");pIcmpSendEcho = (pfnDHDPWPipPDD)GetProcAddress(hIcmp, "IcmpSendEcho");if ((pIcmpCreateFile == 0) || (pIcmpCloseHandle == 0) ||(pIcmpSendEcho == 0)) {cerr  "Failed to get proc addr for function."  endl;return 4;}// 打开ping服务HANDLE hIP = pIcmpCreateFile();if (hIP == INVALID_HANDLE_VALUE) {cerr  "Unable to open ping service."  endl;return 5;}// 构造ping数据包char acPingBuffer[64];memset(acPingBuffer, 'xAA', sizeof(acPingBuffer));PIP_ECHO_REPLY pIpe = (PIP_ECHO_REPLY)GlobalAlloc( GMEM_FIXED | GMEM_ZEROINIT,sizeof(IP_ECHO_REPLY) + sizeof(acPingBuffer));if (pIpe == 0) {cerr  "Failed to allocate global ping packet buffer."  endl;return 6;}pIpe-Data = acPingBuffer;pIpe-DataSize = sizeof(acPingBuffer); // 发送ping数据包DWORD dwStatus = pIcmpSendEcho(hIP, *((DWORD*)phe-h_addr_list[0]),acPingBuffer, sizeof(acPingBuffer), NULL, pIpe,sizeof(IP_ECHO_REPLY) + sizeof(acPingBuffer), 5000);if (dwStatus != 0) {cout  "Addr: " int(LOBYTE(LOWORD(pIpe-Address)))  "." int(HIBYTE(LOWORD(pIpe-Address)))  "." int(LOBYTE(HIWORD(pIpe-Address)))  "." int(HIBYTE(HIWORD(pIpe-Address)))  ", " "RTT: "  int(pIpe-RoundTripTime)  "ms, " "TTL: "  int(pIpe-Options.Ttl)  endl;}else {cerr  "Error obtaining info from ping packet."  endl;}// 关闭,回收资源GlobalFree(pIpe);FreeLibrary(hIcmp);return 0;}

  ==================主函数==================

  

int main(int argc, char* argv[]){WSAData wsaData;if (WSAStartup(MAKEWORD(1, 1), &wsaData) != 0) {return 255;}int retval = doit(argc, argv);WSACleanup();return retval;}

  ==================头文件==================

  

icmpdefs.h//ICMP.DLL 函数中需要的结构 typedef struct {unsigned char Ttl; // Time To Liveunsigned char Tos; // Type Of Serviceunsigned char Flags; // IP header flagsunsigned char OptionsSize; // Size in bytes of options dataunsigned char *OptionsData; // Pointer to options data} IP_OPTION_INFORMATION, * PIP_OPTION_INFORMATION;typedef struct {DWORD Address; // Replying addressunsigned long Status; // Reply statusunsigned long RoundTripTime; // RTT in millisecondsunsigned short DataSize; // Echo data sizeunsigned short Reserved; // Reserved for system usevoid *Data; // Pointer to the echo dataIP_OPTION_INFORMATION Options; // Reply options} IP_ECHO_REPLY, * PIP_ECHO_REPLY;

联系方式: zhangliangsd@hotmail.com

来源:http://www.tulaoshi.com/n/20160219/1614593.html

延伸阅读
功能说明: 检测主机。 语 法: ping [-dfnqrRv][-c<完成次数][-i<间隔秒数][-I<网络界面][-l<前置载入][-p<范本样式][-s<数据包大小][-t<存活数值][主机名称或IP地址] 补充说明: 执行ping指令会使用ICMP传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正...
《阿尔法协议》图文攻略(graybox篇) Graybox 先说一下基本的控制操控 移动还是经典的WSAD模式,LSHIFT是冲刺跑;蹲下时LCRTL。开火/加快过场动画是鼠标左键。调整为准星模式是鼠标右键 填弹是R;使用技能是Q;使用特殊物品(譬如手雷,炸弹)是G 更换武器是鼠标滚轮;近战格斗是E;对物品进行动作时空格。调整技能是Z,调整特殊物...
标签: flash教程
如果你还不满意,你还可以为这个地球做一个光环!将第二层的圆形复制同位粘贴到新层,进行填充,渐变设置如下图: 填充好,将圆形放大120%,然后将第二层的圆形复制再一次同位粘贴在放大的圆形上,选取它删除,如下图: 给这个地球加个环绕的卫星或是文字 ,岂不更漂亮!注意又要用到遮罩了!
《阿尔法协议》图文攻略(rome篇) ROME篇 本关任务还是比较难的,因为本关很多任务的敌人都是战斗力很强的 BUG CIA LISTENING POST 这个任务主要是让你去瘫痪CIA的监听系统。本关还是比较简单的。敌人数量不是很多。本任务可以作为你熟练一下具体操作的任务。 这个任务需要你去商店买齐2个INTEL 首先来到地下室,把地下室的...
《阿尔法协议》攻略--图文(RUSSIA篇) 完成SAUDI ARABIA的部分;你就可以进行你的专职了。 具体分为四大类,SPY,ENGINEER,COMMANDO,OPERATIVE 专职很大程度取决你的初始职业的选择。譬如你初始选择的是FIELD AGENT而且加点的时候,把主要的点数都加到STEALTH和PISTOL技能,则建议你专职为SPY ENGINERRE对应你初始选择的TECH SPECIALIST CO...

经验教程

956

收藏

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