UDP socket 的使用 (part 1)

        这几天在看socket编程这块,呵呵,说来惭愧这些知识应该本来在大学应该掌握的,可惜在大学.....
废话少说,应用socket编程时,传输协议要么是TCP,要么是UDP,至于它们之间的区别我在这里就不说了,有不清楚的可以去查下计算机网络里面的基础知识。
      今天说的是使用UDP的socket,仍然是一个简单的C/S架构,我写里一个简单的测试例子,呵呵,现贴出来,供需要的人参考!
      先看Server端的代码:
[code]
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <winsock.h>

const int MYPORT=4950; // the port users will be connecting to
const int MAXBUFLEN=100;


void init_win_socket();
void clean_win_socket();
void close_win_socket(SOCKET &soc_handle);

//this socket is intend to use as a simple server
int main()
{
    puts("start main server....");
   
    //init windows socket
    init_win_socket();
 
    SOCKET main_sock_fd;
    struct sockaddr_in main_soc_addr; // my address information
    struct sockaddr_in client_soc_addr; // connector's address information
   
    int addr_len;
    int numbytes;
    char buf[MAXBUFLEN];
    int ret=0;
    //create the sock
    if ((main_sock_fd = socket(AF_INET, SOCK_DGRAM, 0)) == -1)
    {
       puts("CREATE SOCK ERROR:");
    }
   
    //configure sockaddr_in
    main_soc_addr.sin_family = AF_INET; // host byte order
    main_soc_addr.sin_port = htons(MYPORT); // short, network byte order
    main_soc_addr.sin_addr.s_addr= htonl(INADDR_ANY); // automatically fill with my IP
    memset(main_soc_addr.sin_zero, '/0', sizeof (main_soc_addr.sin_zero));
   
    //bind the socket
    ret = bind(main_sock_fd, (struct sockaddr *)&main_soc_addr, sizeof main_soc_addr);
    if ( ret == -1)
    {
     puts("BIND SOCK ERROR:");
    }
   
    //get data from client socket
    addr_len = sizeof client_soc_addr;
    numbytes = recvfrom(main_sock_fd, buf, MAXBUFLEN-1 , 0,
                                           (struct sockaddr *)&client_soc_addr, &addr_len);
    if (numbytes == -1)
    {
        puts("RECEIVE SOCK ERROR:");
    }
    else
    {
        printf("got packet from %s/n",inet_ntoa(client_soc_addr.sin_addr));
        printf("packet is %d bytes long/n",numbytes);
        buf[numbytes] = '/0';
        printf("packet contains /"%s/"/n",buf);
    }
    //close and clean the sockets
    close_win_socket(main_sock_fd);
    clean_win_socket();
    
    puts("any key to continue...");
    getchar(); 
    return 0; 
}

void init_win_socket()
{
     WSADATA wdata;
     if(WSAStartup(MAKEWORD(2,2), &wdata)!=0)
     {
      puts("WAS ERROR:");
     }   
}

void close_win_socket(SOCKET &soc_handle)
{
     if(soc_handle>0)
     {
          closesocket(soc_handle);
     }
}
void clean_win_socket()
{
     WSACleanup();
}

[/code]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用Python进行多线程扫描的简单nmap脚本: ``` import threading import queue import socket # 将IP地址拆分为四部分 def split_ip(ip): parts = ip.split('.') return int(parts[0]), int(parts[1]), int(parts[2]), int(parts[3]) # 将四个部分的IP地址重新组合 def join_ip(parts): return '.'.join(str(part) for part in parts) # 线程函数,用于扫描一个IP地址的所有端口 def scan_ports(ip, port_queue, open_ports): while not port_queue.empty(): port = port_queue.get() try: # 尝试连接到目标主机的某个端口 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.settimeout(1) # 设置超时时间为1秒 result = sock.connect_ex((ip, port)) sock.close() # 如果端口开放,则将其添加到open_ports中 if result == 0: open_ports.append(port) except: pass # 主函数,用于扫描一个IP地址范围内的所有端口 def scan_range(ip_range): ip_start, ip_end = [split_ip(ip) for ip in ip_range.split('-')] open_ports = [] # 将要扫描的端口数量分成若干个区间 num_ports = 65535 num_threads = 5 ports_per_thread = num_ports // num_threads port_ranges = [ (i * ports_per_thread + 1, (i + 1) * ports_per_thread) for i in range(num_threads) ] port_ranges[-1] = (port_ranges[-1][0], num_ports) # 创建一个端口队列,用于存储所有要扫描的端口 port_queue = queue.Queue() for i in range(num_ports): port_queue.put(i + 1) # 启动多个线程进行端口扫描 threads = [] for i in range(num_threads): thread_port_range = port_ranges[i] thread_ip = (ip_start[0], ip_start[1], ip_start[2], ip_start[3] + i) thread = threading.Thread(target=scan_ports, args=(join_ip(thread_ip), port_queue, open_ports)) thread.start() threads.append(thread) # 等待所有线程完成端口扫描 for thread in threads: thread.join() # 返回所有开放的端口 return open_ports # 使用范例 ip_range = '192.168.0.1-192.168.0.255' open_ports = scan_range(ip_range) print('开放的端口:', open_ports) ``` 请注意,此脚本仅供学习和参考。在进行网络扫描时,请始终遵循相关法律法规并获得授权。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值