搜索
系统检测到您的用户名不符合规范:

最近的项目需要特别关注sql安全问题,有些体会

浏览:539 发布日期:2017年11月01日 分类:技术分享
最近的项目需要特别注意sql安全问题,到网上查了一些关于sql注入的,多数是说:

$password = md5($_POST['password']);

select * from user where user='$user' and password='$password'; 不安全,原因是$user = "' or '1=1'" 或者$user = "'; -- " 之类的,登录查询分开两句查就没各种问题了。

例如:

$find = M('User')->where("username='$username'")->find();
$uid = $find['uid'];

$find2 = M('User')->where("uid='$uid'")->find();

$find_password = $find2['password'];

if($find_password == md5($password)){...}


另外,看到一些关于组装sql语句不安全,说是可以在变量中加上

自定义的查询,如:

select * from user ..... (select * from infomation ...) 等,这让我觉得倒是TP的__TABLE__,__PREFIX__字符变的不安全了。(针对TP3.2.3),因为在提交的数据不知道表前缀的情况下,给字符串加上__TABLE__ 或者 __PREFIX__,又在接收数据后再组装SQL,正好把表前缀自动加上了。

所以 ,我觉得过滤提交数据时,也需要把__TABLE__ 和 __PREFIX__过滤掉。

最佳答案
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
50030
积分:1129 等级:LV3
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /