简易留言簿系统-ASP.NET MVC (后台基本完成)

今天在工作的空余,完成了简易留言簿系统的基本功能。在这里总结全面总结一下。

简易留言薄系统: 开发工具:vs2013

在数据库方面,我选择了SQL 2012。

在代码开发阶段,我没有用code first的自动生成的数据库,而是指定了SQL服务器与数据库的信息。

通过这个系统学习到的东西。

1. 实现了在同一页面中显示数据与录入数据。刚开始的时候,由于对于MVC学习的东西很死板,所以一直没有想到应该如何实现,但是后来通过在网上的咨询,以及自己的理解,发现很简单,那就是 使用 BeginForm("insert数据的Action名称",“所在的Controller名”)。

代码如下:

@model MvcBBSApplication.Models.ReplyMessageViewModel

<h2>ReplyMessage</h2>

<fieldset>
    <legend>MessageInformation</legend>

    <div class="display-label">
        <b>@Html.DisplayNameFor(model => model.Tile)</b>
    </div>
    <div class="display-field">
        @Html.DisplayFor(model => model.Tile)
    </div>

    <div class="display-label">
        <b>@Html.DisplayNameFor(model => model.MessageContent)</b>
    </div>
    <div class="display-field">
        @Html.DisplayFor(model => model.MessageContent)
    </div>

    <div class="display-label">
        <b>@Html.DisplayNameFor(model => model.MessageCreatOn)</b>
</div>
    <div class="display-field">
        @Html.DisplayFor(model => model.MessageCreatOn)
    </div>

    <div class="display-label">
        <b>@Html.DisplayNameFor(model => model.NickName)</b>
</div>
    <div class="display-field">
        @Html.DisplayFor(model => model.NickName)
    </div>
    <table style="border:solid;">
        <tr>
            <td colspan="6">
                <legend>ReplyInformation</legend>
            </td>
        </tr>
        @foreach (var item in Model.ReplyList)
        {
            <tr>
                <td>
                    <b>@Html.DisplayNameFor(model => item.Content)</b>
                </td>
                <td>
                    @Html.DisplayFor(model => item.Content)
                </td>
                <td>
                    <b>@Html.DisplayNameFor(model => item.CreatOn)</b>
                </td>
                <td>
                    @Html.DisplayFor(model => item.CreatOn)
                </td>
                <td>
                    <b>@Html.DisplayNameFor(model => item.User.NickName)</b>
                </td>
                <td>
                    @Html.DisplayFor(model => item.User.NickName)
                </td>
            </tr>
        }
    </table>
------------以上的代码实现的是显示数据------------------

------------以下的代码实现的是写入数据到SQL-----------
    @using (Html.BeginForm("InsertReply", "Message"))
    {  

    <legend>ReplyMessage</legend>
     <table>
         <tr>
             <td>
                 Content:@Html.TextBox("Content")
                 @Html.Hidden("Id", Model.messageId)
             </td>
             <td>
                 <input type="submit" value="Reply" />
             </td>
         </tr>
     </table>
    }
----------------------end------------------------------
</fieldset>
<p>
   @Html.ActionLink("Back to List", "ListMessage","Message")
</p>

View层

MvcBbsConnect db = new MvcBbsConnect();

//显示页面数据的Action

        public ActionResult ReplyMessage(int id)
        {
            var message = db.Messages.Where(p => p.Id == id).FirstOrDefault();
            List<Reply> listReply = db.Replys.Where(p => p.Message.Id == id).ToList();

            ReplyMessageViewModel rm = new ReplyMessageViewModel()
            {
                Tile = message.Title,
                MessageContent = message.content,
                MessageCreatOn = message.CreatOn,
                NickName = message.User.NickName,
                ReplyList = listReply
            };
            return View(rm);
        }

        //写入数据到数据库的action
        [HttpPost]
        public ActionResult InsertReply()
        {
            int messageid = int.Parse(Request.Form["Id"].ToString());
            var message = db.Messages.Where(p => p.Id == messageid).FirstOrDefault();
            var user = db.Users.Where(p => p.Email == User.Identity.Name).FirstOrDefault();

            Reply re = new Reply(){
                CreatOn = DateTime.Now,
                User = user,
                Message = message,
                Content = Request.Form["Content"],
                Ip = Request.UserHostAddress.ToString()
            };
            db.Replys.Add(re);
            db.SaveChanges();
            return RedirectToAction("ReplyMessage", "Message", new { Id = messageid});
        }

controller层

2.学到了如何建立一个简单的ASP.NET MVC工程,以及实现简单的CRUD的功能。

3.开始接触了简单的AJAX。

另外,在学习的过程中,还是练习了一下在ASP.NET MVC中如何使用webform时期链接数据库的方法。同时,通过这个网站的开发,我对MVC的关注点分离有了一些体会,同时深刻体会到MVC的前台页面确实比Webform 的页面更简洁,在开发过程中层与层之间的划分,职责更加明确。同时MVC没有了服务器端控件,使得开发的灵活度更大了。

简易留言簿系统的功能基本实现:会员注册,登录。留言的发布,删除,回复留言的发布,删除。但是网站的安全,注册发送确认邮件,前台设计等都还没有实现。

接下来的需要做的是前台页面的设计,同时进行下一个网站(互动媒体学习社区)的工程。

