首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

emlog后台作者权限SQL注入

自己这么久执迷于python和php,似乎完全忘记自己的初衷。半年前我曾经抱怨自己,学了很多东西但实际上有关安全的知识自己知道的并不多,诸如逆向、免杀、漏洞分析。...----     后台上传附件处,代码在/admin/attachment.php: //上传附件 if ($action == 'upload') { $logid = isset($_GET[...最后将$file_info带入查询,造成了注入。 下面是演示。当你拥有后台作者权限后,登录后台发表文章处,上传一个图片,中途抓包: ?...如图,可以得到管理员密码的hash。图中显示的不全是因为显错注入显示的长度有限,可以使用mysql的substring函数截取一部分显示,分两次注入完毕。...需要后台登录,虽然比较鸡肋,但某些emlog用户使用了自助注册等插件导致任何人可以注册成为作者,并轻易获取管理员权限。

76121
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Hongcms 3.0.0后台SQL注入漏洞分析

    二、漏洞描述 程序在后台进行清空数据库操作时对传入的数据库名过滤不严格,可插入和执行恶意sql语句。...三、影响版本 Hongcms < 3.0.0 四、漏洞细节 首先,我们登录到网站后台管理定位到系统-→数据库维护。 ?...首先程序在APP.php第170行使用call_user_func函数对接受的参数进行动态函数回调: ? 跟进operate: ?...五、漏洞复现 经过上一节的分析,下面我们就要着手构造我们的sql语句,同样我们定位到数据表操作的页面点击要清空的数据表,随后我们用burp截断来修改我们的数据表名称来注入我们构造的sql语句。 ?...看到执行的sql语句和我们预想的一样,我们返回后台页面看看执行的结果: ? 可以看到当前使用的数据库版本已经被查询了出来。 六、修补措施 系统已停止维护,可以考虑自行安装WAF进行防护。

    79660

    PHP代码审计笔记--SQL注入

    0X01 普通注入 SQL参数拼接,未做任何过滤 漏洞示例代码: <?php $con = mysql_connect("localhost","root","root"); if (!...宽字符注入的修复: 方案一:指定php连接mysql的字符集 mysql_set_charset('gbk',$conn); $id =mysql_real_escape_string($_GET['id...将character_set_client设置成binary,就不存在宽字节或多字节的问题了,所有数据以二进制的形式传递,就能有效避免宽字符注入。 B、PHP 编码转换 漏洞示例代码: <?...  入库后转义符就会消失,变成hack',查询出库的就是hack',如果拼接到SQL语句,成功引入了单引号闭合前面字符,导致注入。...3、数据库报错信息泄露防范:   把php.ini文件display_errors = Off,数据库查询函数前面加一个@字符 最有效可预防SQL注入攻击的防御方式:预处理技术进行数据库查询: 防御代码示例

    1.7K20

    PHP 代码审计之死磕 SQL 注入

    本文作者:x1a0t(信安之路代码审计小组成员) 代码审计中对 SQL 注入的审计是很常见的,那么要怎样才能审计出一个 SQL 注入呢?...好,关键点来了,如果接收传入的参数后,进行的是转义操作,一旦程序员后面在拼接 SQL 语句时并没有加引号限制,就会导致 SQL 注入。...然后做代码跟进,直到 SQL 语句的部分 这里找到这么一处,代码:/controller/seller.php:1498 publicfunctioncategoryAjax() { $id...漏洞利用 1、注册商家账号,后台审核通过(复现可直接后台添加商家),然后需要在商品分类处添加一个分类用于时间盲注 2、前台登陆商家管理,构造类似如下数据包 URL: /index.php?...总结 再列两个可能造成 SQL 注入的漏洞点,及编辑器中搜索的关键字: 直接写或拼接的 SQL 语句,全局正则匹配['"]{1}[select|update|insert|delete] SQL 操作函数中存在可能漏洞点

    1.7K00

    php操作mysql防止sql注入(合集)

    为什么预处理和参数化查询可以防止sql注入呢?...在传统的写法中,sql查询语句在程序中拼接,防注入(加斜杠)是在php中处理的,然后就发语句发送到mysql中,mysql其实没有太好的办法对传进来的语句判断哪些是正常的,哪些是恶意的,所以直接查询的方法都有被注入的风险...参考: PHP中如何防止SQL注入 blog.csdn.net/sky_zhe/... 参数化查询为什么能够防止SQL注入 www.cnblogs.com/LoveJe......然而PHP 5.3.6及老版本,并不支持在DSN中定义charset属性(会忽略之),这时如果使用PDO的本地转义,仍然可能导致SQL注入, 如果ATTR_EMULATE_PREPARES=true(默认情况...再论php 5.3.6以前版本中的PDO SQL注入漏洞问题 my.oschina.net/zxu/blo... segmentfault讨论 segmentfault.com/q/10... html

    4.7K20

    SQL注入PHP-MySQL实现手工注入-字符型

    具体来说,它是利用现有应用程序,将(恶意的)SQL命令注入后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL...比如先前的很多影视网站泄露VIP会员密码大多就是通过WEB表单递交查询字符暴出的,这类表单特别容易受到SQL注入式攻击。...以上只是一个简单的SQL注入的例子。 从根本上讲,当开发人员对用户的输入过滤不严,造成了用户可以通过输入SQL语句控制数据库,就会产生SQL注入漏洞。...简而言之,基于字符型的SQL注入即存在SQL注入漏洞的URL参数为字符串类型(需要使用单引号表示)。 字符型SQL注入的关键—–单引号的闭合 MySQL数据库对于单引号的规则如下: a....猜密码 index.php?username=admin' and password='fendo 上图没报错,说明密码正确

    1.3K20

    php中使用PDO预防sql注入

    在建站中,注入(Injection)一直都是一个值得考虑的安全问题,在OWASP(Open Web Application Security Project) TOP 10 中位列第一。...详见OWASP官网https://www.owasp.org/ 当然我们要考虑的不是怎么去注入,而是怎么去防止注入(此处以php+MySQL作例) 对参数进行安全化处理。...安装可以查看文档https://www.php.net/manual/zh/pdo.installation.php PDO同时也支持其他的数据库类型,这也极大的简化了php中原有的与数据库交互的形式...端口 $user = 'root'; //用户名 $pwd = 'root'; //密码 $dbname = 'test'; //库名称 $db = new PDO("mysql:dbname=...之所以造成sql注入的原因,是因为用户恶意对我们的SQL语句进行拼接,而PDO中的prepare方法则解决了这个问题。处理数据也就是 增删改查,实例如下: //查 $wd = '%'.

    1.2K20

    1.1.1-SQL注入-SQL注入基础-SQL注入原理分析

    SQL注入原理分析 SQL注入背景介绍-SQL语言介绍 sql 结构化查询语言 通用的功能极强的关系数据库标准语言 功能包括查询、操纵、定义和控制四个方面 不需要告诉SQL如何访问数据库,只要告诉SQL...SQL注入核心原理 SQL注入是一种将恶意的SQL代码插入或添加到应用(用户)的输入参数的攻击,攻击者探测出开发者编程过程中的漏洞,利用这些漏洞,巧妙的构造SQL语句对数据库系统的内容进行直接检索或修改...灵活的SQL查询语句+用户输入的数据带入了SQL语句=用户直接操作数据库->SQL注入漏洞 select version(); select id from where id=1; select id...语句,产生SQL注入漏洞 http://test.com/index.php?...vi index.php // 编辑 echo $sql :wq todo sqli-labs源码地址 docker ps -a docker exec -it /bin/bash cd /

    1.5K20

    SQL注入(SQL注入(SQLi)攻击)攻击-联合注入

    页面有显示位时 , 可用联合注入 本次以 SQLi 第一关为案例 第一步,判断注入类型 参数中添加 单引号 ' , 如果报错,说明后端没有过滤参数 , 即 存在注入 ?...id=1' 从数据库的报错中我们可得知 , 最外边的一对单引号是错误提示自带的,我们不用管 我们输入的1 , 两边的一对单引号 , 是SQL拼接参数时使用的 而1 右边的单引号 , 是我们自己输入的...也就是说 , 后台SQL中拼接参数时 , 使用的是单引号 , 固 注入点为 单引号字符串型 第二步,获取字段数 order by 1 , 即 根据第1列排序 , 修改排序的列,如果存在该列,则会正常显示...左边的查询结果显示在上方,右边的查询结果显示在下方 , 前提是两个查询结果的字段数一致 , 如果字段数不一致则会报错 , 这也是我们上一步需要获取字段数的原因  我们输入id为-1 , 由于id没有负数,导致SQL

    2.3K30

    SQL注入攻击(SQL注入(SQLi)攻击)-报错注入

    页面没有显示位 , 但有数据库的报错信息时 , 可使用报错注入 报错注入是最常用的注入方式 , 也是使用起来最方便(我觉得)的一种注入方式 updatexml(1,'~',3); 第二个参数包含特殊字符时...,数据库会报错,并将第二个参数的内容显示在报错内容中 返回结果的长度不超过32个字符 MySQL5.1及以上版本使用 本次以SQLi第一关为案例 第一步,判断注入类型 我们在参数中加入一个单引号 '...id=1' 数据库返回了一个错误 , 从错误来看 , 最外层的一对单引号来自数据库的报错格式 , 我们不用管 1 是我们传递的参数 , 1旁边的一对单引号 , 是SQL中包裹参数的单引号 而 1 右边的一个单引号..., 是我们添加的单引号 也就是说 , 后台SQL中传递参数时 , 参数包裹的就是单引号 , 固 单引号字符串型注入 第二步,脱库 我们先来测试一下 , updatexml()是否能正常报错 ?...schema_name from information_schema.schemata limit 0,1) ),3) -- a 使用分页来查询第几个数据库 , 0开始 接下来可以将'~' 后面的SQL

    2.6K10
    领券