【组件健壮性】后端开发常见安全问题、防范与开发规范

简介: 本文介绍后端开发过程中遇到的常见安全问题及其解决方案,包括越权漏洞、SQL注入、XSS跨站脚本攻击、CSRF跨站请求伪造攻击等。

1. 越权漏洞

1.1. 漏洞原理

假设有一个业务接口/getData用于用户获取用户数据data,并在接口getData上进行了权限p1的校验,业务希望只有p1权限的用户可以获取自己的数据,如下所示。

@Permission(value="p1")
@RequestMapping(value="/getData", method=RequestMethod.GET)
publicDatagetData(
@RequestParam(value="id") Stringid){
returnqueryService.getData(id);
}

用户u1u2均被赋予p1权限。

正常情况下,用户u1通过自己的id1进行数据获取,因为拥有p1权限,权限校验通过,可以获取到数据data1;用户u2通过自己的id2进行数据获取,因为拥有p1权限,权限校验通过,可以获取到数据data2

但是不幸的是,用户u2知道了用户u1的id,即为id1,并通过id1获取到了用户u1的数据data1,造成了用户u1的数据泄露,这种情况即水平越权漏洞。造成这种情况的主要原因是因为接口只校验了接口权限,没有验证数据权限导致。

假设有一个系统,它有前台页面,也有后台管理页面,普通用户只能看到前台页面,超管用户可以看到后管页面,当普通用户猜测或获取到后管页面地址后可以直接访问后端页面,这时就产生了垂直越权漏洞。造成这种情况的主要原因是管理页面及其接口未进行权限控制。

1.2. 解决方案

1.2.1. 水平越权

除了已有的接口权限校验完,需再次进行数据归属校验,如校验用户是否有访问数据的权限。

1.2.2. 垂直越权

对页面和接口进行权限控制。

2. SQL注入

2.1. 漏洞原理

SQL注入是通过在应用API接口参数中传入恶意SQL片段,执行恶意SQL达到获取数据、破坏数据的目的。

如获取用户在前端界面上输入的类型字段type的用户本人数据时有如下业务SQL,type变量为用户从前端界面上输入的值,userId为后端系统从登录信息中自动获取。

SELECT*FROM  table_1
WHERE type = ${type}AND user_id = ${userId}

正常情况下,用户A输入合法的类型字段值(如为type1),则实际执行的业务SQL如下所示,符合业务预期。

SELECT*FROM  table_1
WHERE type ='type1'AND user_id ='A'

