软件开发者如何保护自己的知识产权?

2024-05-07 23:04

本文主要是介绍软件开发者如何保护自己的知识产权?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近一个关于开源软件的知识产权纠纷的案例,非常有代表性,

其中涉及到的平台openwrt,一口君十几年前曾玩过,

通过这个案例,我们可以学习如何在今后工作中保护自己的知识产权

以及如何合理直接或者间接利用别人的“成果”而不侵权

一口君觉得非常有必要分享出来,让大家多了解知识产权的知识。

一、关于本案

1. 案子概述

通过下面鱼骨图,简单说一下这个案子的来龙去脉:

总结起来就是:

  • 苏州公司基于openwrt开发了网关产品,但是用一种方法绕开GPLv2限制,
  • 浙江通信公司通过苏州公司离职的两个核心员工抄袭了苏州公司的代码
  • 法院二审裁定,苏州公司上层功能软件构成GPLv2协议项下“独立且分离的”,裁定浙江通信公司侵犯苏州公司软件著作权


2. 本案的核心:

本案争辩的核心主要两点:

浙江某通信科技有限公司等被诉侵权人基于GPLv2协议提出的不侵权抗辩是否成立?

软件开发者自身存在一定程度上的违反GPLv2协议,是否就一定不享有新研发软件著作权?

要想整明白这个问题,我们必须要搞懂GPL、Openwrt、软件著作权是什么。

二、什么是GPL?

关于GPL,一口君下面文章,做了详细讲述,大家可以回顾一下。
《GPL前世今生》


GPL许可协议(GNU General Public License):只要软件中包含有其他GPL协议的产品或代码,那么该软件就必须也采用GPL许可协议且开源及免费。

具有以下特点:

  • 复制自由:
    允许将软件复制到任何人的电脑中,并且不限制复制的数量。
  • 传播自由:
    允许以各种形式进行传播。
  • 收费传播:
    允许在各种媒介上出售该软件,但必需提前让买家知道这个软件是可以免费获得的,并解释收费的理由(一般来讲都是能够为用户提供某种服务,以技术服务的形式来收费)。
  • 修改自由:
    允许开发人员增加或删除软件的功能,但必须依然基于GPL许可协议授权。

总结成一句话,修改后必须以GPL授权开源发布。

只要在代码中加入这个名叫GPL的许可证,你就能保证软件的用户能够自由地运行、研究、分享和修改你的代码了。

而且,从你的软件衍生出的一切修改版本,都必须遵守这个许可协议。

一个有意思的地方是,拥有代码的人有权利用代码开发软件并盈利。

但是,在有人花钱买走软件之后,这个人可以随意把买到的软件分享给其他人,而不必担心侵权,甚至是被告上法庭——因为对于遵守开源协议的软件来说,压根不存在“盗版”的概念。

由此可见,开源协议大大地提高了软件使用者的权利。

除了GPL之外还有很多其他协议,见下图:

三、什么是openwrt?

1. openwrt基础知识

OpenWrt 是一个基于 Linux 的、针对嵌入式网络设备的开源操作系统。它主要用于替代各种家用路由器上的原始固件。

Linux我们知道,他是目前最著名的遵循GPL协议的开源软件。

所以openwrt也是开源的。

OpenWrt 具备一个好的路由器应该具备的所有有用功能:

DNS 服务器(dnsmasq),WiFi 接入点(AP)和客户端功能,用于调制解调器功能的 PPP 协议,还支持webserver

而且,与标准固件不同,这一切都是可以完全配置的。

正式因为openwrt集成了这么多和网络息息相关的功能模块,

所以基于openwrt,可以很方便的开发和迭代出新的网络产品,

我们市面见到的很多无线通信产品,比如:家用路由器、无线AP等都是基于openwrt开发的。


本案中的苏州网络公司,他们所开发的源码正是基于openwrt开发的。

官网地址:

https://openwrt.org/

