python取代netcat过程分析
作者:以笔为剑的唐吉坷德 发布时间:2021-07-22 17:32:51
标签:python,netcat
首先解释几个概念:
TCP:TCP是因特网中的传输层协议,使用三次握手协议建立连接。
IP:Internet Protocol协议的英文名直译就是:因特网协议。
UDP:和TCP一样,是网络传输层协议,UDP提供了无连接通信,且不对传送数据包进行可靠性保证,适合于一次传输少量数据。
scoket:
网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。建立网络通信连接至少要一对端口号(socket)。socket本质是编程接口(API),对TCP/IP的封装,TCP/IP也要提供可供程序员做网络开发所用的接口,这就是Socket编程接口;HTTP是轿车,提供了封装或者显示数据的具体形式;Socket是发动机,提供了网络通信的能力。
Linux中Netcat命令整理参考:https://www.jb51.net/article/134906.htm
我们所要学习的,就是用python模仿netcat来做一些很神奇的事情。
创建一个简单的TCP客户端:
# -*- coding: utf-8 -*-
import socket
target_host = "www.baidu.com"
target_port = 80
#建立socket对象,建立包含AF_INET,和SOCK_STREAM参数的socket对象。AF_INET参数锁门我们使用IPV4地址,SOCK_STREAM说明这是一个TCP客户端
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#连接客户端
client.connect((target_host, target_port))
#send some data
client.send("GET / HTTP/1.1\r\nHsot:baidu.com\r\n\r\n")
#get some data
response = client.recv(4096)
print response
创建一个基础的TCP服务器:
# -*- coding: utf-8 -*-
import socket
import threading
bind_ip = '0.0.0.0'
bind_port=9999
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
server.bind((bind_ip, bind_port))
server.listen(5)
print "[+]listening on %s, %d"%(bind_ip,bind_port)
#创建客户处理线程
def handle_client(client_socket):
#打印客户端发送得到的内容
request = client_socket.recv(1024)
print "[*]Recived:%s"%request
#返回数据包
client_socket.send("Fuck You All!")
client_socket.close()
while True:
client, addr=server.accept()
print "[*]Accepted connection from:%s:%d"%(addr[0], addr[1])
#挂起客户端,处理传入数据
client_handler = threading.Thread(target=handle_client,args=(client,))
client_handler.start()
由于之前没有接触过,于是对TCP服务器和TCP客户端有一定的疑问,于是开始寻找答案。
1、客户根据用户提供的IP地址连接到相应的服务器;
2、服务器等待客户的连接,一旦连接成功,则显示客户的IP地址、端口号,并向客户端发送字符串;
3、客户接收服务器发送的信息并显示。
如果没有理解错的话,应该是客户端控制服务端。
将上面的TCP客户端的target_ip修改后,可以控制该服务端。修改send()函数。
来源:http://blog.csdn.net/Greepex/article/details/72823546


猜你喜欢
- 在本地windows机器开发的Django项目运行正常,放到服务器上后响应超慢,花了一整个工作日没找到原因(非常绝望),又花了一整个周末才找
- 一、python压缩模块简介python直接通过内置压缩模块可以直接进行压缩文件的创建;内置模块 zipfile/rarfile 完成压缩文
- 扫雷是一款益智类小游戏,最早于 1992 年由微软在 Windows 上发行,游戏适合于全年龄段,规则简单,即在最短的时间内找出所有非雷格子
- 这篇文章主要介绍了基于Python获取城市近7天天气预报,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的
- 一、Ajax简介Ajax被认为是(Asynchronous JavaScript and XML)的缩写,允许浏览器与服务器通信而无需刷新当
- 在任何有监督机器学习项目的模型构建阶段,我们训练模型的目的是从标记的示例中学习所有权重和偏差的最佳值。如果我们使用相同的标记示例来测试我们的
- 今天继续给大家介绍Python相关知识,本文主要内容是Python asyncio异步编程常见问题。一、asyncio编程简单示例首先,我们
- 概述map是基于key-value键值对的无序的集合Go语言中的map是引用类型必须初始化才能使用。语法声明和初始化配合make使用,否则是
- 这里用到django-rest-framework-jwt这个库 https://github.com/GetBli
- 前言:我们在做自动化测试的时候,大家都是希望自己写的代码越简洁越好,代码重复量越少越好。那么,我们可以考虑将request的请求类型(如:G
- 在网上看了很多解决方法,都没有解决,后来我自己解决了这个问题:出现的问题:在cmd上 “pip install package” 时显示 s
- 1. 服务器优化优化原则:内存里的数据要比磁盘上的数据访问起来快;站数据尽可能长时间地留在内存里能减少磁盘读写活动的工作量;让索引信息留在内
- 定义函数:CREATE FUNCTION [dbo].[GetAge] ( @BirthDay nvarchar(2
- Centos7的yum源中默认是没有mysql,因为现在已经用mariaDB代替mysql了。首先我们下载mysql的repo源,我们可以去
- 前言最近在维护项目的python项目代码,项目使用了 python 的日志模块 logging, 设定了保存的日志数目, 不过没有生效,还要
- 可迭代对象和迭代器迭代(iterate)意味着重复,就像 for 循环迭代序列和字典那样,但实际上也可使用 for 循环迭代其他对象:实现了
- 单表备份代码:<?php class Db { &n
- 首先:如果备份的数据库有两个文件,分别是.LDF 和 .MDF,打开企业管理器,在实例上右击---所有任务--附加数据库,然后选择那个.MD
- Line plotsAxes3D.plot(xs, ys, *args, **kwargs)绘制2D或3D数据参数描述xs, ysX轴,Y轴
- 在python程序中添加tensoboard一系列代码我就不一一写了。查找资料就可以找到很多这方面的内容。今天我主要是想说下,如何在cmd中