让AI看懂Maven依赖Jar的黑盒子 - Maven Jar Analyzer MCP工具

最近一在使用AI辅助编程,所在公司系统间对接使用的是Feign接口,引用外部服务接口时,AI拿不到接口API的class信息导致生成代码效果不太理想。

这个问题困扰我挺久的,所以写了这个MCP工具来解决它。

这东西能干嘛

简单说,它能让支持MCP协议的AI助手(比如Cursor、VSCode的Copilot等)直接读取Maven依赖中的Java类源码。

举个实际场景:你在项目里用了Spring框架,想让AI解释一下ApplicationContext的初始化流程。以前AI只能根据文档和记忆来回答,现在可以直接把源码拉出来分析。

项目GitHub地址: https://github.com/jcxzzy/Maven-Jar-Analyzer

工作原理

整个工具分两层:

远程执行层 - 负责脏活累活

  • 根据Maven坐标下载jar包和所有依赖
  • 在jar包里搜索指定的类
  • 用CFR反编译器把class文件还原成Java源码

MCP代理层 - 负责跟AI对话

  • 实现MCP协议,让AI工具能够调用
  • 把AI的请求转发给远程执行层
  • 返回格式化的结果

为什么要分两层?因为下载jar包、运行Maven需要完整的Java环境,很多开发机上不一定配齐全了。分层之后,可以把执行层部署在一台配好环境的服务器上,本地只跑个轻量的代理就行。当然,如果你本地环境齐全,两个都跑在本地也没问题。

三个核心功能

工具提供三个能力:

analyze_maven_dependency - 分析依赖

给定Maven坐标和要找的类名,返回类在哪个jar包里、完整类路径是什么。适合先探探路,看看类存不存在。

decompile_class - 反编译

给定jar包路径和类路径,直接返回反编译后的Java源码。需要配合第一个功能使用。

find_and_decompile - 一站式服务

把上面两步合成一步:给坐标和类名,直接返回源码。省事,推荐用这个。

部署方法

需要准备的环境:

  • Python 3.8及以上
  • Java 8及以上
  • Maven 3.6及以上
  • CFR反编译器

启动远程服务

bash 复制代码
pip install fastapi uvicorn pydantic
python maven_jar_remote_server.py

默认监听8000端口,可以通过环境变量改:

bash 复制代码
SERVER_HOST=0.0.0.0 SERVER_PORT=9000 python maven_jar_remote_server.py

启动MCP代理

bash 复制代码
pip install mcp fastapi uvicorn httpx sse-starlette
REMOTE_SERVER_URL=http://localhost:8000 python maven_jar_mcp_proxy.py

代理默认监听8001端口。

配置AI工具

以Cursor为例,在MCP配置里加上:

json 复制代码
{
  "mcpServers": {
    "maven-jar-analyzer": {
      "type": "streamable_http",
      "url": "<http://localhost:8001>"
    }
  }
}

实际使用

配置好之后,直接跟AI说就行:

帮我分析一下spring-core 5.3.20里的ApplicationContext接口

或者更具体一点:

用maven-jar-analyzer查看com.google.guava:guava:31.1-jre中的Lists类的源码

AI会自动调用工具,下载依赖,找到类,反编译,然后把源码展示出来,再根据源码回答你的问题。

几个注意事项

  1. 第一次分析某个依赖会比较慢,因为要下载jar包。后续再分析同一个依赖会快很多,Maven有本地缓存。
  2. 如果要访问公司内部的私有Maven仓库,需要在调用时传入仓库配置,或者在服务器的Maven settings.xml里配好。
  3. CFR反编译的结果不是百分百准确,特别是对于混淆过的代码。但对于开源框架来说足够用了。
  4. 反编译的是class文件,所以能看到的是编译后的代码,注释和部分泛型信息会丢失。如果需要完整源码,建议还是去GitHub找原始仓库。

最后

这个工具主要解决的是AI编程场景下的一个痛点。以前让AI分析第三方库的实现细节,它只能靠"猜"或者根据训练数据里的知识来回答。现在可以直接把源码喂给它,回答的准确性会好很多。

代码已经在实际项目里用了一段时间,比较稳定。如果你也有类似的需求,可以试试。

觉得这个工具不错?欢迎点个 Star ⭐ 鼓励一下作者

项目GitHub地址: https://github.com/jcxzzy/Maven-Jar-Analyzer

相关推荐
Carson带你学Android4 小时前
别再乱学了!深度解读 Google 官方发布 Android 6 大核心 Skills
android·前端·ai编程
沐泽__5 小时前
多头注意力机制含义
ai编程
jimy15 小时前
记第一次运行codex
c语言·ai编程
小白蒋博客15 小时前
【ai开发段永平投资理财的知识图谱网站】第五天:实现 ArticleReader + 搜索
ai编程
言萧凡_CookieBoty16 小时前
AI 编程省 Token 实战:从 Spec、上下文工程到模型分层的降本策略
前端·ai编程
小饕16 小时前
AI编程的三阶段演化:哪些方向真正值得投入,哪些被高估了
人工智能·ai编程
Hello_Embed17 小时前
STM32CubeIDE 创建第1个工程
stm32·单片机·嵌入式·ai编程
SamDeepThinking19 小时前
代码能跑就别动?有AI之后其实未必
后端·程序员·ai编程
kyriewen1119 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·gpt·ai·copilot
薛定谔的猫36919 小时前
AI Agent 与 MCP 协议:构建标准化大模型交互的新范式
ai·llm·agent·mcp·software engineering