2. openwrt当年被迫开源

网络产品设备商的扛把子Cisco/Linksys(思科) 在 2003 年发布了 WRT54G 这款无线路由器。

同年有人发现它的操作系统是基于Linux的,然而 Linux 是基于GPL许可证发布的,按照该许可证 Cisco 应该把 WRT54G 的源代码公开。

2003年3月,Cisco 迫于公众压力公开了 WRT54G 的源代码。

此后就有了一些基于 Cisco 源码的第三方路由器固件,OpenWrt 就是其中的一个。

那么既然openwrt是开源的,根据gpl协议规定,

苏州公司的软件产品《OfficeTen》应该也是开源的才对,

那么为什么最终法院裁定浙江通信公司侵权了呢?

我们只需要搞清楚,安卓如何绕开GPL,就明白了。

四、安卓如何规避GPL的?

Android内核也是Linux,那他是如何规避GPL的?

下图是一个完整的Android软件系统所用到的所有协议分布。

图片与Android关系最为密切的主要包括两个方面:驱动和glibc

1. glibc

glibc是linux上的主流的c运行时库,几乎每个linux程序都会简介的依赖c运行时库。

由于glibc是gpl授权的,因此如果采用glibc作为crt,按照前述问题的第二条,这些程序必须开源。

因此安卓采用bionic作为c运行时库替代glibc来规避gpl

2. 驱动

再说驱动,Android是基于Linux 内核开发的,Linux内核是GPL授权。

传统的驱动是要作为内核模块被加入到内核中的。

而内核模块属于Linux内核的衍生产品,需要遵守GPL协议开源发布。

Android是由开放手机联盟共同完成的,为了保护联盟中手机生产商的利益,驱动不能被完全开源。

因此安卓引入HAL,给linux内核开了个后门,增加了一些系统调用

HAL在内核的部分按照GPL的要求开源。

驱动开发者可以在用户态使用这些新增的系统调用完成驱动的开发。

从而在驱动方面规避了GPL。

3. 详细说明:

Android的硬件抽象层,简单来说,就是对Linux内核驱动程序的封装,向上提供接口,屏蔽低层的实现细节。

也就是说,把对硬件的支持分成了两层,一层放在用户空间(User Space),一层放在内核空间(Kernel Space), 其中,硬件抽象层运行在用户空间,而Linux内核驱动程序运行在内核空间。

为什么要这样安排呢?

把硬件抽象层和内核驱动整合在一起放在内核空间不可行吗?

从技术实现的角度来看,是可以的,然而从商业的角度来看,把对硬件的支持逻辑都放在内核空间,可能会损害厂家的利益。

我们知道,Linux内核源代码版权遵循GNU License,而Android源代码版权遵循Apache License,前者在发布产品时,必须公布源代码,而后者无须发布源代码。

如果把对硬件支持的所有代码都放在Linux驱动层,那就意味着发布时要公开驱动程序的源代码,而公开源代码就意味着把硬件的相关参数和实现都公开了,在手机市场竞争激烈的今天,这对厂家来说,损害是非常大的。

因此,Android才会想到把对硬件的支持分成硬件抽象层和内核驱动层,

  • 内核驱动层只提供简单的访问硬件逻辑,
    例如读写硬件寄存器的通道
  • 硬件抽象层负责硬件对应寄存器的读写操作,这样就可以把商业秘密隐藏起来了。

也正是由于这个分层的原因,Android被踢出了Linux内核主线代码树中。

大家想想,Android放在内核空间的驱动程序对硬件的支持是不完整的,把Linux内核移植到别的机器上去时,由于缺乏硬件抽象层的支持,硬件就完全不能用了,这也是为什么说Android是开放系统而不是开源系统的原因。

4. 苏州公司如何绕开GPLv2的?

具体到本案,苏州某网络科技有限公司研发的“OfficeTen”软件是以OpenWRT系统软件(OpenWRT系统软件是开源软件,适用的许可证协议为GPLv2协议)为基础经二次开发形成的衍生软件,

