前端全栈之路Deno篇(三):一次性搞懂和学会用Deno 2.0 的权限系统详解和多种权限配置权限声明方式

本文涉及的产品
轻量应用服务器 2vCPU 4GiB,适用于搭建Web应用/小程序
轻量应用服务器 2vCPU 1GiB,适用于搭建电商独立站
轻量应用服务器 2vCPU 4GiB,适用于搭建容器环境
简介: 本文深入解析了 Deno 2.0 的权限系统,涵盖主包和第三方包的权限控制机制,探讨了通过命令行参数、权限 API 和配置文件等多种权限授予方式,并提供了代码示例和运行指导,帮助开发者有效管理权限,提升应用安全性。

本文将详细介绍 Deno 2.0 的权限系统,重点对比主包和第三方包的权限控制机制,分析不同的权限授予方式,并通过代码和配置文件演示如何有效管理这些权限。

前文提要:Deno2.0与Bun对比,谁更胜一筹?,介绍参考 带你掌握Deno2.0的安装到项目构建全流程
本文主要介绍其权限系统、也是与其它js运行时不一样的部分

一、Deno 权限系统概述

Deno 的权限系统旨在通过限制代码对系统资源的访问,确保开发者能够清楚地控制应用的行为并减少安全风险。Deno 使用了“显式权限”模型,默认情况下,所有对文件系统、网络和环境变量等关键资源的访问都被禁止,开发者需要通过命令行参数或特定 API 明确授予这些权限。

Deno 的主要权限包括:

  • 文件系统访问 (--allow-read, --allow-write)
  • 网络访问 (--allow-net)
  • 环境变量访问 (--allow-env)
  • 运行子进程 (--allow-run)
  • 高精度时间访问 (--allow-hrtime)

二、主包和第三方包权限控制对比

Deno 在权限管理上对主包(开发者编写的代码)和第三方包采用了相同的安全模型。无论是主包还是第三方包,Deno 都要求开发者通过显式授权来启用权限。这和其他运行时(比如 Node.js)不一样,在 Deno 中每个模块和依赖包默认都没有权限。

资源类型 主包权限控制方式 第三方包权限控制方式 说明
文件系统访问 显式通过命令行参数 显式通过命令行参数 开发者需授予同样的文件系统访问权限
网络访问 显式通过命令行参数 显式通过命令行参数 无区别对待,需要显式授权
环境变量访问 显式通过命令行参数 显式通过命令行参数 权限统一,需授权
子进程访问 显式通过命令行参数 显式通过命令行参数 主包和第三方包无差别

示例代码:

// 读取文件,需授予 --allow-read 权限
const fileContent = await Deno.readTextFile("./example.txt");
console.log(fileContent);

// 发起网络请求,需授予 --allow-net 权限
const response = await fetch("https://example.com");
const data = await response.text();
console.log(data);

运行命令:

deno run --allow-read --allow-net app.ts

在上述示例中,如果没有正确授予文件读取和网络访问权限,Deno 会报错提示权限不足。

三、多种权限授予方式对比

Deno 允许通过多种方式授予权限,这为开发者提供了灵活性,尤其是在不同场景下可以使用合适的权限管理策略。

1. 命令行参数方式

这是最常见的方式,开发者在运行 Deno 程序时通过命令行参数显式授予权限,例如 --allow-read--allow-net 等。

优点:

  • 简单直观
  • 适合开发阶段快速调试

缺点:

  • 需要开发者记住并维护命令行权限
  • 对复杂应用来说管理不便

2. 权限 API

Deno 提供了权限管理的 API,允许开发者在代码中动态检查和请求权限。API 的主要方法包括:

  • Deno.permissions.query()
  • Deno.permissions.request()
  • Deno.permissions.revoke()

示例代码:

const status = await Deno.permissions.query({
    name: "read" });
if (status.state !== "granted") {
   
    console.log("请求文件读取权限");
    const requestStatus = await Deno.permissions.request({
    name: "read" });
    if (requestStatus.state === "granted") {
   
        console.log("权限已授予");
    }
}

优点:

  • 更加细致的权限控制
  • 适合生产环境下动态管理权限

缺点:

  • 增加代码复杂度
  • 可能影响性能

3. 权限配置文件

Deno 2.0 引入了权限配置文件的机制,允许开发者提前定义权限配置并在运行时加载。这种方式适合复杂应用的权限管理。

