SpringAI1.0的MCPServer自动暴露Tool

java 复制代码
@Configuration
public class ToolAutoRegistrar {

    @Autowired
    private ListableBeanFactory beanFactory;

    @Bean
    public ToolCallbackProvider toolCallbackProvider() {
        List<Object> toolBeans = beanFactory.getBeansWithAnnotation(Service.class)
                .values().stream()
                .filter(bean -> Arrays.stream(bean.getClass().getMethods())
                        .anyMatch(method -> method.isAnnotationPresent(Tool.class)))
                .collect(Collectors.toList());

        return MethodToolCallbackProvider.builder()
                .toolObjects(toolBeans.toArray())
                .build();
    }
}

这段代码会自动查找所有 @Service Bean 中包含 @Tool 注解的方法,然后注册进去。

更加健壮的代码

java 复制代码
package com.example.mcp.config;

import org.springframework.aop.framework.AopProxyUtils;
import org.springframework.beans.factory.ListableBeanFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.ai.tool.ToolCallbackProvider;
import org.springframework.ai.tool.MethodToolCallbackProvider;
import org.springframework.ai.tool.Tool;

import java.lang.reflect.Method;
import java.util.List;
import java.util.stream.Collectors;

@Configuration
public class ToolAutoRegistrar {

    @Bean
    public ToolCallbackProvider toolCallbackProvider(ListableBeanFactory beanFactory) {
        List<Object> toolBeans = beanFactory.getBeansOfType(Object.class)
                .values().stream()
                .filter(bean -> hasToolAnnotatedMethod(bean))
                .collect(Collectors.toList());

        return MethodToolCallbackProvider.builder()
                .toolObjects(toolBeans.toArray())
                .build();
    }

    private boolean hasToolAnnotatedMethod(Object bean) {
        Class<?> targetClass = AopProxyUtils.ultimateTargetClass(bean);
        for (Method method : targetClass.getDeclaredMethods()) {
            if (method.isAnnotationPresent(Tool.class)) {
                return true;
            }
        }
        return false;
    }
}
相关推荐
光影少年2 分钟前
vuex中的辅助函数怎样使用
前端·javascript
teeeeeeemo22 分钟前
JS数据类型检测方法总结
开发语言·前端·javascript·笔记
木木黄木木23 分钟前
HTML5 火焰字体效果教程
前端·html·html5
云墨-款哥的博客24 分钟前
失业学习-前端工程化-webpack基础
前端·学习·webpack
MAOX78926 分钟前
基于python的web系统界面登录
前端·python
懒大王、27 分钟前
Vue添加图片作为水印
前端·javascript·vue.js
Junerver32 分钟前
如何在Jetpack Compose中轻松的进行表单验证
前端·kotlin
3Katrina34 分钟前
《JavaScript this 指向深度剖析:从基础到复杂场景实战》
前端·javascript
岩柏37 分钟前
在vue项目中添加stylelint
前端
暖苏39 分钟前
Vue.js第一节
前端·javascript·css·vue.js·ecmascript