sql 通用高效分页代码(存储过程是带有sql注入)(1/2)

sql 通用高效分页代码(存储过程是带有sql注入)

sql 通用高效分页代码(是带有sql注入)

大家可以看到上面的存储过程中是通过一些步骤最终拼接成一个sql字符串,然后通过exec执行这个串得到分页的结果。

我们假定要做一个这样的查询,通过用户名username模糊查询用户,为了叙述方便,便于理解我们只考虑取第一页的情况,取出存储过程中取第一页的拼串行如下:

为了便于说明问题,我们可以假定@pagesize为20,@strgetfields为 ‘*’,@tblname为useraccount,@strorder为’ order by id desc’ 那么上面一行可以写成如下形式:

set @strsql = ‘select top 20 * from [useraccount] where ‘ + @strwhere + ‘ order by id desc’

我们可以假定用户输入的模糊用户名是: jim’s dog
我们用sqlparameter传递参数给分页存储过程@strwhere 的值是:’username like ‘’%jim” dog%”'(注意like后边的字符串中的单引号已经全部变成两个单引号了),我们将这个值代入上面的@strsql赋值语句中,如下:

set @strsql = ‘select top 20 * from [useraccount] where username like ”%jim” dog%” order by id desc’

让我们写上声明变量的部分执行在查询分析器中测试一下,代码如下:

 

declare @strsql varchar(8000)
declare @strwhere varchar(1000)
set @strwhere = ‘username like ”%jim” dog%”’
set @strsql = ‘select top 20 * from [useraccount] where ‘ + @strwhere + ‘ order by id desc’
print @strsql
exec (@strsql) 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1836893.html

(0)
上一篇 2025年2月21日 22:17:31
下一篇 2025年2月21日 22:17:49

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论