让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

相关推荐
后端研发Marion7 小时前
【深入对比分析三款主流的AI编程CLI编辑器:心流CLI(iFlow CLI)、OpenAI Codex和Claude Code】
编辑器·ai编程·codex·claude code·心流cli
冷yan~21 小时前
OpenAI Codex CLI 完全指南:AI 编程助手的终端革命
人工智能·ai·ai编程
程序员晚枫1 天前
AI的“USB-C时刻”:巨头罕见联手,只为打通AI世界的“任督二脉”
mcp
leonwgc1 天前
🎯 AI 写代码?我用 MCP 让 Copilot 秒变全栈工程师!
react.js·ai编程
魁首1 天前
Gemini CLI 深度源码:从零到一理解 AI 命令行代理的设计与实现
ai编程·gemini·mcp
猫头虎1 天前
openEuler异构算力体系下的GPU加速性能测试与优化研究
开源·github·aigc·ai编程·ai写作·gpu算力·华为snap
lomocode1 天前
AI 模型占了 10G 显存,服务重启却没释放?
后端·ai编程
努力的小郑1 天前
MCP 完全指南(上):撕掉标签,看清本质
前端·后端·ai编程
水木姚姚1 天前
TensorFlow在Microsoft Windows 11下编程
人工智能·windows·python·深度学习·tensorflow·ai编程