【安全测试】5_应用服务器安全性测试 _SQL注入和文件上传漏洞

文章目录

  • 一、SQL注入
    • [1.1 SQl注入原理](#1.1 SQl注入原理)
    • [1.2 SQl注入常用SQl语句](#1.2 SQl注入常用SQl语句)
    • [1.3 SQL注入防范](#1.3 SQL注入防范)
  • 二、文件上传漏洞
    • [2.1 文件上传漏洞原理](#2.1 文件上传漏洞原理)
    • [2.2 文件上传漏洞防范](#2.2 文件上传漏洞防范)

一、SQL注入

SQL注入攻击:指通过构建特殊的请求参数传入应用程序,通过执行SQL语句进而执行攻击者所要的操作。

  • 主要的原因是程序没有细致地过滤用户输入的数据,导致非法数据侵入系统。
  • SQL注入在安全问题中排行榜首!

1.1 SQl注入原理

1.2 SQl注入常用SQl语句

sql 复制代码
select version(),user(),database(); --版本号、用户、库名
select * from t_user limit 1;  
select * from t_user order by 1;
select * from t_user where id=-1 union select 1,2,3,4,5,6; --SQL注入攻击尝试,其目的是通过UNION操作符合并两个查询的结果,从而可能获取数据库中未授权的数据(前提条件:两张表的字段个数一样)
select * from t_user; --注释
select * fromt_user; # 注释
show databases;
show tables;
show columns from tableName;

1.3 SQL注入防范

  • 对用户的输入数据进行校验。
  • 不要动态拼装SQL,使用参数化语句。
  • 不要使用管理员权限的数据库连接,为每个应用使用单独的权限进行数据库连接。
  • 不要把敏感数据直接保存到数据库中(加密)。
  • 应用的异常信息应该给出尽可能少的提示,最好使用自定义的错误信息对原始错误信息进行包装。

二、文件上传漏洞

文件上传漏洞:指攻击者上传了一个可执行的文件(木马,病毒,恶意脚本),并通过此脚本文件获得了执行服务器命令的能力。

2.1 文件上传漏洞原理

1、大部分的网站都有上传功能,而程序员在开发文件上传功能时,并未考虑文件后缀名的合法性校验。

2、这时攻击者可以上传一个与网站脚本语言相对应的恶意代码动态脚本,例如(jsp、asp、php文件)到服务器上。

3、当访问这些恶意脚本中包含的恶意代码时,进行动态解析最终达到执行恶意代码的效果,从而影响服务器安全。

2.2 文件上传漏洞防范

  • 文件上传的目录设置为不可执行
  • 判断文件类型
  • 使用随机数改写文件名和文件路径
  • 单独设置文件服务器的域名
相关推荐
阿波罗尼亚6 小时前
数据库序列(Sequence)
数据库
Junsir大斗师6 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish6 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
m0_596749098 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
老纪的技术唠嗑局9 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
2301_7950997411 小时前
golang如何在Gin中自定义验证器_golang Gin自定义验证器实现方法
jvm·数据库·python
2301_7662834411 小时前
如何在MongoDB GridFS中进行按文件大小(length)范围的查询
jvm·数据库·python
冬天vs不冷12 小时前
面试必知必会(14):MySQL执行计划与SQL优化
sql·mysql·面试
萧曵 丶12 小时前
MySQL 高频面试题(由浅到深 完整版,面试必背)
数据库·mysql·面试
czlczl2002092512 小时前
MySQL 执行引擎:排序与临时表机制深度解析
数据库·mysql