示例配置文件 deno.json

{
   
  "permissions": {
   
    "read": ["./data"],
    "net": ["example.com"],
    "run": true
  }
}

运行命令:

deno run --config deno.json app.ts

优点:

  • 适合生产环境和复杂项目
  • 权限集中管理,维护方便

缺点:

  • 增加了配置的复杂性
  • 不适合快速调试场景

权限授予方式对比总结

授予方式 优点 缺点 适用场景
命令行参数 简单直观,快速调试 维护不便,复杂应用不适合 开发、快速调试
权限 API 动态控制,精细粒度 增加代码复杂性,可能影响性能 生产环境动态授权
权限配置文件 权限集中管理,适合复杂项目 配置复杂,调试不便 复杂应用,生产环境

四、触发权限的代码与运行示例

以下简单示例展示如何在不同场景下触发 Deno 的权限机制。该示例包括文件读取、网络请求和运行子进程。

代码示例:

// 尝试读取文件
try {
   
  const fileContent = await Deno.readTextFile("./secret.txt");
  console.log(fileContent);
} catch (error) {
   
  console.error("读取文件失败:", error);
}

// 尝试发起网络请求
try {
   
  const response = await fetch("https://deno.land");
  const text = await response.text();
  console.log(text);
} catch (error) {
   
  console.error("网络请求失败:", error);
}

// 尝试运行子进程
try {
   
  const process = Deno.run({
    cmd: ["echo", "Hello from Deno!"] });
  await process.status();
} catch (error) {
   
  console.error("运行子进程失败:", error);
}

运行命令:

deno run --allow-read --allow-net --allow-run example.ts

通过这段代码,开发者可以观察到在未授予相应权限时,Deno 会抛出错误,提示缺少必要的权限。

五、总结

Deno 2.0 的权限系统是其安全架构的核心,通过默认的权限隔离和显式的权限授予机制,为前端全栈开发者提供了更高的安全性和灵活性。在不同场景下,开发者可以根据需求选择命令行参数、权限 API 或配置文件等不同方式来授予和管理权限。通过合理利用这些机制,可以确保应用的安全性和稳定性。

相关文章
|
2月前
|
前端开发 JavaScript 安全
7.6K Star Shadcn Admin:颜值与实力并存的后台管理系统,前端开发者的新宠!
"基于 Shadcn UI 和 Vite 打造的现代化管理后台,开箱即用的响应式设计 + 无障碍访问,让后台开发从未如此优雅!" —— 来自 GitHub 7.6K 星认证
537 26
|
2月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
246 1
|
2月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
146 3
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
4月前
|
资源调度 JavaScript 前端开发
前端开发必备!Node.js 18.x LTS保姆级安装教程(附国内镜像源配置)
本文详细介绍了Node.js的安装与配置流程,涵盖环境准备、版本选择(推荐LTS版v18.x)、安装步骤(路径设置、组件选择)、环境验证(命令测试、镜像加速)及常见问题解决方法。同时推荐开发工具链,如VS Code、Yarn等,并提供常用全局包安装指南,帮助开发者快速搭建高效稳定的JavaScript开发环境。内容基于官方正版软件,确保合规性与安全性。
2653 23
|
5月前
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
231 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
5月前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
191 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
5月前
|
监控 前端开发 Java
构建高效Java后端与前端交互的定时任务调度系统
通过以上步骤,我们构建了一个高效的Java后端与前端交互的定时任务调度系统。该系统使用Spring Boot作为后端框架,Quartz作为任务调度器,并通过前端界面实现用户交互。此系统可以应用于各种需要定时任务调度的业务场景,如数据同步、报告生成和系统监控等。
143 9
|
7月前
|
人工智能 前端开发 小程序
2024年12月30日蜻蜓蜻蜓AI工具系统v1.0.0发布-优雅草科技本产品前端源代码已对外开源可免费商用-优雅草老八
2024年12月30日蜻蜓蜻蜓AI工具系统v1.0.0发布-优雅草科技本产品前端源代码已对外开源可免费商用-优雅草老八
253 31
2024年12月30日蜻蜓蜻蜓AI工具系统v1.0.0发布-优雅草科技本产品前端源代码已对外开源可免费商用-优雅草老八
|
6月前
|
缓存 前端开发 Android开发
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
300 12
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
|
6月前
|
Dart 前端开发 架构师
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
352 26

热门文章

最新文章