成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何為你的代碼選擇一個合適的開源協議?

新聞 前端
近期公司全面擁抱開源,在選擇開源協議方面遇到了一些問題,查閱了很多資料,特此總結。

[[419038]]

前言

對于很多剛踏入開源軟件這個行業的小伙伴來說,在編碼過程中難免會用到其他人的成果,如果你足夠細心,很容易注意到即使是一小段代碼,優秀的作者都在文件開頭附上一段關于版權的聲明,比如 Licensed under the MIT license 。同時,一些博客也會標明”此文章采用 CC BY 4.0 CN 協議“。

如果我們拷貝了別人的代碼或文章卻沒注意版權問題,在國外法律意識特別強的環境下(國內版權意識也在逐步加強),那么我們的作品會因觸犯別人的權益而違法。即使是最開放的開源協議,最低要求也是保留原作者對代碼的聲明,所以 開源不等于免費,也不等于沒有約束 。

何為 LICENCE?

LICENCE 是軟件的授權許可,詳細說明了獲得代碼后擁有的權利,哪些操作是允許的,哪些操作是禁止的。軟件的版權許可證可有很多方式,本文僅限于討論開源軟件協議 Open Source License。

對于大多數人來說,沒必要花大把時間去寫許可協議,選擇一種比較流行的開源協議就足夠了,省時省力,更便于自己作品的傳播,于人于己都有利。

PS:

說句題外話,很多國外開發者在尊重他人勞動成果方面做得很好,如果A的作品是因為B的作品的啟發而來,A甚至都沒有使用B任何一句代碼,但A會在他的作品里面指明是受到了B的啟發: Inspired by XXX link: http://www.xxxx.com 。

快速選擇開源協議

如果你不想了解太多,只是想要一個簡直直接的答案,下面給出的建議或許適合你。本小節關于協議地址來自于 GitHub choosealicence 。

簡單寬松的協議:

如果你只想要一個簡單點的協議不想太麻煩的話。

MIT協議 相對寬松,此協議允許別人以任何方式使用你的代碼同時署名原作者,但原作者不承擔代碼使用后的風險,當然也沒有技術支持的義務。

考慮有專利的情況:

如果你的作品中涉及到專利相關。

Apache協議 也是個相對寬松的協議,與MIT類似,但它指明了作者對用戶專利上的一些授權(我的理解是軟件作品中含有專利,但它授權你可以免費使用)。

促進代碼分享:

如果你在乎作品的傳播和別人的修改,希望別人也以相同的協議分享出來。

GPL( V2 或 V3 )協議要求代碼分發者或者以此代碼為基礎開發出來的衍生作品需要以同樣的協議來發布,也必須開源,因此,該協議具有”傳染性“。

烏克蘭程序員 Paul Bagwell 畫了一張分析圖,說明應該怎么選擇。只用兩分鐘,你就能搞清楚這六種開源協議之間的最大區別。

國內大神阮一峰的漢化版本:

主流開源許可協議(Open Source License)

世界上的開源許可協議(Open Source License)大概有 上百種 ,常用的開源軟件協議大致有:

  • GPL
  • LGPL
  • BSD
  • MIT
  • Mozilla
  • Apache

由寬松到嚴緊排序,常用的開源協議有:

  1. MIT
  2. BSD
  3. Apache
  4. LGPL
  5. GPL

主要區別:

  • MIT、BSD 開源協議都源自大學,體現了簡單、開放和包容的特點。
  • MIT、BSD、Apache 三者都支持閉源的后續開發。
  • GPL、LGPL 傳染性開源,編譯的代碼里用了這里的代碼,都必須開源。

MIT

來源于大學,MIT 開源協議是史上最為簡潔、慷慨的開源協議之一。作者只想保留版權,而無任何其他了限制。也就是說,你必須在你的發行版里包含原許可協議的聲明,無論你是以二進制發布的還是以源代碼發布的。

特點:

  • 用戶可以拿你的代碼做任何想做的事情。
  • 用戶在項目副本中要包含版權聲明和許可聲明。
  • 你無需承擔任何責任。