时间: 2024-08-28 15:43:26

简易留言簿系统-ASP.NET MVC (后台基本完成)的相关文章

简易留言簿系统--ASP.NET MVC(文档)

一直都在学习MVC的理论.今天做一个简易的留言簿系统,当做实战的第一个项目.由于前端技术掌握不是很好,所以前端制作最简单的处理. 项目名称:在线留言簿系统. 前端技术:DIV+CSS , AJAX 后台开发技术:ASP.NET MVC + SQL 两大主要模块: 用户模块: 注册(注册信息包括Email,密码,创建时间.需要进行邮箱是否有效验证.) 登录 留言模块: 发布留言(发布留言包括主题,内容,发布时间,ip地址,发布人.) 显示留言 回复留言(回复留言包括 内容,发布时间,ip地址,所关

asp.net mvc后台操作之读写xml控制首页动态页面开关显示

一.背景 在asp.net mvc项目里,用户需要开拓几个活动版面,并以侧栏的方式呈现在首页右侧,几个活动时间不一致,为避免浏览者在活动未开放之时进入未开放的服务页面.因此不仅需要在活动代码中加入限制功能,也需要在前台取消不合时宜的页面的展示.后台效果图: 二.问题分析 要想控制页面开关显示,就得有存储开关信息的介质,将在后台产生的操作记录下来,并在浏览者加载首页之时能读取操作记录并达到控制页面开关的目的.因此,考虑两种介质储存开关记录信息,一是用数据库mysql,二是用xml.考虑到这对数据库

简易留言薄系统-ASP.NET MVC(Model层)

我的开发顺序是从Model层开始.在Model层目前一共有4个类.Model层除MvcBbsContext引用了System.componentModel 与 System.ComponentModel.DataAnnotations,在MvcBbsContext类中引用了System.Data.Entity 1.User 代码: using System;using System.Collections.Generic;using System.Linq;using System.Web;us

ASP.NET MVC后台管理系统之让客户心动的界面

在上一篇博客中介绍了一下我在快速开发框架中一些UI的设计,这篇文章继续往下讲,主要讲下基于BS架构后台管理系统中一些界面的设计思路. 百闻不如一见,demo地址放出来给大家参考一下 地址:http://121.40.148.178:8080/ . 用户名:guest,密码:123456 一.列表页面 列表页面我用的是Jqgrid插件,这个表格插件是开源的,而且功能丰常强大的,有兴趣的朋友可以去看看我系统中的Demo,所有的列表页面都是基于这个插件做的 很多朋友可能感觉用表格插件会比较复杂,其实不

Asp.Net Mvc后台数据验证自测小Demo

*.这里只做后台数据验证,利用mvc数据验证标记验证数据,并获取错误信息提示后页面中. 1.实现效果如下: 2.model类 People.cs using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Linq; using System.Web; namespace WebTest.Areas.Validation.Models { pub

asp.net mvc 后台怎么接受前端返回的array list dictionary

参考了别人的文章,我这样尝试去写: 数据源:memberInRoles 1 var memberInRoles= {}; 2 for(var i=0;i<sureOptions.length;i++){ 3 memberInRoles["memberInRoles["+i+"].UserId"]=sureOptions[i].value; 4 memberInRoles["memberInRoles["+i+"].RoleId&q

ASP.NET MVC后台管理系统精美UI设计

现在越来越多的系统都是BS架构,什么样的界面风格才更加大气.美观.实用呢? 先给大家看一下我自己做的后台系统风格,然后再讲几个主要的界面 地址:http://121.40.148.178:8080/ . 用户名:guest,密码:123456 一.整体部局 现在的管理系统比较流行把界面做得跟CS应用程序很像,让人一眼看去都以为是CS程序,的确那样看起来很大气,很漂亮. 以往的做法,通常是在工作区只能显示一个功能页面,打开一个新的功能以后页面就跳转了,当用户需要同时打开两个功能的时候就很蛋疼,所以

互动媒体学习社区-ASP.NET MVC 后台用户管理模块

在后台用户管理模块中: 用户一共分为三类:0代表注册会员,1代表管理员,2代表超级管理员 页面与功能: 用户列表页. 显示所有用户(管理员,超级管理员) 根据条件查询指定用户(Email,状态)(管理员,超级管理员) 删除用户.(超级管理员) 修改用户状态.(管理员,超级管理员) 跳转至详细页.(管理员,超级管理员) 跳转至新增页面(超级管理员) 用户详细页. 显示用户详细信息. 调整用户类型(超级管理员) 修改用户状态(管理员,超级管理员) 用户新增页面. 新增用户.(超级管理员) 修改密码页

快速构建ASP.NET MVC Admin主页

前言 后台开发人员一般不喜欢调样式,搞半天样式出不来,还要考虑各种浏览器兼容,费心费力不讨好,还好互联网时代有大量的资源共享,避免我们从零开始,现在就来看怎么快速构建一个ASP.NET MVC后台管理admin主页的方法,先看一看最终的效果! 第一步:选择一个合适的admin模板 互联网时代就是资源共享的时代,网上各种前端模板,这里主要是说明怎么把模板整合到我们的ASP.NET MVC项目中,至于模板大家可以自己去选择喜欢的,这里我们选择这个清爽版的AircraftAdmin,首先看看Aircr