sql注入原理

目录

1. sql注入的原因

2. 登录案例

3.cms sql注入


1. sql注入的原因

语言可分为解析型语言和编译型语言。解析型是一种在运行时由一个运行时组件解析语言代码并执行其中包含的指令的语言。 而编译型是代码在生成时转换为机器指令,然后在运行时直接由使用改语言的计算机执行这些指令。

在解析型中,如果程序和用户进行交互。用户就可以构造特殊的输入来拼接到程序中执行,从而使得程序依据用户输入执行有可能存在恶意行为的代码。

比如 sql注入

2. 登录案例

登录sql语句: select *from admin where username ='用户输入的用户名'and password ='用户输入的密码'

用户输入的内容可由用户自行控制,例如可由输入'or 1=1'

sql语句: select * from admin where username =''or 1=1 --'and paswword ='用户输入的密码', 其中or 1=1 永远为真, --注释后面的内容不再执行, 因此sql语句执行会返回admin表中的所有内容。

比如这里

 我们是不知道他的用户名还有密码的,我们随便输入一下,然后点登录会出错,提升错误。

那么,我们这样

注意, 1=1 --     -- 后面要加一个空格, 不然不会成功的!

 可以看到,直接绕过了错误提示

3.cms sql注入

 cms逻辑: index.php首页展示内容,具有文章列表(连接具有文章id)、articles.php文章详情页,URL中article.php?id=文章id读取id文章。

sql注入验证:

1. 单引号 '

2. and 1=1

3. and 1=2

如果页面中mysql报错,证明该页面存在sql注入漏洞

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值