zoukankan      html  css  js  c++  java
  • 【.NET框架】—— ASP.NET MVC5 初识(一)

    章节一 MVC5

    MVC全名是Model View Controller,是模型(model)——视图(view)——控制器(controller)的缩写,是一种软件设计典范,提供了一种用业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构。

    ASP.NET MVC是一种构建WEB应用程序的框架,它将一般的MVC模式应用于ASP.NET框架。ASP.NET MVC经历了5个主要版本的迭代,其中ASP.NET MVC4和MVC5是目前比较成熟的版本。

    ASP.NET MVC4主要功能包括:

    ①ASP.NET Web API;

    ②增强了默认的项目模板;

    ③增加使用jQuery Mobile的手机项目模板;

    ④支持显示模式(Display Mode);

    ⑤支持异步控制器的任务

    ASP.NET MVC5主要功能包括:

    ①单一的ASP.NET开发组件;

    ②提供了新的Web项目体验;

    ③ASP.NET Identity;

    ④BootStrap模板;

    ⑤特性路由;

    ⑥身份验证过滤器;

    开发环境支持:

    MVC5需要.NET4.5,VS2013以上版本

    1.1.创建MVC Web应用程序

    ①新建项目

    选择MVC如下图所示:

    1.2.MVC项目文档的结构

    App_Data:应用程序本地存储;

    App_Start:应用程序配置逻辑文件;

    RouteConfig.cs:配置MVC应用程序的系统路由路径;

    Content:该文件夹被推荐用于存储静态内容文件类似CSS 和 (图片)Images;

    1.3.MVC5 Controller对应View页面

    Controllers控制器方法会返回一个页面视图,和Views中的html页面一一对应

    注意:界面必须和Controller中方法名字一一对应,不然会报错;

    1.4.创建Model模型并向View展示数据

    ①在Model层中创建对应的User类,并在Controller层中Index方法中引入UserList;

    public class TestController : Controller
        {
            // GET: Test
            public ActionResult Index()
            {
                User user = new User();
                user.Name = "测试人员1";
                user.Age = 24;
                User user2 = new User();
                user2.Name = "测试人员2";
                user2.Age = 23;
    
                List<User> userList = new List<User>();
                userList.Add(user);
                userList.Add(user2);
    
                return View(userList);
            }
        }

    ②在Views层中对应Controller的方法视图下进行展示;

    视图引入模型

     @using 包文件

     @model IEnumerable<类>

    展现数据

    <ul>

            @foreach (类 a in Model)

            {

                <li>@a.Name</li>

            }

     </ul>

    <!--视图引入模型-->
    @using WebApplication01.Models;
    @model IEnumerable<User>
    
    @{
        ViewBag.Title = "Index";
    }
    
    <!--数据展示List集合-->
    <ul>
        @foreach (User user in Model)
        {
            <li>@user.Name</li>
            <li>@user.Age</li>
        }
    </ul>

     

    1.5.创建数据库链接实现数据读取

    ①首先在App_Start文件下创建一个数据库连接类;

    public class ConnData
        {
            public DataSet GetDataSet()
            {
                string myStr = "server=DESKTOP-3POL04N;database=stsc;UId=sa;password=123456";//获取链接字符串
                SqlConnection myConn = new SqlConnection(myStr);
                myConn.Open();//打开数据库
                string sqlStr = "select * from test01 ";//定义查询字符串
                SqlDataAdapter myDa = new SqlDataAdapter(sqlStr, myConn);//sql数据适配器
                DataSet myDs = new DataSet();//创建dataset
                myDa.Fill(myDs);//SqlDataAdapter填充DataSet
    
    
                return myDs;
            }
        }

    ②在Controller层中处理更新路由Index中的逻辑;

    public ActionResult Index()
            {
                //使用数据库查询封装User
                ConnData conn = new ConnData();
                DataSet dataSet = conn.GetDataSet();
                User user = new User();
                user.Name = dataSet.Tables[0].Rows[0][1].ToString();
                user.Age = int.Parse(dataSet.Tables[0].Rows[0][2].ToString());
    
                User user2 = new User();
                user2.Name = dataSet.Tables[0].Rows[1][1].ToString();
                user2.Age = int.Parse(dataSet.Tables[0].Rows[1][2].ToString());
                List<User> userList = new List<User>();
                userList.Add(user);
                userList.Add(user2);
    
                return View(userList);
            }

     

    1.6.MVC5+小三层架构

    小三层架构示意图:

    ①需要新增.NET FrameWork项目Model(模型层)、Bll(逻辑业务层)、Dal(数据操作层)

     

    ②增加Model、Dal、Bll中的逻辑代码;

    Model

      public class UserModel
        {
            string name;
    
            public string Name
            {
                get { return name; }
                set { name = value; }
            }
            int age;
    
            public int Age
            {
                get { return age; }
                set { age = value; }
            }
        }

    Bll层:

     public class UserBll
        {
    
            public List<UserModel> getUserData()
            {
                //使用数据库查询封装User
                UserDal userDal = new UserDal();  //Dal数据链接层处理数据
                DataSet dataSet = userDal.GetDataSet();
                UserModel user = new UserModel();
                user.Name = dataSet.Tables[0].Rows[0][1].ToString();
                user.Age = int.Parse(dataSet.Tables[0].Rows[0][2].ToString());
    
                UserModel user2 = new UserModel();
                user2.Name = dataSet.Tables[0].Rows[1][1].ToString();
                user2.Age = int.Parse(dataSet.Tables[0].Rows[1][2].ToString());
                List<UserModel> userList = new List<UserModel>();
                userList.Add(user);
                userList.Add(user2);
    
                return userList;
            }
        }

    Dal层:

      public class UserDal
        {
            public DataSet GetDataSet()
            {
                //有了数据链接层Conn,这里更改为如下操作:
                string sqlStr = "select * from test01 ";//定义查询字符串
                var DataTable = DbHelperSQL.ExecuteDataTable(sqlStr);
                DataSet myDs = new DataSet();//创建dataset
                myDs.Tables.Add(DataTable);
    
    
                return myDs;
            }
        }

    注意:Bll业务层需要增加项目依赖项,如下图

     

    ③需要在WebApplication01项目中处理Controller层和View界面层;

    Controller层:

     

    View层:

    展示数据:

    1.7.MVC5+小三层架构+数据连接层

    这里是在上面的基础上新增加了一个数据连接层Conn;封装数据库连接与增删改查操作

    之后修改Dal数据操作层,使用Conn中的DbHelperSQL封装Sql类来执行查询,构造DataSet:

    public class UserDal
        {
            public DataSet GetDataSet()
            {
                //有了数据链接层Conn,这里更改为如下操作:
                string sqlStr = "select * from test01 ";//定义查询字符串
                var DataTable = DbHelperSQL.ExecuteDataTable(sqlStr);
                DataSet myDs = new DataSet();//创建dataset
                myDs.Tables.Add(DataTable);
    
    
                return myDs;
            }
        }

     

    1.8.MVC5+EF框架

    ①首先,需要自定义创建一个实体Model类UserInfoModels;

      public class UserInfoModels
        {
            public int id { get; set; }
            public string name { get; set; }
            public int age { get; set; }
        }

    ②在Controllers控制器上创建MVC5的EF框架控制器;

     

    ③同时修改Web.config中的数据库连接connectionString配置,关联本地的数据库:

    其中Data Source=DESKTOP-3POL04N为本地数据库服务器名,Initial Catalog为需要生成的数据库名称。

    <add name="UserInfoContext" connectionString="Data Source=DESKTOP-3POL04N; Initial Catalog=UserInfoDB; Integrated Security=True;"
          providerName="System.Data.SqlClient" />

    ④点击视图Views文件夹下面的自定义模型视图Index.cshtml启动,这时会自动由EF框架生成数据库表UserInfoDB与界面;

  • 相关阅读:
    boost::VS2017下编译和配置boost库
    cmake::编译一个工程
    cmake::helloworld
    python模块之urllib
    Python报错:UnicodeEncodeError 'gbk' codec can't encode character
    word页眉添加横线与删除横线
    练习五十九:字典排序
    练习五十八:列表的练习
    练习五十七:for循环 809??=800*?+9*?+1其中?代表的两位数,8*?的结果为两位数,9*?的结果为3位数。求?代表的两位数,及809??后的结果
    windows查看网络常用cmd命令
  • 原文地址:https://www.cnblogs.com/yif0118/p/13406310.html
Copyright © 2011-2022 走看看