php is_numberic函数造成的SQL注入漏洞


Posted in Javascript onMarch 10, 2014

一、is_numberic函数简介
国内一部分CMS程序里面有用到过is_numberic函数,我们先看看这个函数的结构
bool is_numeric (mixed $var)
如果 var 是数字和数字字符串则返回 TRUE,否则返回 FALSE。
二、函数是否安全
接下来我们来看个例子,说明这个函数是否安全。

$s = is_numeric($_GET['s'])?$_GET['s']:0;
$sql="insert into test(type)values($s);";  //是 values($s) 不是values('$s')
mysql_query($sql);

上面这个片段程序是判断参数s是否为数字,是则返回数字,不是则返回0,然后带入数据库查询。(这样就构造不了sql语句)
我们把‘1 or 1' 转换为16进制 0x31206f722031 为s参数的值
程序运行后,我们查询数据库看看,如下图:
php is_numberic函数造成的SQL注入漏洞
如果再重新查询这个表的字段出来,不做过滤带入另一个SQL语句,将会造成2次注入.
三、 总结
尽量不要使用这函数,如果要使用这个函数,建议使用规范的sql语句,条件加入单引号,这样16进制0x31206f722031就会在数据库里显示出来。而不会出现1 or 1。
Javascript 相关文章推荐
js 操作select相关方法函数
Dec 06 Javascript
jQuery学习4 浏览器的事件模型
Feb 07 Javascript
JavaScript flash复制库类 Zero Clipboard
Jan 17 Javascript
也说JavaScript中String类的replace函数
Sep 22 Javascript
JavaScript 数组详解
Oct 10 Javascript
通过location.replace禁止浏览器后退防止重复提交
Sep 04 Javascript
javascript省市区三级联动下拉框菜单实例演示
Nov 29 Javascript
webpack 3.X学习之多页面打包的方法
Sep 04 Javascript
对Vue.js之事件的绑定(v-on: 或者 @ )详解
Sep 15 Javascript
angular6 填坑之sdk的方法
Dec 27 Javascript
Vue内部渲染视图的方法
Sep 02 Javascript
15个值得收藏的JavaScript函数
Sep 15 Javascript
关于JavaScript对象的动态选择及遍历对象
Mar 10 #Javascript
使用js操作css实现js改变背景图片示例
Mar 10 #Javascript
红米手机抢购的js代码
Mar 10 #Javascript
按下回车键指向下一个位置的一个函数代码
Mar 10 #Javascript
用js判断输入是否为中文的函数
Mar 10 #Javascript
用IE重起计算机或者关机的示例代码
Mar 10 #Javascript
屏蔽相应键盘按钮操作
Mar 10 #Javascript
You might like
php debug 安装技巧
2011/04/30 PHP
thinkphp学习笔记之多表查询
2014/07/28 PHP
mysql desc(DESCRIBE)命令实例讲解
2016/09/24 PHP
解决出现SoapFault (looks like we got no XML document)的问题
2017/06/24 PHP
thinkphp5实现无限级分类
2019/02/18 PHP
Javascript中的变量使用说明
2010/05/18 Javascript
文本框中禁止非数字字符输入比如手机号码、邮编
2013/08/19 Javascript
浅析JavaScript中的同名标识符优先级
2013/12/06 Javascript
对js关键字命名的疑问介绍
2014/04/25 Javascript
js预加载图片方法汇总
2015/06/15 Javascript
javascript从作用域链谈闭包
2020/07/29 Javascript
Angular2 环境配置详细介绍
2016/09/21 Javascript
JS制作类似选项卡切换的年历
2016/12/03 Javascript
详解react使用react-bootstrap当轮子造车
2017/08/15 Javascript
js封装成插件的步骤方法
2017/09/11 Javascript
微信小程序用户自定义模版用法实例分析
2017/11/28 Javascript
jQuery实现新闻播报滚动及淡入淡出效果示例
2018/03/23 jQuery
简单实现vue中的依赖收集与响应的方法
2019/02/18 Javascript
如何用原生js写一个弹窗消息提醒插件
2019/05/24 Javascript
vue-cli history模式实现tomcat部署报404的解决方式
2019/09/06 Javascript
Python不使用int()函数把字符串转换为数字的方法
2018/07/09 Python
使用pandas把某一列的字符值转换为数字的实例
2019/01/29 Python
python爬虫库scrapy简单使用实例详解
2020/02/10 Python
HTML5为输入框添加语音输入功能的实现方法
2017/02/06 HTML / CSS
宝拉珍选官方旗舰店:2%水杨酸精华液,收缩毛孔粗大和祛痘
2018/07/01 全球购物
继承公证书
2014/04/09 职场文书
纪念九一八事变演讲稿:忘记意味着背叛
2014/09/14 职场文书
离婚协议书范本
2015/01/26 职场文书
2015年国庆晚会主持词
2015/07/01 职场文书
标枪加油稿
2015/07/22 职场文书
《失物招领》教学反思
2016/02/20 职场文书
合作协议书格式范本
2016/03/21 职场文书
2016年感恩母亲节活动总结
2016/04/01 职场文书
如何利用js在两个html窗口间通信
2021/04/27 Javascript
Nginx虚拟主机的搭建的实现步骤
2022/01/18 Servers
Grafana可视化监控系统结合SpringBoot使用
2022/04/19 Redis