文档详情

基于tcp的端口扫描原理与实现.doc

发布:2018-04-18约1.95千字共4页下载文档
文本预览下载声明
基于tcp的端口扫描原理与实现 基于tcp的端口扫描原理与实现 1.工作原理 基于tcp协议的网络应用程序在通讯过程中首先要建立连接。三次握手,本次实验端口扫描所在的主机的客户机,被扫描的主机是服务器,客户机与服务器的指定端口试图建立连接。若连接成功证明指定端口开放。 2.程序设计 (1)设计要求 1.要求可以输入扫面的目的主机的IP地址和端口,输出端口的状态 2.要求可以扫描任意安装tcp/ip协议的主机,并且可以扫描该主机的任何一个端口。 3.要求在Windows操作系统环境中。 (2)主要代码 定义头文件 #include #include\ #pragmacomment(lib,\) 在CTcpPortScanDlg类里面定义私有成员变量 SOCKET Socket; 添加按键响应函数 voidCTcpPortScanDlg::OnBnClickedButton1() { // TODO: 在此添加控件通知处理程序代码 UpdateData(true); int count = m_List.GetItemCount(); WSADATA WSAData; if (WSAStartup(MAKEWORD(2, 2), WSAData) != 0) { } Socket = socket(AF_INET, SOCK_STREAM, 0);//创建链接套接字 if (Socket == INVALID_SOCKET) { } int IpAddress; IpAddress = inet_addr(m_Address); //判断域名或ip地址 if (IpAddress == INADDR_NONE) { hostent* pHostent = gethostbyname(m_Address); if (pHostent) MessageBox(\创建Socket失败!\); WSACleanup(); return; MessageBox(\初始化失败!\); return; } } IpAddress = (*(in_addr*)pHostent-h_addr).s_addr; sockaddr_in DestHost; //定义套接字地址 memset(DestHost, 0, sizeof(DestHost)); DestHost.sin_family = AF_INET; DestHost.sin_port = htons(atoi(m_Port)); DestHost.sin_addr.s_addr = IpAddress; int nConnect; //与服务器建立连接 nConnect = connect(Socket, (sockaddr*)DestHost, sizeof(DestHost)); if (nConnect == SOCKET_ERROR) { } else { } UpdateData(false); closesocket(Socket); WSACleanup(); //释放套接字 m_List.InsertItem(count, m_Address); m_List.SetItemText(count, 1, m_Port); m_List.SetItemText(count, 2, \); int n = WSAGetLastError(); m_List.InsertItem(count, m_Address); m_List.SetItemText(count, 1, m_Port); m_List.SetItemText(count, 2, \); 在CTcpPortScanDlg::OnInitDialog()函数里定义list的样式。 m_List.InsertColumn(0, \主机地址\, LVCFMT_CENTER, 160); m_List.InsertColumn(1, \端口号\, LVCFMT_CENTER, 100); m_List.InsertColumn(2, \端口状态\, LVCFMT_CENTER, 100); 3.程序测试(程序运行结果) 百度搜索“就爱阅读”,专业资料、生活学习,尽在就爱阅读网92,您的在线图书馆! 1
显示全部
相似文档