作为一名小小的GreenBird,学习MVC呢,已经花费了2天了,期间得到了美丽的学姐的帮助,初步整理了一下。

首先,学习MVC呢就先以一个标准的MVC的简单的例子来入手,然后根据学姐的PPT,我用vs2012建立了一个项目。

1.建立一个MVC架构的项目:

File->New Project->Visual C#->ASP.NET MVC 4 Web Application

可以直接运行这个网站

2.Adding a Controller

右键单击Controller->add->Controller(CommentControler)

public string Index()

{

return "This is my first test of <b>MVC</b>...";

}

把原来的Index方法可以注释掉。

3.在RouteConfig.cs里面有路由规则。

routes.MapRoute(

name: "Default",

url: "{controller}/{action}/{id}",

defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }

);

可以试验一下这个路由规则:

在新建的CommentControler里新定义一个action如下:

public string Welcome(string name, int numTimes = 1)

{

return HttpUtility.HtmlEncode("Hello " + name + ", NumTimes is: " + numTimes);

}

然后在浏览器上面

也可以改变一下路由规则:

routes.MapRoute(

name: "Cathy",

url: "{controller}/{action}/{name}/{id}"

);

改变一下Comment里面的action:

public string Welcome(string name, int ID = 1)

{

return HttpUtility.HtmlEncode("Hello " + name + ", ID: " + ID);

}

4.Add a folder View|Comment

引用:Layout = "~/Views/Shared/_Layout.cshtml";(可以在Share里面的要引用的东西直接拖过来稍微修改一下就可以了)

Index里面的内容是这个样子的:

@{

ViewBag.Title = "Easy";

Layout = "~/Views/Shared/_Layout.cshtml";

}

<h2>Practice of *Comments</h2>

5.修改CommentController里面的内容,

public ActionResult Index()

{

return View();

}

把此注释去掉。

6.在Share的公共模板里面修改界面的格式,menu里面增加一个超链接的文字。

(可以输入函数名称,把鼠标放在上面看下面的参数应该怎么写)

<li>@Html.ActionLink("Easy", "Index", "Comment")</li>

7.Adding a Model:Comment.cs

using System;

using System.Data.Entity;

using System.Web;

using System.ComponentModel.DataAnnotations;

using System.ComponentModel.DataAnnotations.Schema;

namespace Practice.Models

{

public class Comment

{

[Key]

[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]

public int CommentID { get; set; }

public DateTime CommentTime { get; set; }

public string CommnetUser { get; set; }

public string CommenContent { get; set; }

public int ParentCommentID { get; set; }

}

}

8.在Models 里面的另外的cs文件中寻找Dbcontext,并写入:

public DbSet<Comment> Comments { get; set; }

9.在菜单栏里面找到tools->libraries package manager->package manager console

分别输入下面的命令:

Enable-Migrations//会在工程里面自动生成一个Migrations文件

Add-Migration Create_DB_DIY(自己定义的,但是没有间隔)

Update-Database

这样就在vs里面创建了一个数据库,里面有两张表,可以在View->Server Explore里面找到tables,有两张表:

可以右击表,New Query,新建查询

10.设计Easy超链接的页面Index.cshtml

<div>

<div>

<table>

<tr>

<td>

<div>

<div style="color: blue">CommnetUser</div>

<div>CommenContent</div>

<div style="color: gray; font-size: 10px;">CommentTime</div>

</div>

</td>

<td>

<div>

<input id="delete-button" type="submit" value="Delete" />

</div>

</td>

</tr>

</table>

</div>

<div>

<div>

<input name="commentUser" type="text" placeholder="User Name..." />

</div>

<div>

<textarea name="commentContent" rows="5"></textarea>

</div>

<div>

<input id="submit-button" type="submit" value="Submit" />

</div>

</div>

</div>

到了这个地方,我们就可以得到显示的页面了,但是这个时候还不能与数据库连接,需要新建Controller来控制与数据库的交互。

11.新建Controller:BaseController.cs增加内容:

public UsersContext db = new UsersContext();

另外为了和数据库进行交互,还需包含下面的using System.Web.Mvc;

using MVC4.Models;

12.修改CommentController.cs

using CommentSample.Models;

Change Controller into BaseController

public ActionResult Index()
        {
            var comments = db.Comments.OrderByDescending(c => c.CommentTime).ToList();
            return View(comments);
        }

[HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult CommentFunction(string commentUser, string commentContent)
        {
            if (commentUser != null && commentContent != null)
            {
                db.Comments.Add(new Comment { CommentTime = DateTime.Now, CommnetUser = commentUser, CommenContent = commentContent, ParentCommentID = 0 });
                db.SaveChanges();
            }
            return RedirectToAction("Index", "Comment");
        }

    [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult DeleteFunction(int commentId)
        {
            var comment = db.Comments.SingleOrDefault(c => c.CommentID == commentId);
            if (comment != null)
            {
                db.Comments.Remove(comment);
                db.SaveChanges();
            }
            return RedirectToAction("Index", "Comment");
        }

}

13.修改Comment/Index.cshtml:

@model List<MVC4.Models.Comment>
@using MVC4.Models
@{
    ViewBag.Title = "Easy";
    Layout = "~/Views/Shared/_Layout.cshtml";
}

<div>
    <div>
        <table>
            @foreach (var comment in Model.Where(c => c.ParentCommentID == 0))
            {
                <tr>
                    <td>
                        <div>
                            <div style="color: blue">@comment.CommnetUser</div>
                            <div>@comment.CommenContent</div>
                            <div style="color: gray; font-size: 10px;">@comment.CommentTime</div>
                        </div>
                    </td>
                    <td>
                        @using (Html.BeginForm("DeleteFunction", "Comment", "FormMethod.Post"))
                        {
                            @Html.AntiForgeryToken()
                            @Html.Hidden("commentId",comment.CommentID)
                            <div>
                                <input id="delete-button" type="submit" value="Delete" />
                            </div>
                        }
                    </td>
                </tr>
            }
        </table>
    </div>
    @using (Html.BeginForm("CommentFunction", "Comment", FormMethod.Post))
    {
        @Html.AntiForgeryToken()//防止CSRS攻击
        <div>
            <div>
                <input name="commentUser" type="text" placeholder="User Name..." />
            </div>
            <div>
                <textarea name="commentContent" rows="5"></textarea>
            </div>
            <div>
                <input id="submit-button" type="submit" value="Submit" />
            </div>
        </div>
    }

</div>

这样的话就建立了一个简单的留言簿。可以输入评论人的名字,评论内容,提交后显示在页面上,页面上的每个评论都可以删除。

期间出现了问题:

The resource cannot be found.

下面的网址提供了解决方案:

http://cephas.net/blog/2005/07/14/aspnet-the-resource-cannot-be-found/

但是这个对于我来说好像并没有什么用处,Fiona学姐给我解决了这个问题,就是我没有把CSRS攻防的方法放在正确的位置上。

每个增删数据的方法对应于Controller.cs里面的一个方法,该方法上面要加上相应的防止CSRS攻防的语句。同时,在View里利用@来定义一个Action里所对应的模型,这样就可以直接在cshtml文件中调用“Model”变量。 Model其实是一个类库,封装与应用程序的业务逻辑相关的数据以及对数据的处理方法,它可以直接访问数据库。对于一个事件,Controller首先会根据这个事件作出相应的处理,去改变View或Model。

下面是引用的一个博客的文章的一段:

原文地址:(http://blog.csdn.net/qinkeliangqin/article/details/27084639

MVC网站的访问流程:

1. 当第一个请求从客户端发起的时候,首先执行的是Global.asax中的Application_Start()方法来完成一些初始化工作,其中重要的一步是RegisterRoutes方法,这个方法指定了如何将url映射到具体的方法上,稍后详解。

2. 根据第一步中指定的映射表生成一个RouteData对象,利用这个对象来创建一个RequestContext对象。

3. MvcRouteHandler创建一个MvcHandler,并将RequestContext对象传给MvcHandler。

4. MvcHandler对象利用RequestContext对象确定一个IControllerFactory对象来创建Controller对象。

5. MvcHandler对象调用Controller对象的Execute()方法。

6. Controller的ControolerActionInvoker对象决定调用controller的哪个具体的action方法。

7. Action方法接受用户参数,执行方法,返回一个Result类型的对象。

注:其实还有很多问题没有搞清楚,以后接触的过程中会继续学习~~

参考文献:

http://www.cnblogs.com/zgqys1980/archive/2012/08/17/2643572.html

http://blog.csdn.net/qinkeliangqin/article/details/27084639

MVC架构学习的更多相关文章

  1. MVC架构学习之Smarty学习——病来而蔫

    前两天是五一小长假,而每次假期都想着如何如何刻苦一番,往往是自作多情.. 当然这次是有小病在身,多个借口吧. 一有病就蔫的不行...要锻炼了啊,脚估计也差不多了,游泳试试吧这周. 这次学习Smarty ...

  2. MVC架构学习之EasyFirst——快点夸我爱学习~

    iMooc上的MVC教程练习. MVC是PHP基础和进阶的分界点吧应该说是 一.准备 工欲善其事~ 个人环境:windows10+wamp2.5+ZendStudio12: 项目名称:MVCEasyF ...

  3. go区块链学习教程之iris框架mvc架构

    在Iris框架中,封装了mvc包作为对mvc架构的支持,方便开发者遵循mvc的开发原则进行开发. iris框架支持请求数据.模型.持久数据分层处理,并支持各层级模块代码绑定执行. MVC即:model ...

  4. ExtJS 4.2.1学习笔记(一)——MVC架构与布局

    1       ExtJS入门 1.1     支持所有主流浏览器 调试推荐:chrome.Safari.Firefox 1.2     推荐目录结构 - appname (包含所有程序代码,是根目录 ...

  5. 设计模式之美学习(九):业务开发常用的基于贫血模型的MVC架构违背OOP吗?

    我们都知道,很多业务系统都是基于 MVC 三层架构来开发的.实际上,更确切点讲,这是一种基于贫血模型的 MVC 三层架构开发模式. 虽然这种开发模式已经成为标准的 Web 项目的开发模式,但它却违反了 ...

  6. PHP学习(MVC架构与面向对象)

    想好好的学一下php中的一些面向对象的知识,以前只是为了打CTF随意的学了一下,但是为了以后的代码审计(准备PHP这边把thinkphp这个框架好好的学一下). PHP面向对象的基本知识 类与对象 类 ...

  7. 【JAVA】基于MVC架构Java技术荟萃案例演练

    基于JAVA-MVC技术的顾客管理项目案例总结 作者 白宁超 2016年6月9日22:47:08 阅读前瞻:本文源于对javaweb相关技术和资料汇总,涉及大量javaweb基础技术诸如:Servle ...

  8. MVC架构杂谈

    来源:伯乐在线专栏作者 - 林欣达 链接:http://ios.jobbole.com/86895/ 点击 → 了解如何加入专栏作者 前言 MVC是软件工程中的一种软件架构模式,它把软件系统分为三个基 ...

  9. ExtJS 4 MVC架构讲解

    大规模客户端应用通常不好实现不好组织也不好维护,因为功能和人力的不断增加,这些应用的规模很快就会超出掌控能力,ExtJS 4 带来了一个新的应用架构,不但可以组织代码,还可以减少实现的内容新的应用架构 ...

随机推荐

  1. leetCode 53.Maximum Subarray (子数组的最大和) 解题思路方法

    Maximum Subarray  Find the contiguous subarray within an array (containing at least one number) whic ...

  2. CSS 边框 阴影 效果

    CSS 边框 阴影 效果 以下将css实现阴影效果,以便须要朋友们,直接上代码 #shadow1{ width: 200px; height: 100px; color: white; backgro ...

  3. dll注册到GAC还是bin - sharepoint程序

    通常来说程序在使用dll的时候,会先去GAC中查找是否有存在合适的dll,然后才会到应用程序下的bin目录去查找: 前几天遇到了一个奇葩问题,web项目工程添加了一个第三方dll的引用,然后把这个第三 ...

  4. 在ASP.NET中ShowModalDialog+ztree的使用

    .aspx: <script type="text/javascript"> function getReturnValue() { var strResult = w ...

  5. Dom4j解析Xml文件,Dom4j创建Xml文件

    Dom4j解析Xml文件,Dom4j创建Xml文件 >>>>>>>>>>>>>>>>>>&g ...

  6. hao123 百度品专 按品类 计算 下单数量 商品数量 下单金额?

    SELECT * FROM t_tag_source WHERE   s_name='hao123'; +--------+----------+---------+--------+-------- ...

  7. 多线程(Thread),其实很简单!

    目录:  1:线程简介 2:怎么操作线程      3:Thread的常用方法 4:简单的获奖机     5:应用程序域   线程:是Windows任务调度的最小单位.线程是程序中的一个执行流,每个线 ...

  8. CenOs安装中文输入法

    http://jingyan.baidu.com/album/d8072ac4434666ec95cefda1.html?picindex=2 查看链接

  9. SqlSugar-事务操作

    一.事务操作实例 特别说明: 1.特别说明:在事务中,默认情况下是使用锁的,也就是说在当前事务没有结束前,其他的任何查询都需要等待 2.ReadCommitted:在正在读取数据时保持共享锁,以避免脏 ...

  10. 动态库DLL加载方式-静态加载和动态加载

    静态加载: 如果你有a.dll和a.lib,两个文件都有的话可以用静态加载的方式: message函数的声明你应该知道吧,把它的声明和下面的语句写到一个头文件中 #pragma comment(lib ...