用户代理检测和 ua-parser-js 许可证更改
从现在开始,努力学习吧!本文《用户代理检测和 ua-parser-js 许可证更改》主要讲解了等等相关知识点,我会在golang学习网中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!
作者:ikeh akinyemi✏️
用户代理检测在帮助开发人员针对各种设备、浏览器和操作系统优化网站和应用程序方面发挥着重要作用。通过准确识别用户的环境,开发人员可以定制解决方案以提供最佳的用户体验。
在本文中,我们将了解用户代理检测并探索已在开发人员中广泛采用的 javascript 库:ua-parser-js。 ua-parser-js 最近因其许可模式的变化而成为头条新闻,我们将介绍其从宽松的 mit 许可到双 agplv3 + 商业许可模式的转变,以及这如何影响个人和 saas 项目。
什么是用户代理检测?
用户代理检测是识别用户用于访问您的网站或应用程序的特定软件和硬件组件的过程。检测涉及有关用户的浏览器名称和版本、操作系统、设备类型等信息。
通过利用用户代理检测,开发人员可以就如何呈现和优化用户内容做出明智的决策,确保可访问性、定制体验、跨浏览器和硬件兼容性,并可能增强所使用的各种不同平台的性能.
ua-parser-js 库及其最近的变化
ua-parser-js 是一个轻量级 javascript 库,可简化用户代理检测。该库由 faisal salman 开发和维护,由于其易用性、广泛的浏览器支持和可靠的结果,在开发人员社区中得到了广泛采用。
使用ua-parser-js,您可以轻松解析用户代理字符串并获取有关用户的浏览器、操作系统、设备等的精确信息。该库提供了一个简单直观的 api,可以轻松集成到您的 web 项目中。
在下面的章节中,我们将了解 ua-parser-js 库,包括它的重要功能、安装方法和使用示例。我们还将讨论其最近的许可变更,这些变更在开发者社区中引发了争论。
ua-parser-js 安装和设置
可以使用多种方法安装 ua-parser-js 库,具体取决于您的开发环境和偏好。 ua-parser-js 压缩后的大小约为 18kb,gzip 后的大小约为 7.9kb,可以轻松集成到客户端(浏览器)和服务器端(node.js)环境中。
要在 html 文件中使用 ua-parser-js,您只需将库脚本包含在 html 文件中即可:
var parser = new uaparser();
下载缩小后的 javascript 文件,并将其包含在与 html 文件相同的目录级别中。如果您在 node.js 环境中使用 ua-parser-js,则可以使用 npm 安装它:
npm install ua-parser-js
然后,在您的 node.js 脚本中,您可以需要该库:
const uaparser = require('ua-parser-js');
对于 typescript 项目,您可以使用 npm 安装库及其类型定义:
npm install --save ua-parser-js @types/ua-parser-js
然后,在您的 .ts 文件中,您可以导入该库:
import { uaparser } from "ua-parser-js"; const parser = new uaparser()
用法和示例
ua-parser-js 库提供了一个简单的 api,用于解析用户代理字符串并访问解析的数据。
要解析用户代理字符串,您可以创建 uaparser 对象的实例并使用用户代理字符串调用 setua 方法:
const parser = new uaparser(); parser.setua('mozilla/5.0 (windows nt 10.0; win64; x64) applewebkit/537.36 (khtml, like gecko) chrome/93.0.4577.82 safari/537.36');
解析用户代理字符串后,您可以使用 uaparser 对象提供的可用方法访问解析的数据:
const result = parser.getresult(); console.log(result.browser); // {name: "chrome", version: "93.0.4577.82", major: "93"} console.log(result.os); // {name: "windows", version: "10"} console.log(result.device); // {vendor: undefined, model: undefined, type: undefined}
getresult 方法返回一个包含解析数据的对象,包括有关浏览器、操作系统、设备、cpu 和引擎的信息。
使用扩展
ua-parser-js 还允许您通过提供自定义正则表达式和解析规则来扩展其解析功能。创建 uaparser 对象的新实例时,您可以传递扩展数组:
const myExtensions = [ [/(myapp)\/([\w\.]+)/i, [UAParser.BROWSER.NAME, UAParser.BROWSER.VERSION]], ]; const parser = new UAParser(navigator.userAgent, myExtensions);
通过这些功能和示例,您应该很好地了解如何在 web 开发项目中安装、设置和使用 ua-parser-js。在下一节中,我们将探讨最近围绕 ua-parser-js 的许可变更及其对开发人员和开源社区的影响。
ua-parser-js 许可证变更
最近,ua-parser-js 经历了一次重大的许可证变更,引发了开发者社区的讨论。在更改之前,ua-parser-js 最初是在 mit 许可证下分发的,该许可证以其宽松的性质而闻名。该许可证允许开发人员以最小的限制使用、修改和分发该库,使其成为开源和商业项目的流行选择。
ua-parser-js 越来越受欢迎,有超过 2,240 个依赖项目,下载量超过 1230 万次。这种增长导致了维护需求的增加以及对更可持续发展模式的需求。新的许可模式旨在产生收入以支持持续的维护和开发工作。
随着最近发布的 2.0 版本,ua-parser-js 采用了双重许可模式:免费开源版本的 agplv3(gnu affero 通用公共许可证版本 3)和商业用途的专有 pro 许可证。这一变化导致开发人员在项目中使用和分发 ua-parser-js 的方式发生了重大转变。
双重许可模式试图在维护开源库和从可能需要额外功能或支持的商业用户中获利之间取得中间立场。目前,商业项目面临着一个决定——要么遵守 agplv3 许可条款(可能要求他们发布自己的源代码),要么购买 pro 许可。 pro 许可证定价从个人使用 12 美元起,企业使用最高 500 美元。这种模型通常被称为“开放核心”,已被开源生态系统中的其他项目采用,例如 sidekiq、mastodon、nextcloud 等。
有人谈论麻省理工学院许可版本的潜在分支或替代库的开发。例如,node.js tsc 成员 matteo collina 已经创建了一个名为 my-ua-parser 的分支来维护 mit 许可的版本。
在经历这一转变时,了解这些变化并考虑它们可能如何影响您的项目非常重要。在下一节中,我们将探讨一些在您自己的工作中处理此许可证更改的策略。
作为开发人员应对许可证变更
在决定使用哪个许可证时,您需要考虑项目的性质和要求,重新评估其依赖性,并做出明智的决策,以避免许可证变更带来的挑战。
如果您的项目已经使用兼容的开源许可证,那么 agplv3 版本可能适合。这意味着如果您将整个应用程序的源代码分发或作为网络服务运行,您将可以使用它。但是,请记住,使用 agpl 版本可能会限制其他不遵守 agpl 条款的人对您的项目的采用。
但是如果您正在开发专有软件或无法遵守 agpl 条款,您应该考虑购买 pro 许可证;评估 pro 许可证的成本是否与您需要的 ua-parser-js 的优点和功能相匹配。或者,您可以继续使用 ua-parser-js 的 v1.x 分支或分支,该分支仍受 mit 许可。但您应该注意,此版本将来可能会收到有限的更新。
结论
多年来,ua-parser-js 一直被视为 web 开发人员的宝贵工具。它能够准确解析用户代理字符串并提供有关浏览器、操作系统和设备的详细信息,这使其成为我们许多人必不可少的库。
从mit许可证切换到双agplv3+pro模式无疑在开发者社区引起了轰动。我们目睹了对此的各种反应;一些社区成员表示理解,而另一些则表示担忧和反对。对于某些人来说,这意味着调整他们的项目以符合 agplv3 许可证,而对于其他人来说,这可能涉及购买 pro 许可证或寻找替代解决方案。
作为开源软件的用户,我们需要为此类变化做好准备,并在必要时制定适应策略。
终于介绍完啦!小伙伴们,这篇关于《用户代理检测和 ua-parser-js 许可证更改》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