具体可分为两个部分:

  • 一部分是对OpenWRT系统软件所对应源代码进行增删、修改、调整而形成的涉案软件底层系统(以下简称底层系统软件),
  • 另一部分则是与涉案软件具体功能相对应的新增源代码形成的上层功能软件(以下简称上层功能软件)。

苏州某网络科技有限公司声称其在底层系统软件与上层功能软件之间采用套接字(socket)与命令行(command line)等技术手段建立了隔离层,
且二者之间通信内容不涉及内部数据结构信息,由此使得上层功能软件构成GPLv2协议项下“独立且分离的”的程序。

最高法院知产法庭在二审判决中认定,苏州某网络科技有限公司投资研发的名称为“OfficeTen”的网关产品系统软件,投入了大量成本,
涉案软件具有独创性且可以复制,构成著作权法项下的作品,依法应当获得保护。

他人未经苏州某网络科技有限公司许可,不得擅自复制、修改、发行涉案软件,否则将构成侵害涉案软件著作权的违法行为。

合议庭依在案证据认定关联网络公司在开发被诉软件过程中复制并修改了苏州某网络科技有限公司涉案软件的源代码;认定浙江某通信科技有限公司实施了销售被诉软件的行为。

认定该复制、修改、发行行为均未经苏州某网络科技有限公司许可,侵害了其享有的涉案软件著作权

五、软件著作权

本案中,法院最终保护的是苏州公司的软件著作权,所以什么是软件著作权?

1. 什么是软件著作权?

软件著作权是指由权利人根据法律规定享有的,他人不可侵犯的民事权利。

软件著作权保护是对计算机程序文档两部分的保护。

软件著作权保护不延及开发软件所用的思想、处理过程、操作方法或者数学概念。

《计算机软件保护条例》

第二条
本条例所称计算机软件(以下简称软件),是指计算机程序及其有关文档。
第三条
本条例下列用语的含义:
(一)计算机程序,是指为了得到某种结果而可以由计算机等具有信息处理能力的装置执行的代码化指令序列,或者可以被自动转换成代码化指令序列的符号化指令序列或者符号化语句序列。同一计算机程序的源程序和目标程序为同一作品。
(二)文档,是指用来描述程序的内容、组成、设计、功能规格、开发情况、测试结果及使用方法的文字资料和图表等,如程序设计说明书、流程图、用户手册等。

2. 在我国软件著作权登记有什么意义?

  • 1、享受国家优惠政策:
    办理软件著作权登记的企业可享受国家各种优惠政策,包括投融资、税收、出口政策等,具体可参见国务院18号文件;

  • 2、“双软认定”的前提:
    软件著作权登记是企业办理“双软认定”(软件产品登记、软件企业认定)的必要前提。信息产业部的《软件产品登记管理办法》的第七条第四款规定,软件登记时要提交知识产权证明。此知识产权证明即指《软件著作权登记证书》;

  • 3、可作为技术出资入股:
    《关于以高新技术成果出资入股若干问题的规定》规定:“计算机软件可以作为高新技术出资入股,而且作价的比例可以突破公司法20%的限制达到35%。”甚至有的地方政府规定“可以100%的软件技术作为出资入股”,但都要求必须首先办理软件著作权登记;

  • 4、申请科技成果的依据:科学技术部关于印发《科技成果登记办法》的通知第八条规定:“办理科技成果登记应当提交《科技成果登记表》及下列材料:

