1.简单介绍
Blazor应用可以部署到Internet Information Servers(简称IIS),也可以部署到nginx中。也可以以docker容器的形式来部署的或者部署到Cloud中(比如azure web app等)
这边尝试一下在nginx中部署一下Blazor Web Assembly Standalone app
2.具体说明
2.1 创建项目
在Visual Studio 2022中,以Blazor Web Assembly Standalone app为模板创建项目
2.2 发布项目
可以在Visual Studio 2022中进行发布,可以使用命令的方式来发布
2.2.1 VisualStudio发布
1) 右键点击项目,选择菜单项Publish
2) 点击Folder
3) 设定 Folder location,然后点击Publish进行发布
4) 发布结果如下图,
2.2.2 命令行发布
dotnet publish -c Release -o "blazorwasmartificats"
发布文件夹中的内容如下,
wwwroot文件夹下面的内容如下,
notes: .NET9中 对于静态的文件内容做了压缩(比如html, css, javascript),这样减少了网站访问时候所用的时间(文件更小)
2.3 配置nginx
修改一下nginx中的配置文件 nginx.conf
server {
listen 7527;
server_name localhost;
location /{
root D:\blazorwasmartificats\wwwroot;
index index.html index.htm;
try_files $uri $uri/ /index.html;
location /myblazorapp/_framework/ {
gzip_static on;
}
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
主要是设定一下nginx.conf配置文件中的 server_name, location, root以及其index
2.4 运行一下
在命令行中,输入start nginx.exe
如果nginx启动成功,则可以看到两个和nginx相关的进程,一个是工作进程,一个是主进程
可以使用Powershell命令查看一下 get-process | ?{$_.ProcessName -like '*nginx*'}
在命令行中,输入nginx -t,检测一下配置文件是否能正常运作
在浏览器中,打开网页http://localhost:7527,发现页面最后可以正常显示出来
note, 可以在nginx中进一步配置MIME types,certificats等
3.总结
本文简单记录了一下在nginx中部署Blazor Web Assembly Standalone app的操作过程。
如果哪里有错误的地方,麻烦告之,谢谢谢谢!