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

简介: 本文介绍后端开发过程中遇到的常见安全问题及其解决方案,包括越权漏洞、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设置过期时间。



相关文章
|
1月前
|
存储 缓存 负载均衡
后端开发中的性能优化策略
本文将探讨几种常见的后端性能优化策略,包括代码层面的优化、数据库查询优化、缓存机制的应用以及负载均衡的实现。通过这些方法,开发者可以显著提升系统的响应速度和处理能力,从而提供更好的用户体验。
59 4
|
19天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
142 18
|
1月前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
93 3
|
1月前
|
运维 监控 Java
后端开发中的微服务架构实践与挑战####
在数字化转型加速的今天,微服务架构凭借其高度的灵活性、可扩展性和可维护性,成为众多企业后端系统构建的首选方案。本文深入探讨了微服务架构的核心概念、实施步骤、关键技术考量以及面临的主要挑战,旨在为开发者提供一份实用的实践指南。通过案例分析,揭示微服务在实际项目中的应用效果,并针对常见问题提出解决策略,帮助读者更好地理解和应对微服务架构带来的复杂性与机遇。 ####
|
1月前
|
消息中间件 运维 安全
后端开发中的微服务架构实践与挑战####
在数字化转型的浪潮中,微服务架构凭借其高度的灵活性和可扩展性,成为众多企业重构后端系统的首选方案。本文将深入探讨微服务的核心概念、设计原则、关键技术选型及在实际项目实施过程中面临的挑战与解决方案,旨在为开发者提供一套实用的微服务架构落地指南。我们将从理论框架出发,逐步深入至技术细节,最终通过案例分析,揭示如何在复杂业务场景下有效应用微服务,提升系统的整体性能与稳定性。 ####
47 1
|
1月前
|
消息中间件 运维 API
后端开发中的微服务架构实践####
本文深入探讨了微服务架构在后端开发中的应用,从其定义、优势到实际案例分析,全面解析了如何有效实施微服务以提升系统的可维护性、扩展性和灵活性。不同于传统摘要的概述性质,本摘要旨在激发读者对微服务架构深度探索的兴趣,通过提出问题而非直接给出答案的方式,引导读者深入
47 1
|
1月前
|
负载均衡 监控 API
后端开发中的微服务架构实践与挑战
本文深入探讨了微服务架构在后端开发中的应用,分析了其优势和面临的挑战,并通过案例分析提出了相应的解决策略。微服务架构以其高度的可扩展性和灵活性,成为现代软件开发的重要趋势。然而,它同时也带来了服务间通信、数据一致性等问题。通过实际案例的剖析,本文旨在为开发者提供有效的微服务实施指导,以优化系统性能和用户体验。
|
1月前
|
存储 前端开发 Java
深入理解后端开发:从基础到高级
本文将带你走进后端开发的神秘世界,从基础概念到高级应用,一步步揭示后端开发的全貌。我们将通过代码示例,让你更好地理解和掌握后端开发的核心技能。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供有价值的信息和启示。
|
2月前
|
存储 缓存 监控
后端开发中的缓存机制:深度解析与最佳实践####
本文深入探讨了后端开发中不可或缺的一环——缓存机制,旨在为读者提供一份详尽的指南,涵盖缓存的基本原理、常见类型(如内存缓存、磁盘缓存、分布式缓存等)、主流技术选型(Redis、Memcached、Ehcache等),以及在实际项目中如何根据业务需求设计并实施高效的缓存策略。不同于常规摘要的概述性质,本摘要直接点明文章将围绕“深度解析”与“最佳实践”两大核心展开,既适合初学者构建基础认知框架,也为有经验的开发者提供优化建议与实战技巧。 ####
|
2月前
|
存储 JavaScript 前端开发
深入浅出Node.js后端开发
在数字化时代的浪潮中,后端开发作为连接用户与数据的桥梁,扮演着至关重要的角色。本文将以Node.js为例,深入探讨其背后的哲学思想、核心特性以及在实际项目中的应用,旨在为读者揭示Node.js如何优雅地处理高并发请求,并通过实践案例加深理解。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和思考。

热门文章

最新文章