黑客编程破处之旅:简易端口扫描器

简介:

传承裴老师与孟老师《windows黑客技术解密与攻防 I--C语言篇》的教诲,写下自己的第一段黑客编程代码,以此祭奠昔日的梦想,并作为对自己的鼓励。


   简易端口扫描器:

   代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/*
  新手练手:
  简易端口扫描器
*/
#include <stdio.h>
#include <winsock2.h>
#pragma comment(lib,"ws2_32")
#define START 20
#define END 500
int  main( int  argc, char  *argv[])
{
                                                                                                                                                                                                
     if (argc!=2)
     {
         printf ( "Usage:scanport<IP>\n" );
         return  -1;
     }
                                                                                                                                                                                                
     int  i;
     WSADATA ws;       //用于接受winsock结构
     SOCKET sockfd;
     struct  sockaddr_in their_addr;
     WSAStartup(MAKEWORD(2,2),&ws);
     their_addr.sin_family = AF_INET;
     their_addr.sin_addr.S_un.S_addr = inet_addr(argv[1]);
     //根据命令行参数确定扫描IP
     for (i = START;i<=END;i++)
     {
         //循环建立socket后连接
         sockfd = socket(AF_INET,SOCK_STREAM,0);
         their_addr.sin_port = htons(i);
         printf ( "正在扫描的端口:%d\n" ,i);
         if (connect(sockfd,( struct  sockaddr *)&their_addr, sizeof ( struct  sockaddr))==SOCKET_ERROR)
         {
             //如果端口扫描失败,则进行下一个端口的扫描
             continue ;
         }
         //否则认为此端口开放
         printf ( "-------------端口 %d 开放!-------------\n\n" ,i);
     }
     closesocket(sockfd);
     WSACleanup();
     return  0;
}
/*
扫描速度每秒才两个,过慢,不符合实际,可使用多线程技术改装。
*/
/*
   调试提示:开始-->运行-->输入"cmd"-->找到生成的xxx.exe程序所在路径-->输入:xxx argv[1]  就可以了
*/


   <编译环境:VC++ 6.0>


   PS:

   看到这段代码,内心兴奋的同时,不觉间又黯然神伤。

   总觉的自己学的很多了,却是还要差的远。多线程技术啊,一定得掌握,不然这速度,也太慢了。留作纪念。



本文转自 006玩命 51CTO博客,原文链接:http://blog.51cto.com/weiyuqingcheng/1377194,如需转载请自行联系原作者

相关文章
|
8月前
|
网络协议 Shell 网络安全
iOS 逆向编程(九 - 1)通过 USB 连接登录 iPhone 以及端口映射
iOS 逆向编程(九 - 1)通过 USB 连接登录 iPhone 以及端口映射
170 0
|
Python
Python编程:Tornado获取客户端的端口port
Python编程:Tornado获取客户端的端口port
45 0
|
4月前
|
Ubuntu 关系型数据库 MySQL
百度搜索:蓝易云【ubuntu20.4服务器安装mysql社区版并开放3306端口】
现在,你已经在Ubuntu 20.04服务器上成功安装了MySQL社区版,并且已经开放了3306端口,可以通过该端口访问MySQL服务器了。请确保在生产环境中设置安全措施,例如设置强密码、限制访问等,以保护数据库的安全性。
94 2
|
3月前
|
Java Nacos Docker
在集成nacos时,端口9848报错但服务器的这个端口是开放的
在集成nacos时,端口9848报错但服务器的这个端口是开放的【1月更文挑战第14天】【1月更文挑战第67篇】
196 1
|
6月前
|
网络安全 数据安全/隐私保护
百度搜索:蓝易云【多个端口怎么运行SSH服务器?】
记得替换 `username`为你的用户名,`your_server_ip`为你的服务器IP地址。根据需要,可以添加其他端口并进行相应的配置。
82 0
|
1月前
|
安全 Windows
服务器中如何检查端口是否开放
服务器中如何检查端口是否开放
|
6月前
|
网络协议 Linux 数据安全/隐私保护
如何在Windows本地快速搭建SFTP文件服务器,并通过端口映射实现公网远程访问
如何在Windows本地快速搭建SFTP文件服务器,并通过端口映射实现公网远程访问
|
7月前
|
Ubuntu 安全 Shell
Ubuntu服务器安全性提升:修改SSH默认端口号
在Ubuntu服务器上,SSH(Secure Shell)是一种至关重要的远程连接工具。它提供了一种安全的方式来远程连接和管理计算机系统,通过加密通信来确保数据的保密性和完整性。SSH协议广泛用于计算机网络中,用于远程管理、文件传输和安全通信等任务。然而,SSH默认使用的端口号是22,这也是黑客们常常尝试入侵的目标之一。为了提高服务器的安全性,我们通常建议修改SSH的默认端口号,以减少未经授权的访问和潜在的风险。接下来,我们将详细介绍如何在Ubuntu上执行这一关键操作。
231 4
Ubuntu服务器安全性提升:修改SSH默认端口号
|
2月前
|
存储 网络协议 Ubuntu
Linux环境下SVN服务器的搭建与公网访问:使用cpolar端口映射的实现方法
由于文档资料越来越多,将所有资料都存放在自己的电脑上容易混淆,并且也不利于分享。这种情况下,考虑将资料上传SVN统一管理,这样一来其他人也能很方便的查略各种资料。