js保存文件到指定路径_ASP.NET Core 文件系统

静态文件 目录浏览 默认页面 MIME类型配置 实战文件服务器 

紧接上一讲 中间件 之后,今天来我们来讲一下关于 ASP.NET  Core 中静态文件服务。


什么是静态文件?

先看一下下面例子(在客户端浏览器中通过 url 路径访问了网站的一张图片):

b0239603a44fd6fdf045b252d785d70d.png

这样的图片就是一个静态文件

de2e638f00cdc977e6e8421d976cac63.png

  • 静态文件(staticfiles),其实就是指像 HTML、CSS、图片 和 JavaScript 之类固定的文件,是会被应用程序直接提供给客户端的资源。

  • 静态文件通常位于web root(内容根目录或Web根目录)文件夹下。有关 内容根目录 和 Web根目录 的信息在第一讲中介绍过。

    6286999a87dcc6ac18b777c10554b9f8.png

    •  Web根目录默认为的是 Contentroot 路径下的 wwwroot 文件夹。

    •  静态文件中间件将默认只读取 Web根目录和其子目录中的文件。

    •  对于 Razor (.cshtml) 文件,波浪号斜杠 ~/ 指向 webroot。 以 ~/ 开头的路径称为虚拟路径。

    • 内容根目录(Contentroot):是应用程序所用到的所有内容的根路径。WebHost.CreateDefaultBuilder() 中默认下把项目的当前目录设置为内容根目录,也就是指 web 的项目的文件夹,包括 bin 和 webroot 文件夹。

    • Web根目录(webroot):项目中用于存放类似于 CSS、JS、图片等公开、静态资源的目录。

  • 静态文件可以保存在 Web根目录(默认为wwwroot) 下的任意文件夹内,并通过相对根的路径来访问。例如当你通过 VisualStudio 创建一个默认的 Web应用程序(MVC)项目时,在 wwwroot 目录下会多出几个文件夹:css、images以及js。

    6c77032d78f9ba815d5e09db2e80229a.png

    通过下面的URL就能够直接访问 images 目录下的图片:
    http:///images/
    http://localhost:7819/images/banner1.svg

    92e92213b50bce9288b24c68b21ccafe.png


静态文件中间件

如上例子,为了能够使用静态文件的服务,必须配置中间件,把静态文件中间件加入到请求管道内。(默认创建的 MVC Web应用程序已经配置了)
静态文件中间件可通过下述方法来配置:在项目中增加 MicrosoftAspNetCore.StaticFiles 包依赖,然后从Startup.Configure 中调用 app.UseStaticFiles 扩展方法:

