zoukankan      html  css  js  c++  java
  • asp.net core轻松入门之MVC中Options读取配置文件

    接上一篇中讲到利用Bind方法读取配置文件

    ASP.NET Core轻松入门Bind读取配置文件到C#实例

    那么在这篇文章中,我将在上一篇文章的基础上,利用Options方法读取配置文件

    首先注册MVC服务并添加MVC路由

    注册MVC的方法是在ConfigureServices中添加

     services.AddMvc();

    添加MVC路由的方法是在Configure中添加
      app.UseMvcWithDefaultRoute();

    然后在项目中添加Controllers文件夹和Views文件夹,然后在Controllers文件夹中添加home控制器 ,方法是在该文件加有几-》添加-》控制器

    选择MVC控制器,并给该控制器命名为HomeControllers   控制器是必须以Controllers结尾的

    然后选中控制器中的Index方法  右键菜单,选择添加视图,不要勾选,使用模板页,因为我们是一个空项目,没有模板的

    加入视图后,回到home控制器,添加Class实例并利用HomeController的构造函数给该实例赋值,注意,就是在此处使用到了Options方法

    private Class myClass;
    
            public HomeController(IOptions<Class> myClass)
            {
                this.myClass = myClass.Value;
            }
    
    然后修改Index方法,将myClass实例传递给视图。
      public IActionResult Index()
            {
                return View(myClass);
            }

    回到Index视图中,在文件的顶部指定model的类型为 Class类型,然后利用html代码进行输出。
    @model BindReader.Class
    @{
        Layout = null;
    }
    <!DOCTYPE html>
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
    </head>
    <h2>@Model.Name</h2>
    @foreach (var item in Model.Items)
    {
        <div>
            <h2>@item.Language</h2>
            <h2>@item.Tool</h2>
        </div>
    }
    <body>
    </body>
    </html>

    最后,回到StartUp.cs  进行Class的依赖注入,注入的方法是在ConfigureServices添加以下代码,因为系统会自动读取appsettings.json中的信息,其内的具体内容在上一文章中有介绍。
     services.Configure<Class>(Configuration);

    最后,我们需要吧Configure中的app.Run方法进行注释,因为该方法会阻塞管道,影响mvc的正常工作。


    最后,可以运行查看效果了。


    其实还有不需要在home控制器中利用构造函数引入myClass的方法,我们可以直接在利用Options方法读取Class信息,需要将home控制器中构造函数中的代码注释,删除Index 方法中Return View(myClass)的myClass  因为此时myClass是空的。

    然后Index控制器中修改后的代码如下:

    @using BindReader
    @using Microsoft.Extensions.Options
    @inject IOptions<Class> classAccess
    @{
        Layout = null;
    }
    <!DOCTYPE html>
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
    </head>
    <h2>@classAccess.Value.Name</h2>
    @foreach (var item in classAccess.Value.Items)
    {
        <div>
            <h2>@item.Language</h2>
            <h2>@item.Tool</h2>
        </div>
    }
    <body>
    </body>
    </html>
    

    项目的完整代码GitHub地址:https://github.com/liuzhenyulive/BindReader

    有任何疑问可以在文章下方评论留言。


  • 相关阅读:
    flask框架的使用
    git的基本使用
    pycharm连接数据库以及遇到的问题
    Git原理与Git命令大全
    git使用
    Redis 数据库
    ATM项目
    跨域问题及解决方案
    django的信号
    django的缓存机制
  • 原文地址:https://www.cnblogs.com/CoderAyu/p/8490135.html
Copyright © 2011-2022 走看看