这篇文章对于我们做技术选型以及技术学习都有极强的指导性作用,建议收藏!

原创不易,若有帮助,欢迎点赞!

推荐:

开源安全基金会(OpenSSF)发布了 Github 上一些热门开源项目的关键性评分数据。相比于项目的 Star 数量来说,这个关键性评分的含金量更高、更能反应项目的价值。

并且,统计数据是按照编程语言来划分的。涵盖的编程语言非常广,像 Java、C、C++、Go、JS、Php、Python 这些比较火的编程语言都在其中。

对于每一个项目,OpenSSF 就会根据一定的规则给其一个关键性评分。这样的话,关键性评分的计算规则就非常重要了!

下面这些参数决定了开源项目的关键性评分。并且,这些参数之间的权重也不一样。

  • created_since :项目创建时间(单位:月)
  • updated_since: 最近一次更新项目的时间(单位:月)
  • contributor_count : 项目贡献者数量
  • org_count : 项目的贡献者所属的不同开源组织的数量
  • commit_frequency : 项目去年平均每周提交次数
  • recent_releases_count : 项目去年发行的版本数量
  • closed_issues_count : 项目在过去 90 天里关闭的 issue 数量。
  • updated_issues_count : 项目在过去 90 天里更新的 issue 数量。
  • comment_frequency : 项目在过去 90 天里每个 issue 的平均评论数量
  • dependents_count : 项目提交消息中提及的项目数

有了参数之后,我们根据对应的算法/规则即可计算出项目的关键性评分(0~1 之间)。

计算规则的话,小伙伴们可以在项目首页找到。项目地址:https://github.com/ossf/criticality_score

我这里简单带着小伙伴们看下 Java 项目的情况。

对应编程语言的统计数据下载地址:https://commondatastorage.googleapis.com/ossf-criticality-score/index.html

对于 Java 后端开发来说,项目的前 15 名中,大家最熟悉的莫过于下面这几个项目:

  • Gradle:对比 Maven,Gradle 同样是一款非常好用的项目构建工具 。大部分小伙伴的客观印象是 Gradle 只在安卓项目上用的比较多,实际并不是。关于 Gradle 的使用方法可以看这篇文章:《说实话,用完 Gradle 之后,有点嫌弃 Maven 了。贼好用!》
  • Spring Boot : Java 后端开发领域杀手锏级别的框架,只要你是 Java 后端开发,你就离不开它!非常好用!生态也非常棒!
  • JDK :这里指的是 OpenJDK。Oracle JDK 是 OpenJDK 的一个实现,并不是完全开源的
  • Jenkins :一款基于 Java 开发的持续集成工具,避免了我们手动进行 CI/CD 的工作。
  • Netty :我在前面的文章就提过:但凡涉及到网络通信就必然必然离不开网络编程。 Netty 目前作为 Java 网络编程最热门的框架,毫不夸张地说是每个 Java 程序员必备的技能之一。如果你要学习 Netty 的话,可以看看开源的 Netty 入门教程:https://github.com/Snailclimb/netty-practical-tutorial
  • PMDPMD是一款常用的程序代码检查工具。我们在项目中一般会集成它来对自己提交的代码做一层保障。

我们看了关键性评分最高的几个项目之后,再来看看有关技术选型的问题。

Spring Security VS Shiro

Spring Security 的关键评分位列所有 Java 项目的第 29 位。很遗憾的是,Shiro 并未上榜。

Spring Security 是 Spring 全家桶中非常强大的一个用来做身份验证以及权限控制的框架,我们可以轻松地扩展它来满足我们当前系统安全性这方面的需求。

Spring Security 背靠 Spring 生态,可谓是有一个强大的后盾。

虽然,相比于 Shiro 来说,Spring Security 的学习曲线更陡峭。但是,从生态等方面来说,Spring Security 依然是你做身份验证以及权限控制时的首选框架。

Fastjson vs Jackson

Fastjson 和 Jackson 两者都是比较常见的 Java 开源 JSON 解析库。

从 Star 数量来看的话,Fastjson 最多, Jackson 的低了很多。但是,关键性评分 Jackson 领先了很多,这个也是在我的意料之中。

主要也是因为 Fastjson 的代码质量以及设计更差,并且,经常被爆出有安全漏洞(设计问题)。虽然 Fastjson 在速度方面稍稍取胜,但是,差别和 Jackson 是不太明显的。

Spring MVC 默认采用 Jackson 解析 Json 也是有它的道理, 肯定不是 Spring 的那群巨佬拍个桌子就能决定的。

综上,我更推荐使用 Jackson 作为项目的 JSON 解析库。

Flyway vs Liquibase

Flyway 和 Liquibase 两者都是比较常见的数据库迁移工具。

Flyway 的关键评分位列所有 Java 项目的第 70 位,Liquibaseo 未上榜。

Guava vs Hutool

Guava 和 Hutool 两者都是目前非常好用的 Java 第三方工具类库。Guava 是 google 开源的,Hutool 是纯国产。

Guava 的关键性评分位列所有 Java 项目的第 78 位,而 Hutool 位于第 196 位。

相关文章:

ShardingSphere vs MyCat

ShardingSphere (包括 Sharding-JDBC、Sharding-Proxy 和 Sharding-Sidecar ) 和 MyCat 两者都是常用分布式数据库中间件,分库分表等场景都会用到。

ShardingSphere 项目是当当捐入 Apache 的,目前主要由京东数科的一些巨佬维护。Mycat 是基于阿里 Cobar 演变而来。

