如何有效防止sql注入
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,如何有效防止sql注入?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。@RestControllerpublic clas
千家信息网最后更新 2025年01月22日如何有效防止sql注入
如何有效防止sql注入?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
@RestControllerpublic class Controller { @Autowired SqlInject sqlInject; @GetMapping("list") public ListcourseList(@RequestParam("studentId") String studentId){ List orders = sqlInject.orderList(studentId); return orders; }}
@Servicepublic class SqlInject { @Autowired private JdbcTemplate jdbcTemplate; public ListorderList(String studentId){ String sql = "select id,course_id,student_id,status from course where student_id = "+ studentId; return jdbcTemplate.query(sql,new BeanPropertyRowMapper(Course.class)); }}
二 注入攻击演示
1. 正常情况下查询一个学生所选课程及完成情况只需要传入student_id,便可以查到相关数据。
根据响应结果,我们很快便能写出对应的sql,如下:
select id,course_id,student_id,status from course where student_id = 4
2. 如果我们想要获取这张表的所有数据,只需要保证上面这个sql的where条件恒真就可以了。
select id,course_id,student_id,status from course where student_id = 4 or 1 = 1
请求接口的时候将studendId 设置为4 or 1 = 1,这样这条sql的where条件就恒真了。sql也就等同于下面这样
select id,course_id,student_id,status from course
请求结果如下,我们拿到了这张表的所有数据
3. 查询mysql版本号,使用union拼接sql
union select 1,1,version(),1
4. 查询数据库名
union select 1,1,database(),1
5. 查询mysql当前用户的所有库
union select 1,1, (SELECT GROUP_CONCAT(schema_name) FROM information_schema.schemata) schemaName,1
看完上面这些演示后,你害怕了吗?你所有的数据配置都完全暴露出来了,除此之外,还可以完成很多操作,更新数据、删库、删表等等。
三 如何防止sql注入
1. 代码层防止sql注入攻击的最佳方案就是sql预编译
public ListorderList(String studentId){ String sql = "select id,course_id,student_id,status from course where student_id = ?"; return jdbcTemplate.query(sql,new Object[]{studentId},new BeanPropertyRowMapper(Course.class));}
这样我们传进来的参数 4 or 1 = 1
就会被当作是一个student_id
,所以就不会出现sql注入了。
2. 确认每种数据的类型,比如是数字,数据库则必须使用int类型来存储
3. 规定数据长度,能在一定程度上防止sql注入
4. 严格限制数据库权限,能最大程度减少sql注入的危害
5. 避免直接响应一些sql异常信息,sql发生异常后,自定义异常进行响应
6. 过滤参数中含有的一些数据库关键词
@Componentpublic class SqlInjectionFilter implements Filter { @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws IOException, ServletException { HttpServletRequest req=(HttpServletRequest)servletRequest; HttpServletRequest res=(HttpServletRequest)servletResponse; //获得所有请求参数名 Enumeration params = req.getParameterNames(); String sql = ""; while (params.hasMoreElements()) { // 得到参数名 String name = params.nextElement().toString(); // 得到参数对应值 String[] value = req.getParameterValues(name); for (int i = 0; i < value.length; i++) { sql = sql + value[i]; } } if (sqlValidate(sql)) { throw new IOException("您发送请求中的参数中含有非法字符"); } else { chain.doFilter(servletRequest,servletResponse); } } /** * 关键词校验 * @param str * @return */ protected static boolean sqlValidate(String str) { // 统一转为小写 str = str.toLowerCase(); // 过滤掉的sql关键字,可以手动添加 String badStr = "'|and|exec|execute|insert|select|delete|update|count|drop|*|%|chr|mid|master|truncate|" + "char|declare|sitename|net user|xp_cmdshell|;|or|-|+|,|like'|and|exec|execute|insert|create|drop|" + "table|from|grant|use|group_concat|column_name|" + "information_schema.columns|table_schema|union|where|select|delete|update|order|by|count|*|" + "chr|mid|master|truncate|char|declare|or|;|-|--|+|,|like|//|/|%|#"; String[] badStrs = badStr.split("\\|"); for (int i = 0; i < badStrs.length; i++) { if (str.indexOf(badStrs[i]) >= 0) { return true; } } return false; }}
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
数据
参数
数据库
查询
关键
关键词
情况
条件
程度
类型
结果
帮助
攻击
演示
有效
清楚
代码
关键字
内容
字符
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
如何取消网络安全模式
集美广电网络技术员工资
数据库中主键 索引和外键
焦作思启网络技术有限公司
遇到软件开发钱不给
计算机网络技术专业试题
远程登录另一网段的数据库
带数据库的触摸屏
网络安全基础知识论文1000字
苹果手机跳无法验证服务器身份
学生会网络技术部展望
计算机网络技术专业用学高数吗
运行2016数据库最低配置
葫芦岛新零售软件开发价格
房管局数据库app
数据库中的技术有哪些问题
cf进去服务器就卡死
网络技术实习收获
南京市文投互联网科技
数据库导入怎么操作
售后服务规范软件开发培训
青岛三线服务器机房
数据库系统原理学习需要电脑吗
服务器管理没有本地服务器
计算机网络技术校验码
东营联想服务器代理拆机
电脑软件开发要考什么证书
vpn服务器配置
合肥ios软件开发多少钱
网络安全 日资 比例