IIS 部署 .NET 6 WebApi 实战指南(附优缺点分析)

IIS 部署 .NET 6 WebApi 实战指南(附优缺点分析)

在 .NET 开发体系里,IIS 一直是部署 WebApi 的主力工具。

很多人接口写得很熟练,但真正涉及部署时,却容易卡在环境、权限、证书这些细节上。

今天我们从 0 到 1,把 .NET 6 WebApi 部署到 IIS 上跑起来,同时聊聊它适合做什么、不适合做什么。


一、环境准备

部署前,先确认三件事:

1️⃣ 已安装 IIS

控制面板 → 启用或关闭 Windows 功能 → 勾选:

  • Internet Information Services
  • Web 管理工具
  • 万维网服务
  • 应用程序开发功能

安装完成后访问:

http://localhost

能看到默认页面说明成功。


2️⃣ 安装 .NET 6 Hosting Bundle

这是最关键的一步。

如果服务器没有安装对应版本的 Hosting Bundle,接口基本都会报:

HTTP Error 500.30 - ANCM In-Process Start Failure

下载地址(.NET 6):

https://dotnet.microsoft.com/en-us/download/dotnet/6.0https://dotnet.microsoft.com/en-us/download/dotnet/6.0


3️⃣ WebApi 已发布为 Release

在 Visual Studio 中:

右键项目 → 发布 → 文件夹 → 选择发布路径

发布完成后会得到:

  • xxx.dll
  • web.config
  • wwwroot

这就是 IIS 要指向的物理目录。


二、在 IIS 中创建站点

打开 IIS 管理器:

网站 → 右键 → 添加网站

配置如下:

  • 物理路径:选择刚才发布后的文件夹
  • 端口:例如 80(测试环境)
  • 应用程序池:默认即可(.NET Core 不依赖传统 CLR)

完成后访问:

http://localhost:80/swagger

如果能打开 Swagger 页面,说明部署成功。


三、常见问题排查

❌ 500.30 启动失败

大概率是没有安装 Hosting Bundle,或者版本不匹配。


❌ 403 无权限访问

给站点文件夹添加权限:

  • IIS_IUSRS
  • 或 Everyone(测试环境可用)

生产环境建议精细化控制权限。


❌ 端口冲突

执行:

netstat -ano

查看端口是否被占用。


四、IIS 部署 WebApi 的优势

在 Windows 服务器环境下,IIS 部署 WebApi 仍然是非常稳妥的方案。

1️⃣ 集成度高

与 Windows 深度整合,无需额外学习 Linux 运维体系。


2️⃣ 稳定成熟

应用程序池回收机制完善,长期运行稳定。


3️⃣ 权限体系清晰

基于 Windows 账户体系控制访问权限,安全性高。


4️⃣ 操作可视化

对不熟悉服务器命令行的人非常友好。


五、那 IIS 适合部署 Vue 吗?

结论:不太理想。

原因很简单。

Vue 属于单页应用(SPA),它需要:

  • URL Rewrite 重写规则
  • 处理 history 路由模式
  • 各种重定向配置
  • applicationHost.config 相关调整

如果不正确配置,刷新页面直接 404。

IIS 本质上更偏向传统 Web 服务,并不是为现代前端应用优化的服务器。

简单静态页面还可以,但复杂前端项目维护成本较高。

如果是前后端分离项目,通常会采用:

👉 IIS 负责 WebApi
👉 Nginx 负责前端静态资源与反向代理

这才是更主流的生产架构。


六、关于 HTTPS 的说明

本文演示采用的是 HTTP 测试部署方式。

但在生产环境中,必须启用 HTTPS。

尤其是涉及:

  • 登录
  • Token 传输
  • 用户数据
  • 支付接口

如果你有部署 HTTPS 的实际需求,可以在评论区留言。

我可以单独整理一期完整内容,包括:

  • SSL 证书类型说明
  • 免费证书申请流程
  • IIS 绑定证书步骤
  • 强制 HTTP 跳转 HTTPS
  • 常见证书报错排查
  • 多域名 / 泛域名场景处理

