SQL注入---HTTP报头注入

文章目录


前文中提到万能密钥的工作原理,然而万能密钥仅在源代码中没有代码审计,此时才被称之为万能密钥,而代码中有代码审计时需要分以下几种情况讨论

一.uagent注入

先看代码:

php 复制代码
<?php
  #提供用于连接数据库的信息(账号密码等)
include("../sql-connections/sql-connect.php");
error_reporting(0);
	
function check_input($value)
	{
    #判断括号中的值是否为空
	if(!empty($value))
		{
        #使用substr()函数截取变量的前20个内容
		$value = substr($value,0,20);
		}

		if (get_magic_quotes_gpc())
			{
			$value = stripslashes($value);
			}
            #使用ctype_digit()检查变量是否全部为数字
		if (!ctype_digit($value))
			{
            #若不全是数字使用mysql_real_escape_string()转译变量中的特殊字符
            #是原先的符号实体化如单引号不再具有闭合的效果
			$value = "'" . mysql_real_escape_string($value) . "'";
			}	
	else
		{
		$value = intval($value);
		}
	return $value;
	}

    #使用php内置函数$_SERVER[]提取http报文中的信息
	$uagent = $_SERVER['HTTP_USER_AGENT'];
	$IP = $_SERVER['REMOTE_ADDR'];
	echo "<br>";
	echo 'Your IP ADDRESS is: ' .$IP;
	echo "<br>";

#使用isset()函数判断变量是否为空
if(isset($_POST['uname']) && isset($_POST['passwd']))

	{
    #使用自定义函数check_input()检查使用post方式传递的账户+密码
	$uname = check_input($_POST['uname']);
	$passwd = check_input($_POST['passwd']);
	
	$fp=fopen('result.txt','a');
	fwrite($fp,'User Agent:'.$uname."\n");
	
	fclose($fp);
	
	$sql="SELECT  users.username, users.password FROM users WHERE users.username=$uname and users.password=$passwd ORDER BY users.id DESC LIMIT 0,1";
	$result1 = mysql_query($sql);
	$row1 = mysql_fetch_array($result1);
		if($row1)
			{
			echo '<font color= "#FFFF00" font size = 3 >';
     #将查询到的数据uagent,IP,uname插入数据库security中的表uagents的列uagent,ip_address,username
			$insert="INSERT INTO `security`.`uagents` (`uagent`, `ip_address`, `username`) VALUES ('$uagent', '$IP', $uname)";
			mysql_query($insert);
			echo "</font>";	
			echo 'Your User Agent is: ' .$uagent;
			echo "</font>";
			echo "<br>";
			print_r(mysql_error());			
			echo "<br><br>";
			echo "<br>";		
			}
	}
?>

了解完上述代码后发现,uagent没有相应的审计代码防止SQL注入,因此可以使用uagent进行注入。


总结

相关推荐
星川水月1 小时前
Access数据库快速入门——外部数据导入和SQL简单查询
数据库·sql·access
ElevenS_it1881 小时前
MySQL慢查询监控与告警实战:从slow_log采集到分钟级定位慢SQL的完整链路配置
android·sql·mysql
wu@555551 小时前
使用acme生成免费https泛域名证书(通配符证书)
网络协议·http·https
阳光九叶草LXGZXJ2 小时前
达梦数据库-学习-57-读写数据页超时告警排查(page[x,x,xxxxxx] disk write uses)-DSC集群版
linux·运维·服务器·数据库·sql·学习
wljt2 小时前
为什么要使用Spring Cloud,而不是HTTP直接调用接口?
spring·http·spring cloud
阳光九叶草LXGZXJ2 小时前
达梦数据库-堆栈看问题-01-asmapi_asm_extent_load
linux·运维·数据库·sql·学习
pixle02 小时前
LangChain v1.2 Text-to-SQL 实战:从入门到生产级部署
sql·langchain·agent·智能助手·text-to-sql
清平乐的技术专栏3 小时前
【FlinkSQL笔记】(二)Flink SQL 基础语法详解
笔记·sql·flink
lolo大魔王3 小时前
Go 语言 HTTP 协议与 RESTful API 实训全解(理论 + 实战 + 规范)
http·golang·restful
清平乐的技术专栏3 小时前
【FlinkSQL笔记】(一)什么是Flink SQL
笔记·sql·flink