- 文件扩展名映射到MIME
- 非标准的内容类型
(一)引用块内容
FileExtensionContentTypeProvider类内包含一个将文件扩展名映射到MIME中内容类型的集合。
下面的一个例子,多个文件扩展名注册为已知的MIME类型,“.rtf”被替换,”.mp4”被移除:
代码位置:新建默认的.net core2.0 web项目,选择Stratup.cs类文件内的public void Configure(…)方法内:
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env,
ILoggerFactory loggerFactory)
{
var provider = new FileExtensionContentTypeProvider();
//新增一些新的映射
provider.Mappings[".myapp"] = "application/x-msdownload";
provider.Mappings[".htm3"] = "text/html";
provider.Mappings[".image"] = "image/png";
//替换存在的rtf映射
provider.Mappings[".rtf"] = "application/x-msdownload";
//移除MP4 videos
provider.Mappings.Remove(".mp4");
//
//other code........
app.UseMvc();
}
更多的MIME类型大家可以在网址里查看 : http://www.iana.org/assignments/media-types/media-types.xhtml
(二)非标准的内容类型
ASP.NET Core静态文件中间件能够支持超过400种已知文件内容类型。如果用户请求一个未知的文件类型,静态文件中间件将返回HTTP404(未找到)相应。如果启用目录浏览,则该文件的链接将会被显示,但URI会返回一个HTTP404错误。
下面的代码会把不能识别的类型和文件作为图片处理:选择Stratup.cs类文件内的public void Configure(…)方法内:选择Stratup.cs类文件内的public void Configure(…)方法内:
app.UseStaticFiles(new StaticFileOptions{
ServeUnknownFileTypes = true,
DefaultContentType="image/png"
});
注意事项:
UseDirectoryBrowser和UseStaticFiles可能会泄密。建议不要在生产环境开启目录浏览。要小心那些被你开启了UseStaticFiles或UseDirectoryBrowser的目录,它们的子目录都可被访问。建议将公开内容放在/wwwroot这样的目录中,远离应用程序视图、配置文件等。