当系统真正对外开放时:

HTTP 只是开发阶段的选择,HTTPS 才是上线的入场券。

Read more

WebForms SortedList 深入解析

WebForms SortedList 深入解析 引言 在Web开发中,数据管理是至关重要的。ASP.NET WebForms框架为我们提供了丰富的控件和功能,其中SortedList控件是用于存储和排序数据的常用工具。本文将深入探讨WebForms中的SortedList控件,包括其基本用法、优缺点以及在实际应用中的注意事项。 SortedList控件概述 SortedList控件是ASP.NET WebForms中的一种数据绑定控件,它基于System.Collections.Specialized命名空间下的SortedList类。SortedList控件可以用来存储键值对,并按照键的顺序自动排序。 SortedList的主要特点: 1. 键值对存储:SortedList控件允许我们将数据以键值对的形式存储,其中键是唯一的,值可以是任何类型的数据。 2. 自动排序:SortedList控件会根据键的顺序自动排序,默认为升序。 3. 数据绑定:SortedList控件可以与数据源进行绑定,实现数据的动态更新。 4. 丰富的API:SortedList控件提供

trae整合figma的mcp实现前端代码自动生成

1.现在trae版本在3.0及以上版本。 2.trae账号是企业版。 3.打开设置,找到mcp 这里需要token,需要从figma账号里生成,网页登录figma账号,找到设置,打开后找到security,然后点击generate new token,token名称随便取,权限都钩上。然后生成一个token,把token放到mcp中即可。 4.使用mcp,切换到mcp模式,你也可以自己创建智能体使用 5.提问使用,可参考下面的提示词使用 注意:这里面的figma链接是mcp的链接,不是figma链接,一般需要你有原型的权限才能看到 我需要根据提供的Figma链接生成一个与设计稿高度一致的网页。请严格遵循以下详细要求:

实测GLM-4.6V-Flash-WEB的OCR能力:复杂界面表现如何

实测GLM-4.6V-Flash-WEB的OCR能力:复杂界面表现如何 你有没有遇到过这样的情况:一张Windows安装界面截图,用传统OCR工具能识别出“下一步”“修复计算机”几个字,但完全不知道哪个是主操作按钮、哪个是隐藏入口、齿轮图标代表什么——更别说判断“点击哪里能跳过联网步骤”了。这次我们不聊理论,直接上手实测智谱最新开源的 GLM-4.6V-Flash-WEB,在真实复杂系统界面中跑一遍它的OCR理解力:它到底能不能看懂按钮背后的意图?面对中英混排、图标+文字、模糊截图、多分辨率窗口,它的表现稳不稳?结果可能比你预想的更实在。 1. 测试准备:三类典型复杂界面样本 要验证一个视觉模型的真实OCR能力,不能只靠标准印刷体测试图。我们选了三类微PE团队日常高频接触、也是传统OCR最容易翻车的界面类型,全部来自真实系统环境截图(非合成图): 1.1 样本说明与采集方式 * 样本A:Windows 11 安装向导(中文版) 分辨率1920×1080,含动态阴影、半透明按钮、右下角电源图标、

绿联云NAS配置webdav

绿联云NAS配置webdav

前言         zotero使用webdav服务时使用绿联自带的webdav服务只能使用http协议,并且只能在局域网内传输,故而尝试自行配置,以期实现公网文献同步。 注:非专业,自己在配置的时候也是根据前人的分享实现的,可能有很多不准确的地方,请见谅。 1. 大致思路         购买域名(腾讯云)→配置DDNS-go(docker)→获取SSL证书(乐此加密)→配置natfrp(docker) ①域名:固定域名,后续内网穿透时可以使用自定义域名; ②DDNS-go:自动更新域名解析到公网IP; ③SSL证书:https协议需要; ④natfrp:内网穿透需要,这里使用的是Sakura Frp。 2.参考文献 (31 封私信 / 80 条消息) 绿联 NAS 域名直连 DDNS-Go+IPv6 内网穿透并开启 HTTPS - 知乎https://zhuanlan.zhihu.com/p/