dotnet-wasi-sdk

dotnet-wasi-sdk

实验性.NET Core WASI开发工具包,构建WebAssembly应用

dotnet-wasi-sdk是一个实验性工具包,用于将.NET Core项目构建为WASI兼容的WebAssembly文件。它包含Wasi.Sdk用于生成.wasm文件,Wasi.AspNetCore.BundledFiles用于静态文件打包,以及Wasi.AspNetCore.Server.Native用于WASI网络API支持。该SDK支持开发控制台和Web应用,可在WASI环境或自定义主机中运行。目前已被.NET SDK的wasi-experimental工作负载取代,仅供对比参考。

WASI SDK.NET CoreWebAssemblyASP.NET Core实验性项目Github开源项目

已弃用

这个实验性的 SDK 现已被 .NET SDK 的 wasi-experimental 工作负载所取代(该工作负载本身仍处于实验阶段)。请参阅 https://github.com/dotnet/runtime/blob/main/src/mono/wasi/README.md

以下内容仅供比较参考。请将您的实验迁移到使用 wasi-experimental,而不是本仓库中的包。

.NET Core 的实验性 WASI SDK

Wasi.Sdk 是一个实验性包,可以将 .NET Core 项目(包括完整的 ASP.NET Core 应用程序)构建成独立的符合 WASI 标准的 .wasm 文件。这些文件可以在标准 WASI 环境或自定义 WASI 类主机中运行。

使用方法:控制台应用程序

dotnet new console -o MyFirstWasiApp
cd MyFirstWasiApp
dotnet add package Wasi.Sdk --prerelease
dotnet build

从构建输出中可以看到,这会生成 bin/Debug/net7.0/MyFirstWasiApp.wasm

要运行它,请:

  • 确保已安装 wasmtime 并将其添加到系统 PATH
  • 通过 dotnet run 运行您的应用程序,或者如果您使用 Visual Studio,请按 Ctrl+F5

或者,您可以在命令行中手动调用 wasmtimewasmer 等运行器。例如:

  • 对于 wasmtime,运行 wasmtime bin/Debug/net7.0/MyFirstWasiApp.wasm
  • 对于 wasmer,运行 wasmer bin/Debug/net7.0/MyFirstWasiApp.wasm

其他 WASI 主机的使用方式类似。

使用方法:ASP.NET Core 应用程序

dotnet new web -o MyWebApp
cd MyWebApp
dotnet add package Wasi.Sdk --prerelease
dotnet add package Wasi.AspNetCore.Server.Native --prerelease

然后:

  • 在 Visual Studio 或 VS Code 等 IDE 中打开您的新项目

  • 打开 Program.cs 并将 var builder = WebApplication.CreateBuilder(args) 这行改为:

    var builder = WebApplication.CreateBuilder(args).UseWasiConnectionListener();
  • 打开 Properties/launchSettings.json 并编辑 applicationUrl 值,使其只包含一个 HTTP 监听器,例如:

    "applicationUrl": "http://localhost:8080"
  • 打开您的 .csproj 文件(例如,在 VS 中双击项目名称),在 <PropertyGroup> 内添加以下内容:

    <WasiRunnerArgs>--tcplisten localhost:8080 --env ASPNETCORE_URLS=http://localhost:8080</WasiRunnerArgs>

    请将 8080 替换为 Properties\launchSettings.json 中找到的端口号。

就是这样!现在您可以通过 dotnet run 运行它(或在 VS 中使用 Ctrl+F5)

可选:要添加对将 wwwroot 文件打包到 .wasm 文件中并提供服务的支持:

  • 添加 NuGet 包 Wasi.AspNetCore.BundledFiles

  • Program.cs 中,将 app.UseStaticFiles(); 替换为 app.UseBundledStaticFiles();

  • 在您的 .csproj 文件中添加:

    <ItemGroup> <WasmBundleFiles Include="wwwroot\**" /> </ItemGroup>

本仓库包含的内容

  • Wasi.Sdk - 一个使您的构建生成符合 WASI 标准的 .wasm 文件的包。它的工作原理是:
    • 下载 WASI SDK(如果您还没有)
    • 当您的常规 .NET 构建完成后,它会将生成的程序集以及预编译为 WebAssembly 的 .NET 运行时一起使用 WASI SDK 打包成一个单独的 .wasm 文件。您可以选择在编译中包含其他原生源文件,如 .c 文件。
  • Wasi.AspNetCore.BundledFiles - 提供 UseBundledStaticFiles,作为 UseStaticFiles 的替代方案,用于提供打包到 .wasm 文件中的静态文件。这允许您在 wwwroot 或其他地方有文件的情况下实现单文件部署。
  • Wasi.AspNetCore.Server.Native - 一种在 WASI 的 TCP 级标准网络 API(例如 sock_accept)上运行 ASP.NET Core 的方法。这些标准相当新,目前仅在 Wasmtime 中受支持,其他 WASI 主机不支持。

... 以及更多

从源代码构建此仓库

首先,构建运行时。这可能需要相当长的时间。

  • git submodule update --init --recursive
  • 使用 Linux 或 WSL 执行以下步骤:
    • sudo apt-get install build-essential cmake ninja-build python python3 zlib1g-dev
  • cd modules/runtime/src/mono/wasm
    • make provision-wasm(大约需要 2 分钟)
    • make build-all(需要 10-15 分钟)
      • 如果出现关于 setlocale: LC_ALL: cannot change locale 的错误,请运行 sudo apt install language-pack-en。这只会在非常基础的机器上发生。
  • cd ../wasi
    • make(需要几分钟 - 会有很多类似 "System is unknown to cmake" 的警告,这是正常的)

现在您可以构建此仓库中的包和示例:

  • 先决条件
    • .NET 7(dotnet --version 应返回 7.0.100-preview.4 或更高版本)
    • Rust 和 wasm32-unknown-unknown 目标(技术上只有 CustomHost 包需要)
  • 只需对任何示例或 src 项目使用 dotnet builddotnet run,或在 VS 中打开解决方案并对任何示例项目使用 Ctrl+F5

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多