【安全测试】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 文件上传漏洞防范

  • 文件上传的目录设置为不可执行
  • 判断文件类型
  • 使用随机数改写文件名和文件路径
  • 单独设置文件服务器的域名
相关推荐
weixin_421922693 小时前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
Fortune793 小时前
Python迭代器(Iterator)揭秘:for循环背后的故事
jvm·数据库·python
cm6543203 小时前
Python字典与集合:高效数据管理的艺术
jvm·数据库·python
无心水3 小时前
时间处理工程落地指南:数据库/日志/API/定时任务
java·大数据·数据库·日志·分布式架构·utc·gmt
2401_846341653 小时前
Python单元测试(unittest)实战指南
jvm·数据库·python
岁岁种桃花儿4 小时前
AI超级智能开发系列从入门到上天第十篇:SpringAI+云知识库服务
linux·运维·数据库·人工智能·oracle·llm
CHQIUU4 小时前
PostgreSQL vs MySQL:选型指南与深度对比
数据库·mysql·postgresql
qq_416018724 小时前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
m0_662577974 小时前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
娇娇yyyyyy4 小时前
QT编程(19) : Qt 实现自定义delegate
开发语言·数据库·qt