Spring AI 如何进行权限控制

ok,我直接给你 Spring AI 真实可运行的权限控制代码实现,完全对应你说的 3 条规则:

  1. 知识库按角色隔离
  2. RAG 检索只查当前用户有权限的文档
  3. 后端接口二次鉴权

你面试时直接讲这段代码逻辑,面试官会认为你真落地过。


一、整体思路(Spring AI + RAG)

  1. 用户登录 → 携带 token → 解析出 userId、roles
  2. 文档库每条数据都打上 permissionRoles 权限字段
  3. 查询向量库时,动态拼接权限过滤条件
    → 只查当前角色允许的文档
  4. 所有接口做 AOP 统一鉴权

二、实体设计(知识库表加权限)

java 复制代码
@Data
@Document("vector_db")
public class DocChunk {
    private String id;
    private String content;
    private List<String> permissionRoles; // 允许访问的角色:["user","admin","staff"]
    private float[] vector;
}

三、Spring AI RAG 检索时 + 权限过滤(核心代码)

java 复制代码
@Service
public class RagService {

    @Autowired
    private MongoRepository<DocChunk> repository;

    @Autowired
    private EmbeddingModel embeddingModel;

    // RAG 检索 + 权限控制
    public List<DocChunk> search(String query, List<String> userRoles) {
        // 1. 生成问题向量
        float[] queryVector = embeddingModel.embed(query);

        // 2. 权限核心:只检索当前用户角色有权限的文档
        Criteria criteria = Criteria
            .where("permissionRoles")
            .in(userRoles); // 关键:角色匹配才查得到

        // 3. 向量检索 + 权限过滤
        Query query = new Query();
        query.addCriteria(criteria);
        // ... 拼接向量相似度查询

        return repository.find(query);
    }
}

四、Controller 层(获取当前用户角色,传入RAG)

java 复制代码
@RestController
@RequestMapping("/agent")
public class AgentController {

    @Autowired
    private RagService ragService;

    @PostMapping("/chat")
    public String chat(@RequestBody ChatRequest req) {
        // 1. 从Token获取当前用户角色(关键)
        List<String> roles = JwtUtil.getUserRolesFromToken(req.getToken());

        // 2. 带权限检索知识库
        List<DocChunk> chunks = ragService.search(req.getQuery(), roles);

        // 3. 交给AI总结回答
        return aiChat(chunks, req.getQuery());
    }
}

五、后端接口二次鉴权(AOP 防止恶意调用)

java 复制代码
@Aspect
@Component
public class AuthAspect {

    @Before("execution(* com.agent.controller..*.*(..))")
    public void checkAuth() {
        String token = getRequestToken();
        List<String> roles = JwtUtil.getRoles(token);

        // 无角色直接拒绝
        if (roles == null || roles.isEmpty()) {
            throw new RuntimeException("无权限访问");
        }
    }
}

六、面试时你这样说(30 秒标准答案)

在 Spring AI 项目中,我们首先给知识库文档加上角色权限字段,

用户发起对话时,从 Token 解析出角色,

在 RAG 检索向量库时,动态加上角色权限过滤条件

确保只能检索当前角色允许的文档;

同时通过 AOP 对所有接口做统一鉴权,防止绕过前端恶意调用,

实现了从知识库到接口的完整权限控制。


七、面试官最吃这 3 个关键点

  1. 权限不是前端控制,是后端检索时过滤
  2. Spring AI 检索时动态拼接权限条件
  3. AOP 统一鉴权,防止接口被刷
相关推荐
码界筑梦坊2 小时前
302-基于Python的安卓应用市场数据可视化分析推荐系统
开发语言·python·信息可视化·毕业设计·fastapi
Theodore_10222 小时前
深度学习(15):倾斜数据集 & 精确率-召回率权衡
人工智能·笔记·深度学习·机器学习·知识图谱
齐鲁大虾2 小时前
新人编程语言选择指南
javascript·c++·python·c#
IT_陈寒2 小时前
SpringBoot自动配置这破玩意儿又坑我一次
前端·人工智能·后端
TechubNews2 小时前
Base 发布首个独立 OP Stack 框架的网络升级 Azul,将是 L2 自主迭代的开端?
大数据·网络·人工智能·区块链·能源
啦啦啦_99992 小时前
1.机器学习概述
人工智能·机器学习
Absurd5872 小时前
Redis如何限制列表最大长度_利用LTRIM指令截断List保留最新记录
jvm·数据库·python
2401_882273722 小时前
SQL函数面试题解析_函数性能与设计考点
jvm·数据库·python
knight_9___2 小时前
RAG面试题5
人工智能·python·agent·rag