做为一个开发者,若是你打算开源本身的代码,千万不要忘记,选择一种开源许可证(license)。html
许多开发者对开源许可证了解不多,不清楚有哪些许可证,应该怎么选择。本文介绍开源许可证的基本知识,主要参考了 OpenSource.com (1,2)。dom
开源许可证是一种法律许可。经过它,版权拥有人明确容许,用户能够免费地使用、修改、共享版权软件。post
版权法默认禁止共享,也就是说,没有许可证的软件,就等同于保留版权,虽然开源了,用户只能看看源码,不能用,一用就会侵犯版权。因此软件开源的话,必须明确地授予用户开源许可证。ui
目前,国际公认的开源许可证共有80多种。它们的共同特征是,都容许用户免费地使用、修改、共享源码,可是都有各自的使用条件。spa
若是一种开源许可证没有任何使用条件,连保留做者信息都不须要,那么就等同于放弃版权了。这时,软件能够直接声明进入"公共领域"(public domain)。设计
根据使用条件的不一样,开源许可证分红两大类。htm
- 宽松式(permissive)许可证
- Copyleft 许可证
宽松式许可证(permissive license)是最基本的类型,对用户几乎没有限制。用户能够修改代码后闭源。blog
它有三个基本特色。排序
(1)没有使用限制开发
用户可使用代码,作任何想作的事情。
(2)没有担保
不保证代码质量,用户自担风险。
(3)披露要求(notice requirement)
用户必须披露原始做者。
常见的宽松式许可证有四种。它们都容许用户任意使用代码,区别在于要求用户遵照的条件不一样。
(1)BSD(二条款版)
分发软件时,必须保留原始的许可证声明。
(2) BSD(三条款版)
分发软件时,必须保留原始的许可证声明。不得使用原始做者的名字为软件促销。
(3)MIT
分发软件时,必须保留原始的许可证声明,与 BSD(二条款版)基本一致。
(4)Apache 2
分发软件时,必须保留原始的许可证声明。凡是修改过的文件,必须向用户说明该文件修改过;没有修改过的文件,必须保持许可证不变。
Copyleft 是理查德·斯托曼发明的一个词,做为 Copyright (版权)的反义词。
Copyright 直译是"复制权",这是版权制度的核心,意为不经许可,用户无权复制。做为反义词,Copyleft 的含义是不经许可,用户能够随意复制。
可是,它带有前提条件,比宽松式许可证的限制要多。
- 若是分发二进制格式,必须提供源码
- 修改后的源码,必须与修改前保持许可证一致
- 不得在原始许可证之外,附加其余限制
上面三个条件的核心就是:修改后的 Copyleft 代码不得闭源。
常见的 Copyleft 许可证也有四种(对用户的限制从最强到最弱排序)。
(1)Affero GPL (AGPL)
若是云服务(即 SAAS)用到的代码是该许可证,那么云服务的代码也必须开源。
(2)GPL
若是项目包含了 GPL 许可证的代码,那么整个项目都必须使用 GPL 许可证。
(3)LGPL
若是项目采用动态连接调用该许可证的库,项目能够不用开源。
(4)Mozilla(MPL)
只要该许可证的代码在单独的文件中,新增的其余文件能够不用开源。
本节回答一些开源许可证的常见问题。
除了 Affero GPL (AGPL) ,其余许可证都规定只有在"分发"时,才须要遵照许可证。换言之,若是不"分发",就不须要遵照。
简单说,分发就是指将版权做品从一我的转移到另外一我的。这意味着,若是你是本身使用,不提供给他人,就没有分发。另外,这里的"人"也指"法人",所以若是使用方是公司,且只在公司内部使用,也不须要遵照许可证。
云服务(SaaS)是否构成"分发"呢?答案是不构成。因此你使用开源软件提供云服务,没必要提供源码。可是,Affero GPL (AGPL) 许可证除外,它规定云服务也必须提供源码。
某些许可证(Apache 2 和 GPL v3)包含明确的条款,授予用户许可,使用软件所包含的全部专利。
另外一些许可证(BSD、MIT 和 GPL v2)根本没提到专利。可是通常认为,它们默认给予用户专利许可,不构成侵犯专利。
总得来讲,除非有明确的"保留专利"的条款,使用开源软件都不会构成侵犯专利。
全部的开源许可证都带有"披露要求"(notice requirement),即要求软件的分发者必须向用户披露,软件里面有开源代码。
通常来讲,你只要在软件里面提供完整的原始许可证文本,而且披露原始做者,就知足了"披露要求"。
GPL 许可证规定,只要你的项目包含了 GPL 代码,整个项目就都变成了 GPL。有人把这种传染性比喻成"GPL 病毒"。
不少公司但愿避开这个条款,既使用 GPL 软件,又不把本身的专有代码开源。理论上,这是作不到的。由于 GPL 的设计目的,就是为了防止出现这种状况。
可是实际上,不遵照 GPL,最坏状况就是被起诉。若是你向法院表示没法履行 GPL 的条件,法官只会判决你中止使用 GPL 代码(法律上叫作"中止侵害"),而不会强制要求你将源码开源,由于《版权法》里面的"违约救济"没有提到违约者必须开源,只提到能够中止侵害和赔偿损失。
(完)