参考资料

五种开源协议的比较(BSD,Apache,GPL,LGPL,MIT)

如何选择开源许可证? - 阮一峰的网络日志

开源许可证教程 - 阮一峰的网络日志

简介

自由软件许可证由FSF(Free Software Foundation)基于FSD(Free Software Definition)负责批准和维护。

开源许可证由OSI(Open Source Initiative)基于OSD(Open Source Definition)负责批准和维护。

这里是目前OSI所批准的许可证列表

如果用户打算开源自己的代码,一般也是从中选择一款开源许可证。

常见的开源许可证有GPL、BSD、Apache、LGPL和MIT等。

分类

根据使用条件的不同,开源许可证可以分为两大类。

宽松式(permissive)

宽松式许可证是最基本的类型,对于用户几乎没有任何限制,二开后可闭源商业化。它有3个基本特点。

  • 没有使用限制;
  • 不担保代码质量;
  • 用户必须披露(notice requirement)原作者。

无版权式(copyleft)

copyleft是由Richard Stallman发明的词汇,是版权(copyright)的反义词。意为无版权的形式,用户未经许可可以随意复制使用。但是其比宽松式许可证的限制要多。

  • 如果发行的是二进制的格式,则必须提供源代码;
  • 修改后的源代码也必须使用修改前的许可证;
  • 不得在原始许可证以外附加其他限制。

以上条件的核心就是,修改后的copyleft代码不可以闭源!

BSD(Berkeley Software Distribution)

BSD许可证给予用户很大的自由协议,近乎“为所欲为”。可以自由使用、修改源代码,可以将修改后的代码开源或者闭源作为商业软件再发布。

“为所欲为”有前提,当发布了使用BSD许可证的代码,或者以BSD许可证的代码为基础做二开,需要满足三个条件:

  • 如果再发布的产品中包含原BSD许可证的代码,则在新产品的源代码中需要包含BSD许可证;
  • 如果再发布的产品是二进制类库/软件,则在新产品的文档和版权说明中需要包含BSD许可证;
  • 不可以使用原BSD许可证的代码的作者/机构名称和原产品名做市场推广。

BSD鼓励代码共享,但需要尊重代码作者的版权。由于BSD允许使用者修改和再发布代码,允许在代码基础上做二开并闭源做商业软件,因此BSD对于商业集成很友好。

Apache

Apache许可证和BSD类似,鼓励代码共享和尊重原作者版权,允许代码修改和再发布,可开源也可闭源商业化。

  • 需要给代码的用户一份Apache License;
  • 需要在被修改的代码文件中做说明;
  • 在延伸的代码中(修改和有源代码衍生的代码中)需要带有原来代码中的许可证、商标、专利声明和其他原作者规定需要包含的说明;
  • 如果再发布的产品中包含Notice文件,则在Notice文件中需要带有Apache License;
  • 可以在Notice文件中增加自己的许可,但不可以表现为对Apache License做出修改,即不能与之冲突。

GPL(GNU General Public License)

我们所熟悉的Linux内核、GCC编译器等,就是使用了GPL。GPL和BSD,Apache很不同。GPL的出发点是代码的开源/免费使用,引用/修改/衍生代码的开源/免费使用,但是不允许修改后的代码和衍生代码作为闭源产品商业化。因此我们可以使用到各种免费使用的Linux发行版,无论是商业公司发行的还是个人/社区发行的,以及在其上的各种开源免费软件。

如果某个产品在代码中使用(这里的“使用”指类库引用,修改后的代码或者衍生代码)了GPL产品。那么该产品也必须采用GPL许可证,即必须也开源和免费使用。这就是GPL许可证的传染性。

因此GPL并不适用于商业环境。

对比图