()应用技术成果:相关的评价证明(鉴定证书或者鉴定报告、科技计划项目验收报告、行业准入证明、新产品证书等)和研制报告;()知识产权证明(专利证书、植物品种权证书、软件登记证书等)和用户证明”。这里的软件登记证书指的是软件著作权登记证书和软件产品登记证书。其他部委也有类似规定;
  • 5、企业破产后的有形收益:
    软件著作权作为企业的“无形资产”,不会随企业的破产而消失。企业破产后,无形资产的生命力和价值仍然存在,可以在转让和拍卖中获取有形资金;

  • 6、予以重点保护:
    计算机软件著作权登记是我国著作权法规所规定的对计算机软件著作权保护的一项行政辅助管理措施,《计算机软件著作权登记办法》第二条和国务院18号文件均有规定,国家著作权行政管理部门鼓励著作权人进行计算机软件著作权登记,并对已登记的软件给予重点保护。

六、对科技企业的警示

  1. 有知识产权保护意识

作为企业负责人或者软件开发管理者,一定要有知识产权保护意识,

开发的软件要及时申请软件著作权,

对于一些有创新的产品还要及时申请专利,

  1. license授权

软件最大的问题就是复制性,

通过license授权可以在一定程度上保护自己的软件产品。

详情大家可以参考下面文章:

《软件License授权原理》

  1. 对于技术人员的管理

技术人员的是企业的核心竞争力,

企业要想做走的更长远、提升产品竞争力,

主要依靠的就是研发,

平时要注重技术人的培训和提升,

保持研发团队人员的稳定,

尤其是核心技术人员,

核心技术人员的流失对企业会有致命的伤害,

一旦加入竞争对手的公司,

后果不堪设想。

  1. 关键岗位签署竞业协议

对于一些非常重要得岗位,

要与员工签署竞业协议,

最大程度上保护自己。

这篇关于软件开发者如何保护自己的知识产权?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/968644

相关文章

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank 正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

如何保护自己的个人隐私

个人隐私保护概览 在数字时代,个人隐私保护显得尤为重要。随着信息技术的发展,个人信息的收集、存储、使用变得更加便捷,同时也带来了隐私泄露的风险。为了保护个人隐私,我们需要从多个维度出发,采取一系列措施来确保个人信息的安全。 个人隐私泄露风险 个人隐私泄露主要来源于以下几个方面: 社交网络:在社交平台上分享信息时,如果不恰当地设置了隐私权限,可能会导致敏感信息被公开。网络服务:在使用网络服务

梳理2024年,螺丝钉们爱用的3款剪辑软件

这年头,视频到处都是,就跟天上的星星一样数不清。不管你是公司里的新面孔,还是职场上的老狐狸,学会怎么剪视频,就好比找到了赢的秘诀。不管是给上司汇报工作,展示你的产品,还是自己搞点小视频记录生活,只要是剪辑得漂亮,肯定能一下子吸引大家的目光,让人记得你。咱们今天就来侃侃现在超火的三款视频剪辑工具,尤其是PR剪辑,你肯定听说过,这货在剪辑界可是大名鼎鼎,用它剪视频,既专业又麻利。 NO1. 福昕轻松

秒变高手:玩转CentOS 7软件更换的方法大全

在 CentOS 7 中更换软件源可以通过以下步骤完成。更换源可以加快软件包的下载速度,特别是当默认源速度较慢时。以下是详细步骤: 前言 为了帮助您解决在使用CentOS 7安装不了软件速度慢的问题,我们推出了这份由浪浪云赞助的教程——“CentOS7如何更换软件源加快下载速度”。 浪浪云,以他们卓越的弹性计算、云存储和网络服务受到广泛好评,他们的支持和帮助使得我们可以将最前沿的技术知识分

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

【电子通识】半导体工艺——保护晶圆表面的氧化工艺

在文章【电子通识】半导体工艺——晶圆制造中我们讲到晶圆的一些基础术语和晶圆制造主要步骤:制造锭(Ingot)、锭切割(Wafer Slicing)、晶圆表面抛光(Lapping&Polishing)。         那么其实当晶圆暴露在大气中或化学物质中的氧气时就会形成氧化膜。这与铁(Fe)暴露在大气时会氧化生锈是一样的道理。 氧化膜的作用         在半导体晶圆