- 上一篇
- shadcn-ui/ui 代码库分析:shadcn-ui CLI 是如何工作的? - 第1部分

- 下一篇
- go 中反转链表
-
- 文章 · 前端 | 2分钟前 |
- Vue.js异步操作处理技巧与实战案例
- 249浏览 收藏
-
- 文章 · 前端 | 9分钟前 | 格式化日期 Date对象 天数差 UTC时间 Mongoosetimestamps
- JavaScript获取当前日期时间的实用攻略
- 229浏览 收藏
-
- 文章 · 前端 | 23分钟前 |
- JavaScript检测内存泄漏的实用技巧
- 429浏览 收藏
-
- 文章 · 前端 | 45分钟前 |
- JavaScript本地存储(localStorage)实战攻略
- 474浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- HTML链接点击后颜色设置技巧
- 316浏览 收藏
-
- 文章 · 前端 | 11小时前 | JavaScript 错误处理 性能优化 动态加载 脚本加载顺序
- JavaScript动态加载JS文件的实用技巧
- 376浏览 收藏
-
- 文章 · 前端 | 11小时前 |
- JavaScript自定义元素及实现方法详解
- 253浏览 收藏
-
- 文章 · 前端 | 11小时前 | 网页加载速度 JavaScript压缩 UglifyJS Terser 手动优化
- JavaScript代码压缩技巧与实现攻略
- 495浏览 收藏
-
- 文章 · 前端 | 11小时前 |
- Array.from在JavaScript中的妙用与应用
- 192浏览 收藏
-
- 文章 · 前端 | 11小时前 |
- JavaScript防抖与节流实用技巧
- 308浏览 收藏
-
- 文章 · 前端 | 12小时前 | 表单数据 document.getElementById document.querySelector FormData elements属性
- JavaScript获取表单数据的实用技巧
- 212浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- PPTFake答辩PPT生成器
- PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
- 3次使用
-
- Lovart
- SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
- 3次使用
-
- 美图AI抠图
- 美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
- 26次使用
-
- PetGPT
- SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
- 24次使用
-
- 可图AI图片生成
- 探索快手旗下可灵AI2.0发布的可图AI2.0图像生成大模型,体验从文本生成图像、图像编辑到风格转绘的全链路创作。了解其技术突破、功能创新及在广告、影视、非遗等领域的应用,领先于Midjourney、DALL-E等竞品。
- 50次使用
-
- 优化用户界面体验的秘密武器:CSS开发项目经验大揭秘
- 2023-11-03 501浏览
-
- 使用微信小程序实现图片轮播特效
- 2023-11-21 501浏览
-
- 解析sessionStorage的存储能力与限制
- 2024-01-11 501浏览
-
- 探索冒泡活动对于团队合作的推动力
- 2024-01-13 501浏览
-
- UI设计中为何选择绝对定位的智慧之道
- 2024-02-03 501浏览