GPL、BSD和Apache开源许可证的更多相关文章

  1. [转载]一张图看懂开源许可协议,开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    本文转载自:http://blog.csdn.net/testcs_dn/article/details/38496107 开源许可证GPL.BSD.MIT.Mozilla.Apache和LGPL的区 ...

  2. 一张图看懂开源许可协议,开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    一张图看懂开源许可协议,开源许可证GPL.BSD.MIT.Mozilla.Apache和LGPL的区别 首先借用有心人士的一张相当直观清晰的图来划分各种协议:开源许可证GPL.BSD.MIT.Mozi ...

  3. 了解开源的许可证GPL、LGPL、BSD、Apache 2.0的区别 【转】

    原文来自:http://blog.sina.com.cn/s/blog_6870d1e00100lhlv.html 你对开源有多少了解呢?如果你是软件开发者,要开源软件,不单单是开放源代码就可以了,选 ...

  4. 开源的许可证GPL、LGPL、BSD、Apache 2.0的通俗解释

    软件开发者要开源软件,不单单是开放源代码就可以了,选择一种许可证很重要,一个许可证之于软件就相当于价值观之于普通人,代表了这个软件的基本品性.一个错误的许可证选择可能会直接导致整个项目的失败. 各种开 ...

  5. 开源的许可证GPL、LGPL、BSD、Apache 2.0

    软件开发者要开源软件,不单单是开放源代码就可以了,选择一种许可证很重要,一个许可证之于软件就相当于价值观之于普通人,代表了这个软件的基本品性.一个错误的许可证选择可能会直接导致整个项目的失败.各种开源 ...

  6. 开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别(转)

    因CooCox用户数及影响力越来越大,CooCox团队也逐渐提高了对软件及代码协议的重视.在收集整理的过程中,一些归纳好的信息和大家分享一下.首先借用有心人士的一张相当直观清晰的图来划分各种协议:开源 ...

  7. 【转】 一张图看懂开源许可协议,开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    原文:http://blog.csdn.net/testcs_dn/article/details/38496107 ----------------------------------------- ...

  8. [转帖]开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    开源许可证GPL.BSD.MIT.Mozilla.Apache和LGPL的区别 https://www.geek-workshop.com/thread-1860-1-1.html     liamj ...

  9. 转载:开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    转自:https://www.cnblogs.com/findumars/p/6309048.html 首先借用有心人士的一张相当直观清晰的图来划分各种协议:开源许可证GPL.BSD.MIT.Mozi ...

随机推荐

  1. 【经验分享】URL链接地址最长是多少?

    近期在做一个Hot Fix,其中有个界面在IE6下超链接无法打开,经查是链接地址太长,2161个字节,已经超出ie6,7的长度限制,现把发现此问题的过程分享给大家. ===过程===== 1.万恶的i ...

  2. 20145226夏艺华 《Java程序设计》第6周学习总结

    教材学习内容总结 学习目标 理解流与IO 理解InputStream/OutPutStream的继承架构 理解Reader/Writer继承架构 会使用装饰类 会使用多线程进行并发程序设计 第十章 输 ...

  3. HDU 1846 Brave Game 巴什博奕

    解题报告:Alice和Bob在做一个取石子游戏,有一堆n个石子,然后规定每个人每次最少要去1个石子,最多可以取m个石子,最后一次取完石子的人为胜. 巴什博奕,关键是找到必胜点和必败点,我们可以先列举出 ...

  4. Kissy && Require

    KISSY add(name?,factory?,deps)  函数挂载在全局对象KISSY上,用来定义模块.   一个 JS 文件包含一个add()(这时路径+文件名可以用作模块名),如果一个文件包 ...

  5. css单行文本和多行文本溢出实现省略号显示

    1.单行文本溢出 文本内容 <div class="singleLine"> HelloWorldHelloWorldHelloWorldHelloWorldHello ...

  6. SolrJ案例实现搭建环境——(十五)

    案例

  7. 查看linux系统的信息

    #!/bin/sh ################################################## #function:get host's information #Autho ...

  8. 字符串匹配算法之 kmp算法 (python版)

    字符串匹配算法之 kmp算法 (python版) 1.什么是KMP算法 KMP是三位大牛:D.E.Knuth.J.H.MorriT和V.R.Pratt同时发现的.其中第一位就是<计算机程序设计艺 ...

  9. 蛮力法解决0_1背包问题新思路-——利用C语言位域类型

    废话不说了,直接上代码 #include<stdio.h> #include<math.h> #define N 5 //物品种类数目 #define CAPACITY 6 / ...

  10. 【CF767C】Garland

    传送门啦 分析: 这个题我是看着翻译做的,感觉不是很难,很普通的一个树形dp 题目大意: 在一棵树上分离出三个子树,使这三个子树的点权和相等. 明确题目意思这个题就简单多了吧. 我们会发现每一棵子树的 ...