maven中央仓库油猴脚本

简介: 这是一个用于 Maven 中央仓库的油猴脚本,帮助开发者在选择依赖时查看每个 Jar 包的 JDK 版本信息。通过该脚本,用户可以在 Maven 中央仓库的组件版本列表页和详情页看到每个版本的 JDK 编译信息,从而避免因版本不兼容导致的运行问题。脚本支持从油猴商店安装或自行编译安装,并提供多种实用功能,如 GAV 快速访问详情页和展开隐藏文本等。

# maven中央仓库油猴脚本


GitHub仓库:[https://github.com/scagogogo/mvnrepository-helper-UserScript](https://github.com/scagogogo/mvnrepository-helper-UserScript)


介绍视频: [https://www.bilibili.com/video/BV13fkgYaEDn](https://www.bilibili.com/video/BV13fkgYaEDn)


![Greasy Fork Downloads](https://img.shields.io/greasyfork/dt/471802) ![Greasy Fork Rating](https://img.shields.io/greasyfork/rating-count/471802) ![GitHub Created At](https://img.shields.io/github/created-at/scagogogo/mvnrepository-helper-UserScript) ![GitHub contributors](https://img.shields.io/github/contributors-anon/scagogogo/mvnrepository-helper-UserScript) ![GitHub top language](https://img.shields.io/github/languages/top/scagogogo/mvnrepository-helper-UserScript) ![GitHub commit activity](https://img.shields.io/github/commit-activity/t/scagogogo/mvnrepository-helper-UserScript) ![GitHub Release](https://img.shields.io/github/v/release/scagogogo/mvnrepository-helper-UserScript) ![GitHub Issues or Pull Requests](https://img.shields.io/github/issues/scagogogo/mvnrepository-helper-UserScript) ![GitHub Issues or Pull Requests](https://img.shields.io/github/issues-closed/scagogogo/mvnrepository-helper-UserScript) ![GitHub Issues or Pull Requests](https://img.shields.io/github/issues-pr/scagogogo/mvnrepository-helper-UserScript) ![GitHub Issues or Pull Requests](https://img.shields.io/github/issues-pr-closed/scagogogo/mvnrepository-helper-UserScript) ![GitHub License](https://img.shields.io/github/license/scagogogo/mvnrepository-helper-UserScript) ![GitHub Repo stars](https://img.shields.io/github/stars/scagogogo/mvnrepository-helper-UserScript) ![GitHub forks](https://img.shields.io/github/forks/scagogogo/mvnrepository-helper-UserScript) ![GitHub watchers](https://img.shields.io/github/watchers/scagogogo/mvnrepository-helper-UserScript)


# 一、解决了什么问题?


我们有时会遇到要求Java项目兼容JDK 1.8的情况,有可能是部署时运行环境的要求,有可能是Java Agent类产品必须保证一定的JDK兼容性,也有可能是领导或者甲方的诉求,这个要求合理或者不合理,我们没得选只能接受这个要求并将其落实好。


但是我们开发的时候可能会持续的增加一些依赖,对于Maven的这些Jar包,在Maven中央仓库是不显示Jar包具体是哪个JDK版本编译的,如果加错版本了可能我们的项目就无法运行了,因为JDK 1.8是无法加载解释JDK 1.9版本编译出来的Class文件的,则我们加依赖的时候就得小心翼翼,甚至可能得采取二分法试探出合适的版本(经历过的都能体会这是多么让人崩溃),而这个脚本就是用来解决这个问题的,它给Maven的中央仓库里的组件的版本增加了显示对应JDK版本的功能,这样我们再来选择组件版本的时候,就能根据自己要兼容到的JDK版本来选择合适的版本:


![](data/demo-video.gif)


# 二、安装


## 2.1 从油猴商店安装(推荐方式)


首先你应该已经安装了油猴插件:


[https://chromewebstore.google.com/detail/dhdgffkkebhmkfjojejmpbldmpobfkfo](https://chromewebstore.google.com/detail/dhdgffkkebhmkfjojejmpbldmpobfkfo)


然后从油猴商店直接安装此脚本即可:


[https://greasyfork.org/zh-CN/scripts/471802-repo1-maven-org-helper](https://greasyfork.org/zh-CN/scripts/471802-repo1-maven-org-helper)


## 2.2 自行编译


克隆仓库到本地:


```bash

git clone git@github.com:scagogogo/mvnrepository-helper-UserScript.git

```


进入克隆到的本地目录:


```bash

cd mvnrepository-helper-UserScript

```


安装依赖(yarn):


```bash

yarn install

```


或者npm:


```bash

npm install

```


然后打包(yarn):


```bash

yarn build

```


或者npm:


```bash

npm run build

```


打好包的文件在`dist/index.js`中,以`dist/index.js`中的内容创建一个新的油猴组件即可:


![image-20241216015544138](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20241216015544138.png)


# 三、功能详细介绍


## 3.1 组件版本列表页展示每个版本Jar包的JDK版本


在组件的版本列表页面这里,增加了一列,展示组件的每个版本的具体的JDK编译信息:


![image-20241216013810124](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20241216013810124.png)


JDK编译信息分为两部分,一部分是从Jar包中的每个class文件中分析出的编译版本:


![image-20241216013918398](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20241216013918398.png)


比如上面的信息表示Jar包中共有178个class文件,其中177个是JDK 1.6版本编译的,而1个class是JDK 1.9版本编译的,这个时候如果想使用这个Jar包的话,比较保险的运行时JDK版本至少应该是1.9及以上。


还有一部分是从Jar包的`META-INF/MANIFEST.MF`文件中解析出来的编译元信息,这是因为虽然我们能够从Jar包中的每个class文件的编译版本分布情况推测出我们至少应该使用哪个JDK版本来运行此Jar包,但是有的时候Jar包编译的时候会往Jar包的`META-INF/MANIFEST.MF`中放一些元信息,其中可能就会有一些编译相关的元信息,虽然实际加载解释class文件的时候只看class的文件头的编译版本,但不确定会不会有一些特殊情况是由元信息决定的最低运行JDK版本,所以把这个信息也放到这里作为参考:


![image-20241216014151485](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20241216014151485.png)


## 3.2 组件版本详情页展示编译JDK版本信息


在组件的详情页也展示了此组件的此版本是用哪个JDK版本编译的:


![image-20241216014633039](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20241216014633039.png)


## 3.3 GAV快速访问详情页


不开启脚本的情况:


![image-20230521195256248](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230521195256248.png)


开启脚本之后会在页面底部增加几个输入框,在输入框中输入`GroupId`、`ArticleId`、`Version`之后单击`Go`按钮访问到对应的详情页:


![image-20230521195239339](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230521195239339.png)


比如这样,输入`fastjson`的`groupId`、`articleId`、`version`单击`Go`按钮可将当前页面定位到:


```plaintext

https://repo1.maven.org/maven2/com/alibaba/fastjson/2.0.9/

```


![image-20230521200329668](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230521200329668.png)


其中`ArticleId`和`Version`都是可以省略的,比如省略`Version`:


![image-20230521200922731](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230521200922731.png)


比如同时省略`ArticleId`和`Version`:


![image-20230521200948849](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230521200948849.png)


其中GroupId可以输入`com.alibaba:fastjson`的形式:


![image-20230521200804487](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230521200804487.png)


另外三个输入框都有历史输入记录。


## 3.4 展开因为过长而被隐藏的文本


开启插件之前,可以看到文本超出部分都被隐藏了,当他们前缀相似的时候很难区分到底谁是谁:


![image-20230727112824602](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230727112824602.png)


开启插件之后,将被隐藏的文本显示全,同时保证布局不会乱掉(在某些窄屏可能会有问题,稍微宽一点的屏基本都没问题):


![image-20230727112809379](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230727112809379.png)


在详情页未开启插件:


![image-20230727113109999](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230727113109999.png)


开启了插件之后:


![image-20230727113126701](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20230727113126701.png)


# 四、FAQ


![image-20241218030043456](https://gh.api.99988866.xyz/https://raw.githubusercontent.com/scagogogo/mvnrepository-helper-UserScript/main/README.assets/image-20241218030043456.png)


# 五、Contributors


![](https://contrib.nn.ci/api?repo=scagogogo/mvnrepository-helper-UserScript)


# 六、Star History


![](https://starchart.cc/scagogogo/mvnrepository-helper-UserScript.svg)

目录
相关文章
|
9月前
|
机器学习/深度学习 人工智能 搜索推荐
医疗领域的人工智能:诊断和治疗的革命
医疗领域的人工智能:诊断和治疗的革命
336 84
|
API 开发工具 git
git常用的API以及每个的应用场景
【4月更文挑战第5天】Git是流行的分布式版本控制系统,用于代码管理,提供丰富的API。本文概述了Git常用API,如`git init`(初始化仓库)、`git add`(添加到暂存区)、`git commit`(提交)、`git remote add origin`(添加远程仓库)、`git pull`和`push`(同步远程仓库)、`git branch`(分支管理)以及`git checkout`(切换分支或恢复文件)。了解和熟练使用这些API能提升开发效率和代码质量,更多Git功能可参考官方文档。
723 0
|
9月前
|
数据采集 分布式计算 大数据
Pandas数据清洗:缺失值处理
本文详细介绍了Pandas库中处理缺失值的方法,包括检测缺失值、删除缺失值、填充缺失值和插值法填充缺失值。通过基础概念和代码示例,帮助读者理解和解决数据清洗中常见的缺失值问题。
519 80
|
9月前
|
存储 安全 Java
Spring Boot 编写 API 的 10条最佳实践
本文总结了 10 个编写 Spring Boot API 的最佳实践,包括 RESTful API 设计原则、注解使用、依赖注入、异常处理、数据传输对象(DTO)建模、安全措施、版本控制、文档生成、测试策略以及监控和日志记录。每个实践都配有详细的编码示例和解释,帮助开发者像专业人士一样构建高质量的 API。
255 9
|
9月前
|
前端开发 JavaScript 开发者
React 按钮组件 Button
本文介绍了 React 中按钮组件的基础概念,包括基本的 `<button>` 元素和自定义组件。详细探讨了事件处理、参数传递、状态管理、样式设置和可访问性优化等常见问题及其解决方案,并提供了代码示例。帮助开发者避免易错点,提升按钮组件的使用体验。
431 77
|
9月前
|
存储 弹性计算 数据挖掘
阿里云服务器ECS经济型e实例与通用算力u1区别、特性优势、使用场景及租赁费用对比
阿里云ECS云服务器的经济型e实例和通用算力型u1实例各有特点。e实例适合个人开发者和小微企业,适用于中小型网站、开发测试和轻量级应用,性价比高。u1实例则更适合中小企业,提供更高的性能和稳定性,适用于企业级应用、数据分析和中小型数据库。同等配置下,u1实例在计算、存储和网络性能上优于e实例。
609 86
|
9月前
|
机器学习/深度学习 编解码 人工智能
ColorFlow:腾讯和清华大学联合推出的图像序列着色模型,通过参考图像的颜色对黑白漫画进行着色生成彩色漫画
ColorFlow是由清华大学和腾讯ARC实验室共同推出的图像序列着色模型,通过检索增强、上下文学习和超分辨率技术,确保黑白图像序列的着色与参考图像颜色一致,适用于漫画、动画制作等工业应用。
651 15
ColorFlow:腾讯和清华大学联合推出的图像序列着色模型,通过参考图像的颜色对黑白漫画进行着色生成彩色漫画
|
9月前
|
弹性计算 运维 监控
云资源运维难?阿里云免费工具来帮忙
阿里云推出免费运维工具——云服务诊断,帮助用户提升对云资源的运维效率、降低门槛、减轻负担。其核心功能包括「健康状态」和「诊断」。通过「健康状态」可实时查看云资源是否正常;「诊断」功能则能快速排查网络、配置、安全等问题,并提供修复建议,助您迅速恢复业务。体验评测活动火热进行中,参与即有机会赢取索尼头戴耳机、小米背包等好礼。活动链接:https://developer.aliyun.com/topic/cloud-health。
833 24
|
9月前
|
机器学习/深度学习 人工智能 监控
《C++赋能智能摄像头:开启实时视频分析新纪元》
在科技飞速发展的今天,智能摄像头结合人工智能技术,实现了人员识别、行为分析和异常事件预警等强大功能。C++凭借其高效性和对底层资源的出色掌控能力,成为将人工智能模型部署到智能摄像头的关键技术之一。本文深入探讨了如何在C++中实现这一目标,解锁智能摄像头的无限潜能。文章详细介绍了智能摄像头与人工智能的结合带来的需求与挑战,C++的独特优势,以及模型选择与优化、环境搭建与依赖配置、数据传输与预处理、模型集成与实时分析等关键技术要点。最后,提出了应对复杂环境和提升性能的策略,并展望了未来的发展前景。
209 18