- Hands-On Full:Stack Web Development with ASP.NET Core
- Tamir Dresher Amir Zuker Shay Friedman
- 290字
- 2021-06-10 19:37:24
Configuring the available MIME types
ASP.Net Core serves static files that are of a known MIME type. A MIME type is an identifier of the type of content that a specific file holds. For example, HTML files have a MIME type of text/html, and JPEG image files have a MIME type of image/jpeg.
When a web server serves a file, it attaches its MIME type to the response as an HTTP header named content-type. The browser then, in turn, uses this MIME type to decide on how to interpret the file.
ASP.NET Core recognizes almost 400 mime types automatically. When it runs into an unrecognized file, it will not serve it to the end user and instead return a 404 — Not Found response. This behavior improves the security of your web application and works in the majority of use cases.
However, sometimes, your application needs to send files to end users that are not recognized by default by ASP.NET Core; for example, .exe files, which are Windows' executable file format. The following code instructs ASP.NET Core to use the application/vnd.microsoft.portable-executable MIME type for these types of files:
FileExtensionContentTypeProvider provider = new FileExtensionContentTypeProvider();
provider.Mappings[".exe"] = "application/vnd.microsoft.portable-executable";
StaticFileOptions staticFileOptions = new StaticFileOptions()
{
ContentTypeProvider = provider
};
app.UseStaticFiles(staticFileOptions);
Using this technique, you can also change existing MIME types to fit your needs, or remove MIME types that you do not want to be served. For example, the following code changes .ts files to be recognized as TypeScript files, instead of the video file MIME type defined by ASP.NET Core. This will be needed later in this book when we start using TypeScript:
FileExtensionContentTypeProvider provider = new FileExtensionContentTypeProvider();
provider.Mappings[".ts"] = "application/x-typescript";
StaticFileOptions staticFileOptions = new StaticFileOptions()
{
ContentTypeProvider = provider
};
app.UseStaticFiles(staticFileOptions);
- Building Django 2.0 Web Applications
- 從區塊鏈到Web3:構建未來互聯網生態
- 計算機網絡安全實訓教程(第二版)
- 互聯網基礎資源技術與應用發展態勢(2021—2023)
- Go Web Scraping Quick Start Guide
- Building RESTful Web services with Go
- TD-LTE無線網絡規劃與設計
- SAE原理與網絡規劃
- Android UI Design
- 網絡工程實施技術與方案大全
- 一本書讀懂物聯網
- 5G技術核心與增強:從R15到R17
- Hands-On Docker for Microservices with Python
- Web用戶查詢日志挖掘與應用
- 從物聯到萬聯:Node.js與樹莓派萬維物聯網構建實戰