首页 > 编程语言 >ASP.NET Core MVC 从入门到精通之wwwroot和客户端库

ASP.NET Core MVC 从入门到精通之wwwroot和客户端库

时间:2023-04-20 19:34:56浏览次数:58  
标签:Core wwwroot ASP 静态 app 默认 所示 NET

随着技术的发展,ASP.NET Core MVC也推出了好长时间,经过不断的版本更新迭代,已经越来越完善,本系列文章主要讲解ASP.NET Core MVC开发B/S系统过程中所涉及到的相关内容,适用于初学者,在校毕业生,或其他想从事ASP.NET Core MVC 系统开发的人员。 经过前几篇文章的讲解,初步了解ASP.NET Core MVC项目创建,启动运行,以及命名约定,创建控制器,视图,模型,接收参数,传递数据,路由,页面布局等内容,今天继续讲解ASP.NET Core MVC wwwroot和客户端库等相关内容,仅供学习分享使用。

 

wwwroot文件夹概述

 

通过模板创建的ASP.NET Core MVC项目,会在程序根目录创建一个wwwroot文件夹。此文件夹又称为webroot文件夹,主要用于存放静态资源文件,如:html,JavaScript,css样式等内容。默认情况下,存在wwwroot文件夹下的所有静态资源都可以通过Http请求提供服务。在新的框架中,且只有存放于wwwroot目录下的静态资源可以直接通过Http访问,其他目录下的静态资源都将阻止。

 

静态资源中间件

 

为了使wwwroot目录下的静态资源能够被Http直接访问,需要在程序启动时【Program.cs】加载静态资源中间件。如下所示:

 1 var builder = WebApplication.CreateBuilder(args);
 2 
 3 // Add services to the container.
 4 builder.Services.AddControllersWithViews();
 5 
 6 var app = builder.Build();
 7 
 8 // Configure the HTTP request pipeline.
 9 if (!app.Environment.IsDevelopment())
10 {
11     app.UseExceptionHandler("/Home/Error");
12     // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
13     app.UseHsts();
14 }
15 
16 app.UseHttpsRedirection();
17 
18 //1. 启动静态资源服务中间件
19 app.UseStaticFiles();
20 
21 app.UseRouting();
22 
23 app.UseAuthorization();
24 
25 app.MapControllerRoute(
26     name: "default",
27     pattern: "{controller=Home}/{action=Index}/{id?}");
28 
29 app.Run();

 

静态资源示例

 

创建程序后,直接运行,会通过路由设置,默认加载Home/Index页面,如下所示:

在wwwroot目录下,创建index.html,内容如下所示:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="utf-8" />
 5     <title>静态首页</title>
 6 </head>
 7 <body>
 8     <h1>公子小六</h1>
 9     <h2>这是静态首页</h2>
10 </body>
11 </html>

在Program.cs启动文件中,添加默认文件中间件【app.UseDefaultFiles();】,如下所示:

 1 var builder = WebApplication.CreateBuilder(args);
 2 // Add services to the container.
 3 builder.Services.AddControllersWithViews();
 4 var app = builder.Build();
 5 // Configure the HTTP request pipeline.
 6 if (!app.Environment.IsDevelopment())
 7 {
 8     app.UseExceptionHandler("/Home/Error");
 9     // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
10     app.UseHsts();
11 }
12 app.UseHttpsRedirection();
13 
14 
15 //0. 允许默认文件映射
16 app.UseDefaultFiles();
17 //1. 启动静态资源服务中间件
18 app.UseStaticFiles();
19 
20 
21 app.UseRouting();
22 app.UseAuthorization();
23 app.MapControllerRoute(
24     name: "default",
25     pattern: "{controller=Home}/{action=Index}/{id?}");
26 
27 app.Run();

再次运行程序,会发现静态默认首页Index.html会替换之前默认的Home/Index路由视图,如下所示:

通过以上示例得出在结论:默认静态资源首页优先级高于默认路由。

 

修改默认资源名称

 

默认启动静态资源名称为Index.html,可以通过DefaultFilesOptions指定默认的首页加载顺序和名称。如下所示:

 1 var builder = WebApplication.CreateBuilder(args);
 2 // Add services to the container.
 3 builder.Services.AddControllersWithViews();
 4 var app = builder.Build();
 5 // Configure the HTTP request pipeline.
 6 if (!app.Environment.IsDevelopment())
 7 {
 8     app.UseExceptionHandler("/Home/Error");
 9     // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
10     app.UseHsts();
11 }
12 app.UseHttpsRedirection();
13 
14 //默认文件启动项
15 DefaultFilesOptions options = new DefaultFilesOptions();
16 options.DefaultFileNames.Add("Hello.html");
17 //0. 允许默认文件映射
18 app.UseDefaultFiles(options);
19 
20 //1. 启动静态资源服务中间件
21 app.UseStaticFiles();
22 
23 app.UseRouting();
24 app.UseAuthorization();
25 app.MapControllerRoute(
26     name: "default",
27     pattern: "{controller=Home}/{action=Index}/{id?}");
28 
29 app.Run();

修改后再次启动,发现加载的依然是Index.html,而不是Hello.html。经过调试发现,DefaultFilesOptions的默认加载页面,会自动填充4个默认页面名称。后面添加的页面名称会在原有默认页面之后。如下所示:

 经过以上分析,删除默认的index.html页面,重新启动,默认首页变成了Hello.html页面,如下所示:

 静态资源文件除了可以通过静态资源中间件来实现【app.UseStaticFiles()】,还可以通过文件服务中间件来实现,如下所示:

1 FileServerOptions options = new FileServerOptions();
2 options.DefaultFilesOptions.DefaultFileNames.Add("Hello.html");
3 app.UseFileServer(options);

 

修改静态资源目录

 

默认的静态资源目录为wwwroot,一般也是通用的webroot文件夹名称,如果需要修改成其他目录 ,可以通过WebApplication.CreateBuilder(options)中的选项进行修改,接线所示:

1 WebApplicationOptions weboptions = new WebApplicationOptions() { WebRootPath="wwwroot2" };
2 var builder = WebApplication.CreateBuilder(weboptions);

修改后,重新运行程序,如下所示:

注意:为了让wwwroot2生效,必须修改原有的wwwrooot文件名称或者删除wwwroot文件夹,否则wwwroot2将不生效。

 

客户端库

 

客户端库主要是指JavaScript,CSS等第三方库,在ASP.NET Core MVC项目中,安装客户端库如下所示:

在项目名称处右键,选择添加,客户端库,如下所示:

 在打开的客户端库添加窗口,可以选择需要的库名称,进行搜索,然后进行安装即可,如下所示:

 安装成功后,在目标位置即可进行查看,如下所示:

以上就是关于ASP.NET Core MVC项目中wwwroot和客户端库相关内容。关于客户端库在安装成功后,如何在页面中引用,将在后续章节中进行介绍。

 

标签:Core,wwwroot,ASP,静态,app,默认,所示,NET
From: https://www.cnblogs.com/hsiang/p/17328107.html

相关文章

  • asp.net程序通过Microsoft Azure中SAML协议实现单点登录
    1.新建应用程序登录Azure门户,进入左侧菜单“企业应用程序--所有应用程序”,点“新建应用程序”,继续点“创建你自己的应用程序”,如下图选择和录入名称:填好应用的名称、想要如何处理应用程序必须选择第三个“继承未在库中找到的任何其他应用程序(非库)”,之后点“创建”按钮;2.单......
  • org.pentaho.di.core.exception.KettleXMLException: Unexpected problem reading sh
    【kettle】【报错】UnexpectedproblemreadingsharedobjectsfromXMLfile当读共享文件时发生错误UnexpectedproblemreadingsharedobjectsfromXMLfile:null当读共享文件时发生错误kettle新建转换时,“读取共享对象时发生一个严重错误”“Unexpectedproblemre......
  • 如何在 .NET Core WebApi 中处理 MultipartFormDataContent
    最近在对某个后端服务做.NETCore升级时,里面使用了多处处理MultipartFormDataContent相关内容的代码。这些地方从.NETFramework迁移到.NETCore之后的代码改动较大,由于本身没有测试覆盖,导致在部署QA环境后引发了一些问题。这里做一个技术复盘。什么是MultipartForm......
  • Raspberry Pi & Experience AI All In One
    RaspberryPi&ExperienceAIAllInOneExperienceAIisaneweducationalprogrammethatofferscutting-edgeKS3(ages11–14)resourcesonartificialintelligenceandmachinelearningforteachersandtheirstudents.Developedincollaborationby......
  • Crash on AIX produces no core or a truncated core
    CrashonAIXproducesnocoreoratruncatedcoreTroubleshootingProblemThisdocumentoutlineswhatneedstobedonetoensurethatafullcorefileisproducedonAIXifWebSphereApplicationServercrashes.ResolvingTheProblemSystemc......
  • AspNetCore 成长杂记(一):JWT授权鉴权之生成JWT(其一)
    引子最近不知怎么的,自从学了WebAPI(为什么是这个,而不是MVC,还不是因为MVC的Razor语法比较难学,生态不如现有的Vue等框架,webapi很好的结合了前端生态)以后,使用别人的组件一帆风顺,但是不知其意,突然很想自己实现一个基于的JWT认证服务,来好好了解一下这个内容。起步自从Session-Cooki......
  • api-ms-win-core-file-l1-2-0.dll文件问题解决
    其实很多用户玩单机游戏或者安装软件的时候就出现过这种问题,如果是新手第一时间会认为是软件或游戏出错了,其实并不是这样,其主要原因就是你电脑系统的该dll文件丢失了或者损坏了,这时你只需下载这个api-ms-win-core-file-l1-2-0.dll文件进行安装(前提是找到适合的版本),当我们执行某......
  • 19c环境,运行DBCA创建CDB时,报错ORA-01519: error while processing file:?/rdbms/admin
    1、同事新搭建的一套19CRAC,补丁为19.10,运行DBCA安装CDB数据库时报错,错误日志如下所示:ORA-01519:errorwhileprocessingfile:?/rdbms/admin/dcore.bsq.....ORA-00604:erroroccurredatrecursiveSQLlevel1ORA-01119:errorincreatingdatabasefile'+DATA01/CDB1/pdb......
  • ASP.NET没有魔法——ASP.NET MVC Controller的实例化与执行
    原文:https://www.cnblogs.com/selimsong/p/7677108.html上一章节中对路由的注册和匹配过程进行了介绍,知道了MVC的Http请求最终是交由MvcHandler处理的,而其处理过程就是对Controller的创建、执行和释放。本章将从以下几点进一步对上面提到的三个过程进行介绍:●MvcHand......
  • ASP.NET Core - 缓存之分布式缓存
    分布式缓存是由多个应用服务器共享的缓存,通常作为访问它的应用服务器的外部服务进行维护。分布式缓存可以提高ASP.NETCore应用的性能和可伸缩性,尤其是当应用由云服务或服务器场托管时。与其他将缓存数据存储在单个应用服务器上的缓存方案相比,分布式缓存具有多个优势。当分发......