ShardingSphere 的关键评分位列所有 Java 项目的第 72 位,MyCat 并为上榜。

这也是意料之中的事情了,毕竟 ShardingSphere 的生态体系更加完善,社区更加活跃,文档更加完善,更新和发布也更加频繁。从任何角度来说,你都没有理由选择 MyCat 。

我的Github地址:Snailclimb - Overview

来啦!2020 Java开源项目权威排名解读:Spring Boot排名稳定、Shiro未上榜的更多相关文章

  1. 网上下载的 java开源项目 如何 打jar包

    目前很多java开源项目(例如qlexpress)只提供了源码,没有提供jar,下面提供maven打jar包的方法. 1.进入qlexpress下载后源代码所在的目录,此目录应包含pom.xml,如下 ...

  2. 用Java开源项目JOONE实现人工智能编程

    http://www.robotsky.com/ZhiN/MoS/2011-08-25/13142461416649.html 用Java开源项目JOONE实现人工智能编程 https://sourc ...

  3. 【我整理的java开源项目】

    摘要: 1. 整理出一些使用比较广或者个人觉得比较好的java开源项目和资料供参考. 2. 如果你觉得好但是我没有列出的开源项目请告诉我,方便我添加到列表里. 3. 如果你发现信息描述有误请联系我,我 ...

  4. 3月份GitHub上最热门的Java开源项目

    今天,我们来盘点3月份GitHub上最热门的Java项目的时候了,如果你每月都有关注猿妹发布的排行榜,那么本月的Java项目对你来说一定不陌生,这些都是曾经多次出现在榜单中的项目: 1 advance ...

  5. 硬核! 逛了4年Github ,一口气把我收藏的 Java 开源项目分享给你!

    Awsome Java Great Java project on Github(Github 上非常棒的 Java 开源项目). English Version 大家都知道 Github 是一个程序 ...

  6. 阿里巴巴的26款Java开源项目

    阿里巴巴的26款Java开源项目 开源展示了人类共同协作,成果分享的魅力.没有任何一家网络公司可以不使用开源技术,仅靠自身技术发展起来.“取之于开源,用之于开源,才能促进开源的良性发展”,阿里巴巴各个 ...

  7. java开源项目

    原文地址:http://blog.longjiazuo.com/archives/2625 1.整理出一些使用比较广或者个人觉得比较好的java开源项目和资料供参考.2.如果你觉得好但是我没有列出的开 ...

  8. 硬核! Github上 ,star超高的Java 开源项目分享给你!

    Awsome JavaGreat Java project on Github(Github 上非常棒的 Java 开源项目). English Version 大家都知道 Github 是一个程序员 ...

  9. 【c3p0】目前使用它的开源项目有Hibernate,Spring等

    C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Spring等. c3p0与dbcp区别 JNDI ...

  10. 我的第一个 60 k+ Star Java开源项目

    JavaGuide([Java学习+面试指南] 一份涵盖大部分Java程序员所需要掌握的核心知识):https://github.com/Snailclimb/JavaGuide. 人生总有各种各样的 ...

随机推荐

  1. 简洁好用的python-pip包更新工具

    今天推荐一个github的开源工具 pkgu,支持以表格形式展示当前python环境下的有新版本的package的版本信息,并支持全部或部分更新这些已经过期或者有新版的库. 该工具目前还提供了 cac ...

  2. OLAP引擎也能实现高性能向量检索,据说QPS高于milvus!

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 随着LLM技术应用及落地,数据库需要提高向量分析以及AI支持能力,向量数据库及向量检索等能力"异军突起& ...

  3. Windows 系统如何完全卸载 VSCode

    0. 参考资料 Uninstall visual studio code in windows 1. 删不干净的用户数据 最近正在从 Sublime Text 3 环境切换到 VS Code,看重的是 ...

  4. vue-router路由复用后页面没有刷新

    vue-router提供了页面路由功能,可以用来构建单页面应用,在使用vue-router的动态路由匹配的时候,遇到了url变化了,但是页面却没有任何动静的问题,记录一下. 动态路由匹配url变化了, ...

  5. C# 排序算法1: 冒泡排序

    本文用控制台程序展示数据排序前后的变化,本文数据都按将从小到大进行排序. 1.  准备arr数据  及 arr数据的展示 /// <summary> /// 生成n个元素的int数组 // ...

  6. java基础-Junit 注解 枚举-day12

    目录 1. Junit 2. 注解 annotation 3. 枚举 1. Junit 白盒测试 黑盒测试 自行baidu了解 java单元测试 package com.msb01; import o ...

  7. 类的MRO属性 C3算法

    C3算法 class A(object): pass class B(A): pass class C(A): pass class D(B): pass class E(C): pass class ...

  8. bitcask论文翻译/笔记

    翻译 论文来源:bitcask-intro.pdf (riak.com) 背景介绍 Bitcask的起源与Riak分布式数据库的历史紧密相连.在Riak的K/V集群中,每个节点都使用了可插拔的本地存储 ...

  9. MyBatis_问题解决:Invalid bound statement (not found)

    Invalid bound statement (not found)问题,即在mybatis中dao接口与mapper配置文件在做映射绑定的时候出现问题,简单说,就是接口与xml要么是找不到,要么是 ...

  10. 【水一篇】骚操作之net 6的winform启动的同时启动Net 6 WebApi【同一套代码】

    引言 有段时间没有写博客了,不知道写什么,加上最近一直在玩单片机方面的东西,所以有一些懈怠.首先呢,为什么会有这么一个问题,是在一个QQ群里,有看到有人提问,能不能在启动Winform的同时去启动一个 ...