gpt4 book ai didi

C# 上传前过滤文件扩展名

转载 作者:行者123 更新时间:2023-12-02 02:45:27 25 4
gpt4 key购买 nike

以前我使用PHP。然后我得到了一个基于 C# 的项目,但我不知道该怎么做。即使我尝试打印一些东西,但总是出错。

下面是(我想,因为我在Controller目录下找到了这个文件)上传文件 Controller ,我想限制为只能上传图片。有人可以帮忙吗?

public IActionResult UploadFile ([FromForm] IFormFile file, [FromForm] string fileName) {
return Ok (new {
id = _fileService.UploadFile (fileName, file),
fileName = file.FileName,
fileSize = file.Length,
fileType = file.ContentType,
file = file
});
}

最佳答案

(仅供引用,在您进行任何更改之前,我会确保您所使用的代码已被验证可以正常工作。)

如果您尝试限制可以上传的文件类型,则应该能够检查文件类型(内容类型)或扩展名。

ContentType 应该类似于“image/png”或“image/jpeg”。您可以在线找到图像类型的列表,我发现这个答案有很多常见的:https://stackoverflow.com/a/14587821/13734398

要检查扩展名,我相信您可以使用 Path.GetExtension 来解析文件名。 :

var extension = Path.GetExtension(file.FileName);

(路径来自 System.IO 命名空间。使用 System.IO.Path... 或将 using System.IO; 添加到 C# 的顶部文件)

然后您可以检查扩展名,例如“.png”或“.jpeg”。

客户端检查

哦,你的问题提到了“上传之前”。从技术上讲,此时文件已经上传。如果您试图限制上传的内容,您可以在上传表单中添加一些客户端检查。请注意,它并不是万无一失的,您仍然需要像我上面提到的那样检查服务器端。

其他建议

就我个人而言,我建议也稍微重构一下您的代码。这是我想要的样子:

public IActionResult UploadFile ([FromForm] IFormFile file, [FromForm] string fileName)
{
var fileId = _fileService.UploadFile(fileName, file);

return Ok (new {
id = fileId,
fileName = file.FileName,
fileSize = file.Length,
fileType = file.ContentType,
// Removing this from the Response.
// Probably don't need to send the file back.
// file = file
});
}

我认为,如果 UploadFile() 出现问题,这会给您更好的错误消息。 (对我来说)它也更清楚事情的顺序/顺序。

关于C# 上传前过滤文件扩展名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62880548/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com