修复Nacos namespaces未授权访问漏洞【原理扫描】

近日,我们自己的微服务应用通过绿盟软件扫描到了有关nacos的namespaces问题,在这里记录一下,供有需要的人参考。

一、问题描述

nacos版本: 2.5.0

存在问题: Nacos namespaces未授权访问漏洞【原理扫描】

问题复现:

漏洞扫描结果:

官方明确说明:

/nacos/v2/console/namespace接口是Nacos用于展示集群中存在的命名空间列表的OpenAPI,其设计初衷是为了提供公开数据,允许所有访问者获取这些信息,类似于查询云平台支持的Region列表。因此,该接口默认不支持关闭,也未实施鉴权措施。

如果确实有安全需求要限制此接口的访问,唯一的途径是根据Nacos的源代码进行自定义修改,比如增加鉴权逻辑或者改变接口行为,随后重新编译并部署Nacos服务。

参考链接: https://www.nacos.io/blog/faq/nacos-user-question-history11025/?spm=55c5c5db.2ef5001f.0.0.73a53b7ch0jUQm

二、问题修复

这里需要下载对应nacos版本的源码程序。我的是:2.5.0

下载地址: https://github.com/alibaba/nacos/tree/2.5.0?spm=55c5c5db.2ef5001f.0.0.73a53b7ch0jUQm

然后使用idea工具打开,修改以下两个文件即可。

1、NamespaceController

bash 复制代码
@Secured(resource = AuthConstants.CONSOLE_RESOURCE_NAME_PREFIX + "namespaces", action = ActionTypes.READ)

2、NamespaceControllerV2

bash 复制代码
@Secured(resource = AuthConstants.CONSOLE_RESOURCE_NAME_PREFIX
            + "namespaces", action = ActionTypes.READ, signType = SignType.CONSOLE)

全部修改完毕后,执行打包构建命令

bash 复制代码
mvn -Prelease-nacos -DskipTests clean install -U

使用新生成的压缩包或者替换nacos-server.jar包,重启服务,问题修复。

验证:

相关推荐
7哥♡ۣۖᝰꫛꫀꪝۣℋ8 分钟前
Spring-cloud\Eureka
java·spring·微服务·eureka
Lsir10110_10 分钟前
【Linux】进程信号(下半)
linux·运维·服务器
老毛肚21 分钟前
手写mybatis
java·数据库·mybatis
两点王爷23 分钟前
Java基础面试题——【Java语言特性】
java·开发语言
skywalk816326 分钟前
unbound dns解析出现问题,寻求解决之道
运维·服务器·dns·unbound
choke23327 分钟前
[特殊字符] Python 文件与路径操作
java·前端·javascript
酉鬼女又兒28 分钟前
零基础入门Linux指南:每天一个Linux命令_pwd
linux·运维·服务器
云飞云共享云桌面30 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
skywalk816331 分钟前
走近科学:unbound dns域名服务器自己本地解析出现问题,寻求解决之道
运维·服务器·dns·unbound
choke23332 分钟前
Python 基础语法精讲:数据类型、运算符与输入输出
java·linux·服务器