public void Configure(IApplicationBuilder app, IHostingEnvironment env){
    
app.UseStaticFiles();

上面我们通过一个简单的实例使用 app.UseStaticFiles() 来使用文件中间件,使得Web根目录下的所有静态文件直接发布出来。如果我们需要发布的静态文件存储在其他目录下呢?依旧是这个应用,现在我们将静态文件放在自定义文件夹 MyStaticFiles 内,并将以Web的形式发布出来,展示如何通过使用 UseStaticFiles将其他非wwwroot目录下的内容也向外提供服务。

7Vtdk5owFP01PnaHEEB9rPbroZ3pdDvT5ygR00ZCQyxuf31vIBHZ6K6tQN1ddpydcMNHcs89h9wbHeH5Zvdekmz9ScSUj3wv3o3wm5HvY8+D/9pwVxkCNK4MiWRxZfJqwy37TSsjstYti2neOFEJwRXLjBFVxqVIU7pUjROJlKJoXrsSPG5cl5GEOobbJeGu9RuL1bqyTvxxbf9AWbI2T0YomlY9C7L8kUixTc3zRj5elX9V94bYe5mR5WsSi+LAhN+O8FwKoarWZjenXLu26bZ3J3r345Y0Vedc4FcX/CJ8S+2Iy3GpO+sLGGKmm3BTxQj/Av4maaJ7Z0pk0OFBi9OVMk1p/KLbC6GU2JgDwlmSQrs6d/aLwv3A5a+NubzZbMU4nwsuJFhSkeqn5BlZsjT5WD0i8mrTF/OoAEwC7rfipS/XLI5pqociFFFkUc5EX5YJlqoyNMIZfMA1c+8mHIUwzTkco/oYPvp0qeYizZUkrHQnJbkqaK5HH0uRfSUyoXaqK5EqE8gIYJy5SBhw9Lzp7sBkkHlPxYYqeQenmN7QBIkl0WRSHRd1SCIbSOuDcPQjwwTDgmR/5zoSoGGC4Xhg4IsCo3SGOROdCpRGcBzB/ax4aQZH0FZsPAa/nrOZ2+PA+yeA3+uXGUZDAxoBcYB4GHUDePA44JxVfFRS/NjrIvon8DYAAz8g99cyQF4hB1HsIoqPoMfJgvLPImeKCX1/I0J/iWoHHEZe1CRxhBwSW98fQjq5HNFw0PYno+0hwv1pezRoe2vaHp4A/qq0fTwowZNRAjzpUQkmgxK0pgTjE8BflRJMByV4MkoQeNP+lMBWXgYpaEEKpieQvyopQMhBvCiKsvTkR1zPeSGhlaj9FA9CAeal7Wu14cYrVVZ4D9EHQF6Ct6h8KDUs1kzRWwBXP7OQJCtB3KYxjQ2ELXAO4Xv5WRg6pAuOcc5rAQE354bwUzCZl4aCrWzZNVDk9QfCGWnyUPhoofBxZF3bUeEDuQnup7tb8BtbvmOc5s+XRyiYNp0+H

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在ASP.NET Core上载文件,您可以按照以下步骤操作: 1. 在您的控制器方法使用`[HttpPost]`属性标记该方法。 2. 添加`[Request.Form.Files]`属性来接收提交的文件。 3. 使用`IFormFile`对象处理文件。您可以使用`CopyToAsync()`方法将文件复制到服务器文件系统。 以下是示例代码: ```csharp [HttpPost] public async Task<IActionResult> UploadFile([FromForm] List<IFormFile> files) { long size = files.Sum(f => f.Length); // 遍历上传的文件 foreach (var formFile in files) { if (formFile.Length > 0) { var filePath = Path.Combine(Directory.GetCurrentDirectory(), "wwwroot\\uploads", formFile.FileName); using (var stream = new FileStream(filePath, FileMode.Create)) { await formFile.CopyToAsync(stream); } } } return Ok(new { count = files.Count, size }); } ``` 在此示例,我们从`[HttpPost]`属性开始,该属性表示此方法应该响应HTTP POST请求。我们还使用`[FromForm]`属性将数据传递给`files`参数。 接下来,我们使用`Sum()`方法计算上传文件的大小。然后,我们使用`foreach`循环遍历上传的文件。如果文件大小大于零,则将文件保存服务器文件系统。 最后,我们使用`Ok()`方法返回HTTP 200 OK响应,并将上传文件的数量和大小作为JSON对象返回。 ### 回答2: ASP.NET Core 文件上传是指在开发ASP.NET Core应用程序,实现将文件从客户端上传到服务器的功能。ASP.NET Core 提供了丰富的工具和API来处理文件上传。 要实现文件上传功能,首先需要在前端添加一个文件选择的input元素,并将其设置为文件上传的类型。然后,当用户选择文件后,可以使用JavaScript将文件发送到后端。 在后端,可以使用ASP.NET Core的控制器来处理文件上传。可以使用HttpPost特性将方法定义为POST请求,并使用FromForm特性获取从前端发送的文件。 下一步是处理接收到的文件。可以使用IFormFile接口来操作上传的文件。可以通过Name属性获取文件的名称,并使用OpenReadStream方法获取文件的二进制流。 在处理文件之前,可以对文件进行一些验证和验证。例如,可以检查文件的大小、文件类型等。如果有验证错误,可以将错误信息返回给前端。 接下来,可以将接收到的文件保存服务器指定位置。可以使用File类的CopyToAsync方法将文件复制到指定路径。在保存文件之前,可以为文件生成一个唯一的文件名,以避免文件名冲突。 完成文件上传后,可以向前端发送响应,确认文件上传成功。可以返回一个包含文件信息的JSON对象,或者返回一个简单的成功消息。 综上所述,ASP.NET Core 文件上传可以通过前端的文件选择和JavaScript来实现文件上传功能,并使用ASP.NET Core的控制器来接收和处理上传的文件。可以对上传的文件进行验证和处理,并将其保存指定的位置。完成文件上传后,可以向前端发送响应以确认上传成功。 ### 回答3: ASP.NET Core 是一个开源、跨平台的框架,可以用来构建 Web 应用程序和服务。文件上传是 Web 开发常见的功能,ASP.NET Core 提供了方便的方式来处理文件上传。 要在 ASP.NET Core 实现文件上传,可以使用 Mvc 的 Controller 和 View。下面是一个简单的示例: 1. 在 Controller ,可以使用 [HttpPost] 特性来标记一个接受 Post 请求的方法。 2. 在这个方法,需要使用 [FromForm] 特性来接受从前端传来的文件。例如,可以在方法的参数定义一个 IFormFile 类型的参数来接收上传的文件。 3. 为了接受文件上传的表单,需要在 View 文件使用 form 标签,并设置 enctype="multipart/form-data" 属性来指示表单是用于文件上传。 4. 在表单,可以使用 input 标签的 type="file" 来创建一个文件选择框。用户选择文件后,就可以点击提交按钮将文件上传到服务器。 5. 在 Controller 的方法,可以处理接收到的文件。例如,可以使用 IFormFile 类型的参数的 OpenReadStream() 方法来获取文件的流,然后将文件保存服务器。 需要注意的是,文件上传涉及到服务器端的文件处理和安全问题。在实际应用,我们需要对文件类型、大小、保存路径等进行限制,以及对上传的文件进行合法性校验和防止文件上传漏洞攻击的处理。 总结来说,ASP.NET Core 提供了方便的方式来实现文件上传功能。通过使用 Controller 和 View,可以很容易地将文件从前端上传到服务器,并对文件进行处理和保存。同,为了确保安全和合法性,我们需要对文件进行校验和防御措施。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值