代表作品:

  • jQuery
  • Rails 等。

BSD

  • BSD-2-Clause
  • BSD-3-Clause

BSD可證也來源于大學,與MIT差不多,也非常簡單、慷慨。

BSD開源協議是一個給于使用者很大自由的協議?;旧鲜褂谜呖梢?rdquo;為所欲為”,可以自由的使用、修改源代碼,也可以將修改后的代碼作為開源或者專有軟件再發布。前提是當你發布使用了BSD協議的代碼,或者以BSD協議代碼為基礎開發自己的產品時,需要滿足三個條件:

  1. 如果再發布的產品中包含源代碼,則在源代碼中必須帶有原代碼中的BSD協議。
  2. 如果再發布的只是二進制類庫/軟件,則需要在類庫/軟件的文檔和版權聲明中包含原來代碼中的BSD協議。
  3. 不可以用開源代碼的作者/機構名字和原來產品的名字做市場推廣。

BSD 開源協議鼓勵代碼共享,但需要尊重代碼作者的著作權。BSD 開源協議允許使用者修改和重新發布代碼,也允許使用或在BSD代碼上開發商業軟件發布、銷售,是對商業集成很友好的協議。因此,很多公司在選用開源產品的時候都首選BSD協議。

Apache Licence

  • Apache License, Version 2.0
  • Apache License, Version 1.1
  • Apache License, Version 1.0

來自 Apache,類似 MIT 開源協議,但它重視專利權。

Apache Licence 是著名的非盈利開源組織 Apache 采用的協議。該協議和BSD類似,同樣鼓勵代碼共享和尊重原作者的著作權,同樣允許修改代碼、再發布(作為開源或商業軟件)。需要滿足的條件也和BSD類似:

  1. 需要為使用代碼的用戶提供一份 Apache Licence 。
  2. 如果你修改了代碼,需要在被修改的文件中說明。
  3. 在延伸的代碼中(修改和由源代碼衍生的代碼中)需要帶有原來代碼中的協議、商標、專利聲明和其他原作者規定需要包含的說明。
  4. 如果再發布的產品中包含一個 Notice 文件,則在Notice文件中需要帶有 Apache Licence 。你可以在 Notice 中增加自己的許可,但不可對 Apache Licence 構成更改。

Apache Licence 也是對商業應用友好的許可,使用者也可以在需要的時候修改代碼來滿足需要并作為開源或商業產品發布/銷售。

代表作品:

  • echarts
  • superset
  • dubbo
  • spark

LGPL

LGPL(GNU LESSER GENERAL PUBLIC LICENSE)來自于自由軟件聯盟GNU,可以翻譯為更寬松的GPL協議,也屬于傳染性開源協議。

LGPL是GPL的一個主要為類庫使用設計的開源協議。和 GPL要求任何使用/修改/衍生之GPL類庫的的軟件必須采用GPL協議 不同,LGPL 允許商業軟件通過類庫引用(link)方式使用LGPL類庫而不需要開源商業軟件的代碼。這使得采用LGPL協議的開源代碼可以被商業軟件作為類庫引用并發布和銷售。

但是如果修改LGPL協議的代碼或者衍生,則所有修改的代碼,涉及修改部分的額外代碼和衍生的代碼都必須采用LGPL協議,因此,LGPL協議的開源代碼很適合作為第三方類庫被商業軟件引用,但不適合希望以LGPL協議代碼為基礎,通過修改和衍生的方式做二次開發的商業軟件采用。

GPL/LGPL都保障原作者的知識產權,避免有人利用開源代碼復制并開發類似的產品。

GPL

GPL(GNU GENERAL PUBLIC LICENSE)來源于自由軟件聯盟GNU,GPL/LGPL側重于代碼及衍生代碼的開源與免費使用。

GPL協議的主要內容是只要在一個軟件中使用(”使用”指類庫引用,修改后的代碼或者衍生代碼)GPL 協議的產品,則該軟件產品必須也采用GPL協議,既必須也是開源和免費。 這就是所謂的”傳染性” 。

