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

  • 文件上传的目录设置为不可执行
  • 判断文件类型
  • 使用随机数改写文件名和文件路径
  • 单独设置文件服务器的域名
相关推荐
H Journey1 小时前
Django 教程
数据库·django·sqlite
eWidget1 小时前
核心业务系统国产化:如何破解 Oracle 迁移中的“重构代价”与“性能瓶颈”?
数据库·oracle·重构·kingbase·数据库平替用金仓·金仓数据库
lhxsir1 小时前
oracle常用命令(DBA)
数据库·oracle·dba
Elastic 中国社区官方博客1 小时前
Elasticsearch 8.17.2 升级到 9.2.4 完整升级过程
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索·运维开发
Re.不晚1 小时前
Redis事务
数据库·redis·php
数据知道2 小时前
PostgreSQL:如何定期验证备份的有效性?(灾备演练)
数据库·postgresql
档案宝档案管理2 小时前
档案管理系统软件:档案宝让企业实现高效档案利用与精准数据分析
大数据·数据库·人工智能·档案·档案管理
eWidget2 小时前
核心业务系统“去O”实战:如何破解语法兼容与逻辑重构难题?核心业务系统“去O”实战:如何破解语法兼容与逻辑重构难题?
数据库·oracle·重构·kingbase·数据库平替用金仓·金仓数据库
2501_941982052 小时前
Python开发:外部群消息自动回复
java·前端·数据库