异常情况下,如果用户A进行恶意攻击,输入非法的类型字段值(如为' or 1=1 #),则实际执行的业务SQL如下所示,用户ID过滤条件被注释了,用户A获取了所有的业务数据,造成了数据泄露。

SELECT*FROM  table_1
WHERE type =''or1=1 #' #AND user_id = 'A'

2.2. 解决方案

2.2.1. 预编译SQL语句

使用PreparedStatement对SQL语句进行预编译,通过变量绑定方式进行SQL执行。

如果使用MyBatis进行SQL语句的编写,则要注意变量需使用#{}进行引用,不能使用${}。因为#{}使用预编译SQL方式绑定变量并执行,${}使用字符串拼接的方式组装SQL并执行。

2.2.2. 用户输入数据参数校验

可以通过前端、后端正则校验限制用户输入数据格式,规范用户输入数据。

3. XSS跨站脚本攻击

XSS(Cross Site Scripting)跨站脚本攻击

3.1. 漏洞原理

XSS是恶意攻击者向页面里插入恶意Script脚本,当用户浏览该页面时触发执行恶意Script脚本,从而达到攻击用户的目的。

假设有一个系统的页面A,其页面URL中的参数name会直接显示到页面上,当用户给name参数赋值一段恶意Script脚本,则此恶意Script脚本会被页面渲染显示到页面A上,恶意Script脚本可能是一张空白的图片,图片的src是一段来自黑客的恶意网站的Script脚本,点击图片后用户的敏感信息cookie就会被发送到黑客的网站。攻击者可以构造带有恶意Script脚本的页面A的URL给到用户,诱使其点击,达到获取用户敏感信息cookie的目的, 这种情况称之为反射型XSS攻击

论坛网站,用户可以对帖子进行评论,并查看历史评论。如果论坛后台系统没有对评论内容进行校验,当攻击者使用带有恶意Script脚本的内容进行评论时,系统会将此评论存入数据库。之后每次有用户查看这个帖子时恶意Script脚本都会显示到页面上。恶意Script脚本可能是一张空白的图片,图片的src是一段来自黑客的恶意网站的Script脚本,点击图片后用户的敏感信息cookie就会被发送到黑客的网站。这种情况称之为存储型XSS攻击

3.2. 解决方案

可以通过后端正则校验限制用户输入数据格式,规范用户输入数据。

使用安全包对用户输入数据在输出时进行过滤、转义。如使用apache commons-lang包中的StringEscapeUtils.escapeHtml()方法进行HTML编码。

4. CSRF跨站请求伪造攻击

CSRF(Cross Site Request Forgery)跨站请求伪造

4.1. 漏洞原理

攻击者盗用了用户身份,在当前已登录的网站以用户的名义向某网站发起恶意请求。

例如,用户登录了某银行网站A,此时用户的浏览器中产生了网站A的Cookie。用户在没有登出网站A的情况下不小心访问了恶意网站B,恶意网站B背地里向网站A发出一个转账请求。此时浏览器会带着之前产生的Cookie访问网站。由于请求中带有用户的认证信息,网站A响应了这次请求,并把用户的钱转到了攻击者名下。

4.2. 解决方案

验证Referer:HTTP请求头中Referer字段记录了该请求的来源地址。正常情况下,请求中的Referer会是开发者已知的白名单域名,如果Referer中包含了未知的域名,则判定为攻击,予以拦截。但这种方法过于依赖浏览器,某些低版本浏览器存在漏洞,可以篡改Referer,所以不够安全。而且Referer会记录用户的访问来源,会侵犯用户的隐私权。

请求中增加token:请求方需要先调用服务端的鉴权接口获取一个token,之后的每次请求都需要在参数中带上这个token,并且token设置过期时间。



相关文章
|
6月前
|
人工智能 Java API
后端开发必看:零代码实现存量服务改造成MCP服务
本文介绍如何通过 **Nacos** 和 **Higress** 实现存量 Spring Boot 服务的零代码改造,使其支持 MCP 协议,供 AI Agent 调用。全程无需修改业务代码,仅通过配置完成服务注册、协议转换与工具映射,显著降低改造成本,提升服务的可集成性与智能化能力。
1898 1
|
10月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
569 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
6月前
|
前端开发 Java 数据库连接
后端开发中的错误处理实践:原则与实战
在后端开发中,错误处理是保障系统稳定性的关键。本文介绍了错误分类、响应设计、统一处理机制及日志追踪等实践方法,帮助开发者提升系统的可维护性与排障效率,做到防患于未然。
|
8月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
509 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
9月前
|
前端开发 JavaScript 关系型数据库
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
740 5
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
|
9月前
|
人工智能 小程序 NoSQL
【一步步开发AI运动小程序】二十一、如何将AI运动项目配置持久化到后端?
本文介绍基于云智「Ai运动识别引擎」的运动配置持久化方案,旨在优化小程序或Uni APP中AI运动识别能力。通过将运动检测参数(如`Key`、`Name`、`TickMode`、`rules`或`samples`)持久化到后端,可避免因频繁调整运动参数而重新发布应用,提升用户体验。持久化数据结构支持规则和姿态样本存储,适用于关系数据库、文件或文档数据库(如MongoDB)。此外,云智还提供运动自动适配工具及「AI乐运动」产品,助力快速实现AI体育、全民健身等场景。
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
614 2
|
存储 缓存 负载均衡
后端开发中的性能优化策略
本文将探讨几种常见的后端性能优化策略,包括代码层面的优化、数据库查询优化、缓存机制的应用以及负载均衡的实现。通过这些方法,开发者可以显著提升系统的响应速度和处理能力,从而提供更好的用户体验。
466 6
|
消息中间件 运维 安全
后端开发中的微服务架构实践与挑战####
在数字化转型的浪潮中,微服务架构凭借其高度的灵活性和可扩展性,成为众多企业重构后端系统的首选方案。本文将深入探讨微服务的核心概念、设计原则、关键技术选型及在实际项目实施过程中面临的挑战与解决方案,旨在为开发者提供一套实用的微服务架构落地指南。我们将从理论框架出发,逐步深入至技术细节,最终通过案例分析,揭示如何在复杂业务场景下有效应用微服务,提升系统的整体性能与稳定性。 ####
266 32
|
运维 监控 Java
后端开发中的微服务架构实践与挑战####
在数字化转型加速的今天,微服务架构凭借其高度的灵活性、可扩展性和可维护性,成为众多企业后端系统构建的首选方案。本文深入探讨了微服务架构的核心概念、实施步骤、关键技术考量以及面临的主要挑战,旨在为开发者提供一份实用的实践指南。通过案例分析,揭示微服务在实际项目中的应用效果,并针对常见问题提出解决策略,帮助读者更好地理解和应对微服务架构带来的复杂性与机遇。 ####

热门文章

最新文章