当前位置: 首页 > news >正文

ASP.NET Core----基础学习03----开发者异常页面 MVC工作原理及实现

文章目录

      • 1. 开发者异常页面
        • (1)Startup.cs 页面的基础配置
        • (2)自定义显示报错代码的前后XX行
      • 2. MVC 的原理
      • 3. MVC 的实现
      • 4.默认路由路径
      • 5.返回Json字符串

1. 开发者异常页面

(1)Startup.cs 页面的基础配置

namespace ASP.Net_Blank
{public class Startup{private readonly IConfiguration _configuration;public Startup(IConfiguration iconfiguration){_configuration = iconfiguration;}public void Configure(IApplicationBuilder app, IWebHostEnvironment env, ILogger<Startup> logger){// app.UseDeveloperExceptionPage() 这个调用需要在中间件使用之前调用,否者中间件运行过程中的报错可能无法显示出来。if (env.IsDevelopment()){app.UseDeveloperExceptionPage();}app.UseFileServer();app.UseStaticFiles();app.Run(async (context) =>{throw new Exception("This is an Error");await context.Response.WriteAsync("third MiddleWare");});}}
}

如下红框中是核心添加的代码:
在这里插入图片描述

出错代码的具体位置:
在这里插入图片描述

如果请求的url包含参数的显示:
在这里插入图片描述


请求的Headers信息头:
在这里插入图片描述


(2)自定义显示报错代码的前后XX行
# Startup.cs 文件详情namespace ASP.Net_Blank
{public class Startup{private readonly IConfiguration _configuration;public Startup(IConfiguration iconfiguration){_configuration = iconfiguration;}public void Configure(IApplicationBuilder app, IWebHostEnvironment env, ILogger<Startup> logger){if (env.IsDevelopment()){DeveloperExceptionPageOptions developerExceptionPageOptions = new DeveloperExceptionPageOptions();developerExceptionPageOptions.SourceCodeLineCount = 3;      // 设置代码报错行的前后3行显示出来app.UseDeveloperExceptionPage(developerExceptionPageOptions);}app.UseFileServer();app.UseStaticFiles();app.Run(async (context) =>{throw new Exception("This is an Error");await context.Response.WriteAsync("third MiddleWare");});}}
}

在这里插入图片描述


2. MVC 的原理

  • Model(模型): 包含一组数据的类和管理该数据的逻辑信息
  • View(视图): 包含显示逻辑,用于显示Controller提供给它的模型中的数据
  • Controller(控制器):处理Http请求,调用模型,选择一个视图来呈现该模型。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


3. MVC 的实现


创建Controllers 文件夹并创建控制器(HomeController.cs):

在这里插入图片描述

在这里插入图片描述

HomeController.cs创建好之后,修改为返回string:
在这里插入图片描述

Startup.cs文件添加MVC 服务和调用该服务
在这里插入图片描述

最终的呈现结果:
在这里插入图片描述

4.默认路由路径

通过如上启动的页面,发现访问了http://localhost:5188/ 也到达了/home/index 路径下面的该显示的视图。通过追踪UseMvcWithDefaultRoute方法的源码,可以查看到。

  • 该方法会默认进入到home这个controller(HomeController简称Home), 中的index这个方法中。(不区分大小写),最终返回如上结果。

在这里插入图片描述


5.返回Json字符串

在这里插入图片描述

在这里插入图片描述

http://www.lryc.cn/news/396795.html

相关文章:

  • jvm 07 GC算法,内存池,对象内存分配
  • ComfyUI入门教程
  • Flutter TabBar与TabBarView联动及获取当前点击栏目索引
  • 【区块链+跨境服务】跨境出口电商溯源 | FISCO BCOS应用案例
  • 记录一次mysql死锁问题的分析排查
  • 【UE5.1 角色练习】16-枪械射击——瞄准
  • 04OLED简介和调试方法
  • “LNMP环境搭建实战指南:从零开始配置CentOS 7下的Nginx、MySQL与PHP“
  • 院内导航:如何用科技破解就医找路难题
  • C++基础篇(1)
  • 云视频监控中的高效视频转码策略:视频汇聚EasyCVR平台H.265自动转码H.264能力解析
  • xcode配置swift使用自定义主题颜色或者使用RGB或者HEX颜色
  • 相同含义但不同类型字段作为join条件时注意事项
  • 数据结构(3.8)——栈的应用
  • 前端面试题35(在iOS和Android平台上,实现WebSocket协议有哪些常见的库或框架?)
  • Mysql如何高效ALTER TABL
  • vue3+vite搭建第一个cesium项目详细步骤及环境配置(附源码)
  • LiteOS增加执行自定义源码
  • 《Nature》文章:ChatGPT帮助我学术写作的三种方式
  • 防火墙安全策略与用户认证综合实验
  • vue学习day05-watch侦听器(监视器)、Vue生命周期和生命周期的四个阶段、、工程化开发和脚手架Vue cli
  • 数字人+展厅互动体验方案:多元化互动方式,拓宽文化文娱新体验
  • 在Spring Boot项目中集成监控与报警
  • opencv实现目标检测功能----20240704
  • 音视频解封装demo:使用libmp4v2解封装(demux)出mp4文件中的h264视频数据和aac语音数据
  • 手撸俄罗斯方块(一)——简单介绍
  • 构建LangChain应用程序的示例代码:61、如何使用 LangChain 和 LangSmith 优化链
  • Android系统通过属性设置来控制log输出的方案
  • JavaDoc的最佳实践
  • 数字力量助西部职教全面提升——唯众品牌大数据、人工智能系列产品中标甘肃庆阳职院数字经济人才培养基地!