由于GPL嚴格要求使用了GPL類庫的軟件產品必須使用GPL協議,對于使用GPL協議的開源代碼,商業軟件或者對代碼有保密要求的部門就不適合集成/采用作為類庫和二次開發的基礎。

我們很熟悉的Linux就是采用了GPL。GPL協議和BSD, Apache Licence等鼓勵代碼重用的許可很不一樣。GPL的出發點是 代碼的開源/免費使用/引用/修改 和 衍生代碼的開源/免費使用 ,但 不允許 修改后和衍生的代碼做為 閉源 的商業軟件發布和銷售。

其它細節和BSD/Apache等協議類似。

代表作品:

  • Linux

更多開源協議對比

下方表格中出現的用詞的解釋:

  • 協議和版權信息 (License and copyright notice):在代碼中保留作者提供的協議和版權信息。
  • 聲明變更 (State Changes):在代碼中聲明對原來代碼的重大修改及變更。
  • 公開源碼 (Disclose Source):代碼必需公開。
  • 庫引用 (Library usage):該庫可以用于商業軟件中。
  • 責任承擔 (Hold Liable):代碼的作者承擔代碼使用后的風險及產生的后果。如果禁止,那么作者將不會承擔責任,可以理解為免責條款。
  • 商標使用 (Use Trademark):可以使用作者的姓名,作品的Logo,或商標。
  • 附加協議 (Sublicensing):允許在軟件分發傳播過程中附加上原來沒有的協議條款等。
