基于tcp的端口扫描原理与实现.doc
文本预览下载声明
基于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
显示全部