通过这个技术,浏览器可以运行Node.js、Rust、Python、PHP、C++、Java代码了!

news2025/1/16 18:26:55

近日,WebContainers 发布重要更新,WASI(WebAssembly 系统接口)已全面集成到 WebContainers 中。这是一个重要里程碑,它扩大了可以使用浏览器执行的操作,是 Web 开发的全新范例,允许运行大量原生应用,而无需考虑多种不同的架构。

WebContainers 是 StackBlitz 推出一种基于容器技术的 Web 应用环境,它提供了一个隔离环境来执行Web应用。WebContainers 也是第一个基于 WebAssembly 的系统,可以安全地在浏览器中启动 Node.js 环境。可以在 Stackblitz 的官网(https://stackblitz.com/)在线体验 webContainers 技术,官网已经初始提供了多种开发环境:

近日,WebContainers 发布重要更新,WASI(WebAssembly 系统接口)已全面集成到 WebContainers 中。这是一个重要里程碑,它扩大了可以使用浏览器执行的操作,是 Web 开发的全新范例,允许运行大量原生应用,而无需考虑多种不同的架构。

这也意味着,像使用 Rust、Python、PHP、C++、C 等语言编写的项目都可以在浏览器中运行了!

什么是 WASI?

多年来,JavaScript 是 Web 浏览器原生支持的唯一编程语言。然而,随着 Web 的不断发展,对紧凑、安全和高效执行的代码的需求不断增长。为了解决这个问题,Mozilla 在 2015 年透露,他们正在与谷歌、微软和苹果的工程师合作开发一种新标准,称为 WebAssembly,简称 Wasm。WebAssembly 是一种低级、类似汇编的语言,独立于任何特定平台运行。它使用压缩的二进制格式,旨在安全、快速地运行,提供接近本地执行速度的性能。此外,它还可以作为编译在 Web 上运行的代码的目标。

WebAssembly 用作编译目标,其中原生代码(例如 Rust、C++ 或 Golang)被编译到 WebAssembly。最初,它是为了在Web上运行 C++ 或 Rust 等语言而创建的。然而,现在它的应用范围已经扩大了。WebAssembly 支持多种编程语言,并且不仅限于 Web 浏览器。

现在,每个 WebAssembly 模块都在一个沙盒环境中运行,没有访问系统功能(例如文件和文件系统或网络)的权限。 这意味着 WebAssembly 的功能受到限制,必须通过JavaScript提供所有外部功能。

这就是 WASI 的用武之地。WASI 表示 WebAssembly 系统接口,充当一个桥梁,提供标准化接口,允许 WebAssembly 代码安全地与文件系统、网络、生成随机数等系统接口交互,而无需要通过JavaScript注入这些功能。这扩展了 WebAssembly 的功能,使我们能够使用任何编译为WebAssembly 的语言构建应用,并在任何可用运行时的地方运行它们,包括 WebContainers!

WASI将以多种颠覆性的方式影响你:

  • 速度和安全性:两者兼得。应用在保持安全沙盒环境的同时,以接近本地速度运行。
  • 可移植性:编译一次,到处运行!将本机代码编译为 WebAssembly,并在Web或其他地方运行它。
  • 多语言支持:许多编程语言如 C、C++、Rust 等都可以编译成WebAssembly 并使用 WASI 接口。这意味着可以使用其他语言编写系统级别的代码,而不只是Web所使用的JavaScript,从而提供更多的选项和灵活性。

实现以前不可能的事

WebAssembly 运行时

WASI的集成使得在WebContainers中可以使用wasm命令从终端执行 WebAssembly 或 WASI 编译的模块。这意味着可以将代码编译为WASI,将其上传到项目中,然后通过新的wasm命令运行它。这样就可以在终端上直接运行 WebAssembly 模块,无需使用复杂的工具或设置。

Python 支持

作为对可能性的示范,目前引入了对 Python 在 WebContainers 中的实验性支持。考虑到 Python 作为第三种最常用的编程语言,在浏览器的原生环境中一直缺失,这一点尤为重要。由于需要外部服务器进行执行,Python 的功能通常是分割的,导致开发体验不连贯。但现在不同了。随着 WASI 与 WebContainers 的集成,服务器和浏览器的领域进一步融合,为浏览器内开发开辟了新时代的道路。

重要的是,随着WASI不断演进和扩展其功能集,它将直接影响 WebContainers 中 Python 的功能。注意,这种Python的集成目前仍然处于实验阶段,这意味着它目前仅限于 Python 语言的核心功能。目前还未推出对 pip 的支持,即 Python 的软件包管理器,这意味着暂时还无法安装额外的 Python 软件包。可以编写、编辑和执行依赖于内置 Python 模块和功能的Python脚本,但对于依赖于外部库的更复杂项目则需要再等待一段时间。

原生 CLI 工具

除此之外,还扩展了 shell 的功能,添加了对jq的支持,这是一个本地命令行JSON处理器,可以轻松地切片、过滤、映射和转换结构化数据。可以在任何项目中从shell中使用它。

展望未来

虽然这些发展令人兴奋,但这只是个开始。WASI 仍在标准化的过程中,随着它的成熟,它将在 WebContainers  中释放更多的功能。目前正在开发一些令人兴奋的新功能,包括WebAssembly线程或WebAssembly垃圾回收等。StackBlitz 的野心是为其他流行语言添加实验性支持,特别是对 Ruby 和 PHP 的实验性支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1107734.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java封装:面向对象的三大特性之一

👑专栏内容:Java⛪个人主页:子夜的星的主页💕座右铭:前路未远,步履不停 目录 一、封装的概念二、访问修饰限定符三、包1、包的概念2、导入包中的类3、常见的包 嗨!前面我们简单的认识了一下什么…

vite+vue3.0 + TypeScript+element-plus环境搭建

1、环境要求:node版本16以上 2、搭建vite项目 npm create vitelatest cmd运行下面命令 cd vite-project npm install npm run dev 谷歌浏览器访问http://127.0.0.1:5173/ 查看效果 3、安装element-plus组件 npm运行以下命令进行安装element-plus npm install elem…

汽车屏类产品(二):360全景环视(SVC)、多分割显示、行车记录

前言 随着新能源汽车的快速发展,带动了车载器件的大发展,大的比如域控,小的创新更是不断涌现。而车载显示屏可以说是一大类产品,产品形态也是愈发多样化,比如:仪表cluster、中控IVI、副驾屏、行车记录仪、流媒体后视镜、透明A柱屏、方向盘屏(替代方向盘按键)、门饰板显…

基因组的Phasing原理

1.Phasing的概念 Phasing,或者说Genotype Phasing,它的中文名有很多:基因定相、基因分型、单倍体分型、单倍体构建等在不同的语境下都有人说过。但不管如何,所谓Phasing就是要把一个二倍体(甚至是多倍体)基…

Vue 网络处理 - axios 异步请求的使用,请求响应拦截器(最佳实践)

目录 一、axiox 1.1、axios 简介 1.2、axios 基本使用 1.2.1、下载核心 js 文件. 1.2.2、发送 GET 异步请求 1.2.3、发送 POST 异步请求 1.2.4、发送 GET、POST 请求最佳实践 1.3、请求响应拦截器 1.3.1、拦截器解释 1.3.2、请求拦截器的使用 1.3.3、响应拦截器的使…

配电房智能化改造在加油站等的应用

随着科技的发展和智能化趋势的推进,对加油站配电房进行智能化改造成为了一个必然的选择。智能化改造不仅可以提高加油站的工作效率,减少事故发生率,还可以实现能源的合理利用,提高经济效益。 力安科技加油站智能化改造升级是一种高…

深度学习——卷积神经网络(CNN)基础三

深度学习——卷积神经网络(CNN)基础三 文章目录 前言五、汇聚层(池化层)5.1. 最大池化和平均池化5.2. 填充和步幅5.3. 多个通道5.3. 小结 六、卷积神经网络(LeNet)6.1. LeNet6.2. 模型训练6.3. 小结 总结 前…

Centos7 安装 MySQL5.7 步骤

Centos7 安装 MySQL5.7 步骤 前言:一 .使用yum源方式安装1、卸载系统自带 mariadb查看并卸载系统自带的 Mariadb 2、下载并安装MySQL官方的 Yum2.1 下载mysql的yum源配置2.2 安装mysql的yum源2.3 使用yum方式安装mysql2.3.1 安装过程中报错解决问题描述解决方案 3、…

JTS-通过Coordinate点截断几何Geometry

背景 通过一堆点,线上的点或者靠近线的点,来截取线段,将线段截取成多段 代码片段 /*** 通过点截取线,点可以是线上的形状点也可以是靠近线的点** 线 ------------------------------------------* 点 . . . …

YOLO目标检测——复杂场景人员数据集【含对应voc、coco和yolo三种格式标签】

实际项目应用:安防监控、人群管理、自动驾驶、城市规划、人机交互等等数据集说明:YOLO目标检测数据集,真实场景的高质量图片数据,数据场景丰富。使用lableimg标注软件标注,标注框质量高,含voc(xml)、coco(j…

C++模版初阶讲解

今日为大家分享C的模版,这里先把模版的初阶讲解一下,以后再讲解模版进阶! 前言:模版的引入 在我们进行学习的编程中,常常会有许多函数的功能相同,有些不同点可能就是其中的数据类型不同!如果我…

Jmeter连接Mysql数据库

一.下载mysql数据驱动 https://dev.mysql.com/downloads/connector/j/ 二、在Jmeter测试计划中添加驱动包 三、jmeter添加配置元件:JDBC Connection Configuration 四、Jmeter发送JDBC请求 五、提取mysql查询结果

工业交换机的应用场景

在选择工业交换机的时候,很多人会疑惑自己的场景是否适用工业交换机,工业交换机广泛应用于以下场景,大家可以参考了解 1. 工业自动化:工业交换机用于连接各种工业设备,如PLC(可编程逻辑控制器)、…

【探索C++】三大特性以及类和对象(包括类的特殊函数成员)

(꒪ꇴ꒪ ),Hello我是祐言QAQ我的博客主页:C/C语言,数据结构,Linux基础,ARM开发板,网络编程等领域UP🌍快上🚘,一起学习,让我们成为一个强大的攻城狮&#xff0…

遇到的问题总结

1、在实验室服务器里运行新项目的时候遇到 conda activate pytorch3_7(我的环境名字) conda install -c anaconda tensorboard (失败 一直堵在"Solving environment" ) pip install tensorboard

VS使用Visual Assist添加代码说明信息

写代码时,我们一般需要在代码的最前面添加一些说明信息,作者的联系方式等等。一些高级的 IDE 工具提供修改代码模板的功能,这样就能够在创建新代码时自动加上版权信息。Visual Studio 虽然没有提供这样的操作界面,但是我们可以通过…

Cron表达式每周三周五18点执行

Cron表达式每周三周五18点执行 0 0 18 ? * WED,FRI验证正确性:

C# Winform编程(5)菜单栏和工具栏

菜单和菜单组件 添加菜单编辑菜单菜单栏和工具栏 添加菜单 将MenuStrip控件拖拽到Form窗体顶部添加菜单 编辑菜单 添加菜单项,编辑菜单属性等功能。 右键单击已添加的菜单项可以弹出右键菜单: 可以设置菜单图标,使能菜单,显示…

[Python中常用的回归模型算法大全:从线性回归到XGBoost]

文章目录 概要保序回归:理论与实践多项式回归:探索数据曲线关系多输出回归的示例 概要 在数据科学和机器学习领域,回归分析是一项关键任务,用于预测连续型变量的数值。除了传统的线性回归模型外,Python提供了丰富多样…

每周电子W4——电路与电路模型

文章目录 每周电子W4——电路与电路模型电路电路模型电流和电压的参考方向电流的参考方向电压的参考方向 电功率 每周电子W4——电路与电路模型 电路 实际电路:由电工设备和电气器件按预期目的连接构成的电流的通路。 为完成某种预期的目的而设计、安装、运行的&a…