協議 描述 要求 允許 禁止
Apache 一個比較寬松且簡明地指出了專利授權的協議。 1. \(\color{#0000FF}{協議和版權信息}\)
2. \(\color{#0000FF}{聲明變更}\)
1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{專利授權}\)
5. \(\color{#00EE00}{私用}\)
6. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\) (作者免責)
2. \(\color{#FF3030}{商標使用}\)
GPL 應用最廣泛的開源協議,擁有較強的版權自由(copyleft)要求。
衍生代碼的分發需開源并且也要遵守此協議。
此協議有許多變種,不同變種的要求略有不同。
1. \(\color{#0000FF}{公開源碼}\)
2. \(\color{#0000FF}{協議和版權信息}\)
3. \(\color{#0000FF}{聲明變更}\)
1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{專利授權}\)
5. \(\color{#00EE00}{私用}\)
1. \(\color{#FF3030}{責任承擔}\)
2. \(\color{#FF3030}{附加協議}\)
MIT 此協議寬松簡單。在適當標明來源及免責的情況下,它允許你對代碼進行任何形式的使用。 1. \(\color{#0000FF}{協議和版權信息}\) 1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{私用}\)
5. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\)
Artistic Perl社區最鐘愛此協議。要求更改后的軟件不能影響原軟件的使用。 1. \(\color{#0000FF}{協議和版權信息}\)
2. \(\color{#0000FF}{聲明變更}\)
1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{私用}\)
5. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\)
2. \(\color{#FF3030}{商標使用}\)
BSD 較為寬松的協議,有兩個變種 BSD 2-Clause 和 BSD 3-Clause ,兩者都與MIT協議只存在細微差異。 1. \(\color{#0000FF}{協議和版權信息}\) 1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{私用}\)
5. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\)
Eclipse 對商用非常友好的協議,可以用于軟件的商業授權。包含對專利的優雅授權,也可以對相關代碼應用商業協議。 1. \(\color{#0000FF}{公開源碼}\)
2. \(\color{#0000FF}{協議和版權信息}\)
1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{專利授權}\)
5. \(\color{#00EE00}{私用}\)
6. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\)
LGPL 主要用于一些代碼庫。衍生代碼可以以此協議發布(也可以用其他協議),但與此協議相關的代碼必需遵循此協議。 1. \(\color{#0000FF}{公開源碼}\)
2. \(\color{#0000FF}{庫引用}\)
3. \(\color{#0000FF}{協議和版權信息}\)
1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{專利授權}\)
5. \(\color{#00EE00}{私用}\)
6. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\)
Mozilla Mozilla Public License(MPL 2.0)是由Mozilla基金創建維護的,旨在較為寬松的BSD協議和更加互惠的GPL協議中找一個折衷點。 1. \(\color{#0000FF}{公開源碼}\)
2. \(\color{#0000FF}{協議和版權信息}\)
1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{分發}\)
3. \(\color{#00EE00}{修改}\)
4. \(\color{#00EE00}{專利授權}\)
5. \(\color{#00EE00}{私用}\)
6. \(\color{#00EE00}{附加協議}\)
1. \(\color{#FF3030}{責任承擔}\)
2. \(\color{#FF3030}{商標使用}\)
No license 作者保留所有權利,不允許他人分發,復制或者創造衍生物。
當你將代碼發表在一些網站上時需要遵守該網站的協議,此協議可能包含了一些對你勞動成果的授權許可。比如將代碼發布到GitHub,那么就必須同意別人查看和fork。
1. \(\color{#0000FF}{協議和版權信息}\) 1. \(\color{#00EE00}{商用}\)
2. \(\color{#00EE00}{私用}\)
1. \(\color{#FF3030}{分發}\)
2. \(\color{#FF3030}{修改}\)
3. \(\color{#FF3030}{附加協議}\)
Public domain dedication 在許多國家,默認版權歸作者自動擁有,所以 Unlicense 協議提供了一種通用的模板。
此協議表明作者放棄版權,將勞動成果無私貢獻出來,會喪失作品全部權利,包括在MIT/X11中定義的無擔保權利。

 

 

 

責任編輯:張燕妮 來源: 博客園精華區
相關推薦

2020-03-04 13:53:25

物聯網協議物聯網IOT

2021-09-30 12:55:44

數據處理流處理引擎

2017-02-28 14:17:03

機器學習算法

2015-03-16 12:54:25

虛擬化存儲設備

2022-03-01 18:21:27

云遷移云服務

2023-05-29 15:53:32

DevOps架構自動化

2014-12-29 11:08:31

虛擬化環境存儲設備

2013-07-23 10:31:59

冗余數據遠程數據中心數據中心

2020-12-31 09:39:39

應用圖像格式SVGOMG

2012-03-26 10:02:23

私有云虛擬機云計算

2013-12-02 14:48:17

開源許可協議開放代碼

2021-07-01 10:54:42

云計算供應商云應用

2021-02-23 23:06:31

數據庫Redis技術

2013-07-29 14:04:22

2021-06-29 09:00:00

機器人ITRPA

2017-03-20 16:00:20

深度學習GPU

2018-06-27 09:14:54

嵌入式操作系統Linux

2020-06-16 14:12:02

架構ITAPI

2010-07-08 15:48:34

開源

2009-03-04 11:29:24

ibmdwJava
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久av网站 | 国产一级片免费看 | 日韩在线免费 | 久久久久久综合 | 在线免费观看a级片 | 日韩成人av在线 | 国产精品精品久久久 | 久久久久亚洲精品 | 欧美理论片在线 | 午夜a v电影| 日本高清不卡视频 | 尤物视频在线免费观看 | 丝袜 亚洲 另类 欧美 综合 | 久久精品视频免费观看 | 在线观看视频一区 | 羞羞视频在线观看 | 中文字幕一区在线观看视频 | 在线观看 亚洲 | 欧美视频一区 | 欧美在线视频免费 | 久久婷婷色| 日韩在线视频一区二区三区 | 日本中文字幕在线观看 | 天天天操 | 免费一区二区三区 | 午夜精品一区二区三区在线观看 | 久久久国产精品入口麻豆 | 日韩精品视频在线播放 | 亚洲精品二三区 | 国产a级黄色录像 | 免费a级毛片在线播放 | 亚洲第一黄色网 | 夜夜艹天天干 | 午夜爱爱毛片xxxx视频免费看 | www.99re | 毛片一级电影 | 天天干天天干 | 欧美女优在线观看 | 久久久久91| 欧美区日韩区 | 亚洲精品福利在线 |