Windows Server 2022 + IIS + ASP.NET Core 完整可上传大文件的 报错的问题

核心异常:

System.UnauthorizedAccessException: Access to the path 'C:\Windows\TEMP\ASPNETCORE_*.tmp' is denied.

C:\inetpub\wwwroot\ePortal\ <- 应用根目录

│ ePortalPlus.exe

│ web.config

└─ logs

stdout_YYYYMMDD_HHMMSS_xxx.log

注意事项

默认 stdoutLogEnabled="false",日志不会生成,需要临时设置为 true。

确保 IIS AppPool 用户有写权限:

右键 logs 文件夹 → 属性 → 安全 → 给应用池用户(如 IIS AppPool\ePortalPlus)写权限。

日志会一直生成,调试完成后建议关闭:

stdoutLogEnabled="false"

🔹 原因分析

ASP.NET Core 上传文件时,默认会在 临时目录 (Path.GetTempPath(),Windows 下通常是 C:\Windows\TEMP) 创建 临时缓存文件。

你当前的 应用池用户(IIS AppPool 用户)没有 写入 C:\Windows\TEMP 的权限,导致创建临时文件失败。

这发生在:

Microsoft.AspNetCore.WebUtilities.FileBufferingReadStream.CreateTempFile()

也就是 ASP.NET Core 在读取上传的 IFormFile 时尝试写临时文件失败。

🔹 解决办法

方案 1:给应用池用户写权限(推荐)

找到 IIS 应用池对应的用户,例如 IIS AppPool\ePortalPlus。

给 C:\Windows\TEMP 文件夹 完全控制或修改权限:

右键 → 属性 → 安全 → 编辑 → 添加 IIS AppPool\ePortalPlus → 允许"修改"和"写入"。

重启 IIS 网站,上传就可以正常创建临时文件。

方案 2:修改 ASP.NET Core 临时目录

可以在 Program.cs 或 Startup.cs 设置 TempDirectory,改用应用目录下的临时文件夹:

var tempPath = Path.Combine(AppContext.BaseDirectory, "Temp");

Directory.CreateDirectory(tempPath);

Environment.SetEnvironmentVariable("TMP", tempPath);

Environment.SetEnvironmentVariable("TEMP", tempPath);

优点:不改系统 C:\Windows\TEMP 权限,更安全。

需要确保应用池用户有该目录写权限。

方案 3:直接读取到内存(小文件可行)

如果文件较小,可以完全用内存,不写临时文件:

using var ms = new MemoryStream();

await fileUpload.CopyToAsync(ms);

var originalBytes = ms.ToArray();

⚠️ 大文件(几十 MB 以上)可能导致内存占用过高。

🔹 总结

你的 500 错误不是数据库或代码逻辑问题,而是 IIS 应用池用户没有写 C:\Windows\TEMP 权限。

✅ 推荐做法:

给应用池用户写权限,或

改用应用目录下临时目录,并确保权限。

相关推荐
代码匠心14 分钟前
从零开始学Flink:状态管理与容错机制
java·大数据·后端·flink·大数据处理
分享牛15 分钟前
LangChain4j从入门到精通-11-结构化输出
后端·python·flask
姚华军1 小时前
在本地(Windows环境)部署LLaMa-Factory,进行模型微调步骤!!!
windows·ai·llama·llama-factory
知识即是力量ol1 小时前
在客户端直接上传文件到OSS
java·后端·客户端·阿里云oss·客户端直传
闻哥1 小时前
深入理解 Spring @Conditional 注解:原理与实战
java·jvm·后端·python·spring
x***r1512 小时前
AntDM下载管理器安装步骤详解(附下载管理与断点续传教程)
windows
面对疾风叭!哈撒给2 小时前
Windows 系统安装 Mysql 8.0+
数据库·windows·mysql
qq_256247052 小时前
Google 账号防封全攻略:从避坑、保号到申诉解封
后端
MX_93593 小时前
使用Spring的BeanFactoryPostProcessor扩展点完成自定义注解扫描
java·后端·spring
弹简特3 小时前
【JavaEE05-后端部分】使用idea社区版从零开始创建第一个 SpringBoot 程序
java·spring boot·后端