逛Github时经常看到项目README旁边,有个License tab,不知道大家是不是跟我一样,撇了一眼就过去了,不太清楚这个license具体作用,有点法律意识的朋友可能会意识到这个可能是版权声明,不过难免还是会有其他疑问:既然都开源了,怎么还有各种条件限制?除了GPL还有Apache、MIT等,这些"License"又有哪些区别呢? 很多朋友可能像之前的我一样,二开项目或者使用第三方组件时直接拿来就用了,没有考虑过其背后的"风险"……
写在前面的一句话:开源 != 免费 首先来看一下关于开源和免费的定义:
开源: 1、一个源码开放的项目(个人或团队开发) 2、一个友好交流的社区(除了源码的开放,还有社区的开放,人人都可以提issue、pr等) 3、一个产品(好的项目同时也是一个好的产品,例如Linux的产品化,可以说,如果没有 Linux 的产品化,也不会有 Linux 开源的枝繁叶茂) 免费: 1、无任何使用费用 2、闭源或开源:免费软件可以是闭源的,也可以是开源的
互联网的发展离不开开源社区的建设,很多时候,开源发布的产品难以满足用户的需求。所以,在不违反相关开源许可证 (License) 的条件下,有些公司对其加以定制,就变身为自己的产品或解决方案。 很多开发同学都不清楚开源许可证的"存在",更别提Boss有这方面的意识了 开源许可证是指用于授权他人使用、修改和分发软件的一种法律文件。它规定了软件的使用权利和义务,确保开发者和用户了解如何合法地使用软件。
这里可以将开源许可证作用总结为:
下面对一些常见许可证进行整理分析
分类 | 示例许可证 | 描述 |
---|---|---|
公共代码 (Public Domain) | CC0、无License | 理论上无限制,任何人都可以自由使用、修改和分发 |
宽松型许可证 (Permissive) | MIT、Apache |