ASP.NET MVC5网站开发之业务逻辑层的架构和基本功能 (四)
业务逻辑层在Ninesky.Core中实现,主要功能封装一些方法通过调用数据存储层,向界面层提供服务。
一、业务逻辑层的架构
Ninesky.Core包含三个命名空间Ninesky.Core、Ninesky.Core.Types、Ninesky.Core.General.
Ninesky.Core包含模型和功能实现,Ninesky.Core.Types是项目用到的一些类型的定义,Ninesky.Core.General是项目用到的一些方法的定义。
1、Ninesky.Core命名空间的结构
NineskyContext-数据上下文
ContextFactory- 获取数据上下文的工厂类
BaseManager-基础类,实现了一些常用数据访问方法,提供其他管理类继承。
Category-栏目模型。
CategoryManager-栏目管理类。
Content-内容模型。
ContentManager-内容管理类。
User-用户模型
UserManager-用户管理类
Administrator-管理员类
AdministratorManager-管理员管理类
2、Ninesky.Core.Types命名空间的结构
Response 响应返回类。
Paging<T> 分页数据类。
二、基础功能的实现
1、添加引用
(1)、添加EntityFramewok 引用
Ninesky.Core项目->引用【右键】 –>管理NuGet程序包
在NuGet包管理对器话框中选择 EntityFramewok 并安装。
(2)、添加Ninesky.DataLibrary项目的引用
Ninesky.Core项目->引用【右键】 –>添加引用
在引用管理器中选择 项目->解决方案->Ninesky.DataLibrary,点击确定。
2、NineskyContext类
NineskyContext类是项目的数据数据上下文,使模型和数据库的表进行对应。
Ninesky.Core项目【右键】->添加->类, 输入类名NineskyContext。
在类中引入命名空间System.Data.Entity;
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Data.Entity; namespace Ninesky.Core { public class NineskyContext:DbContext { public NineskyContext():base("DefaultConnection") { Database.SetInitializer<NineskyContext>(new CreateDatabaseIfNotExists<NineskyContext>()); } } }
3、ContextFactory类
ContextFactory是一个简单工厂类,CurrentContext()是一个静态函数,用来获取当前线程DbContext。
Ninesky.Core项目【右键】->添加->类, 输入类名ContextFactory。
在类中添加对System.Runtime.Remoting.Messaging的引用。在类中实现CurrentContext()静态方法返回数据上下文NineskyContext。方法中通过CallContext类在线程中存储NineskyContext。
using System.Runtime.Remoting.Messaging; namespace Ninesky.Core { /// <summary> /// 数据上下文工厂 /// </summary> public class ContextFactory { /// <summary> /// 获取当前线程的数据上下文 /// </summary> /// <returns>数据上下文</returns> public static NineskyContext CurrentContext() { NineskyContext _nContext = CallContext.GetData("NineskyContext") as NineskyContext; if (_nContext == null) { _nContext = new NineskyContext(); CallContext.SetData("NineskyContext", _nContext); } return _nContext; } } }
4、Response类
Response类是一个常用的方法返回数据类型,包含返回代码、返回消息和返回数据3个属性。
在Ninesky.Core项目[右键]新建文件夹,输入名称Types。
在Types文件夹[右键]->添加->类,在弹出的添加新项对话框中输入类名Response。代码如下:
namespace Ninesky.Core.Types { /// <summary> /// /// </summary> public class Response { /// <summary> /// 返回代码. 0-失败,1-成功,其他-具体见方法返回值说明 /// </summary> public int Code { get; set; } /// <summary> /// 返回消息 /// </summary> public string Message { get; set; } /// <summary> /// 返回数据 /// </summary> public dynamic Data { get; set; } public Response() { Code = 0; } } }
5、Paging<T>类
Paging<T>类是一个查询分页数据时使用的类,包含当前页、每页记录数、总记录数、和当前页数据列表等几个属性。
在Types文件夹[右键]->添加->类,在弹出的添加新项对话框中输入类名Paging。代码如下:
using System.Collections.Generic; namespace Ninesky.Core.Types { public class Paging<T> { /// <summary> /// 当前页。从1计数 /// </summary> public int PageIndex { get; set; } /// <summary> /// 每页记录数。默认20 /// </summary> public int PageSize { get; set; } /// <summary> /// 总记录数 /// </summary> public int TotalNumber;/// <summary> /// 当前页记录列表 /// </summary> public List<T> Items { get; set; } public Paging() { PageIndex = 1; PageSize = 20; } } }
6、BaseManager类
BaseManager类是所有管理类的基类,此类包含了管理类的常用方法。
将Ninesky.Core项目的Class1.cs重命名为BaseManager.cs
引入命名空间System.Data.Entity和Ninesky.Core.Types,实现共有方法。
using Ninesky.Core.Types; using Ninesky.DataLibrary; using System.Data.Entity; using System.Linq; namespace Ninesky.Core { /// <summary> /// 管理类的基类 /// </summary> /// <typeparam name="T">模型类</typeparam> public abstract class BaseManager<T> where T :class { /// <summary> /// 数据仓储类 /// </summary> protected Repository<T> Repository; /// <summary> /// 默认构造函数 /// </summary> public BaseManager():this(ContextFactory.CurrentContext()) { } /// <summary> /// 构造函数 /// </summary> /// <param name="dbContext">数据上下文</param> public BaseManager(DbContext dbContext){ Repository = new Repository<T>(dbContext); } /// <summary> /// 添加 /// </summary> /// <param name="entity">实体数据</param> /// <returns>成功时属性【Data】为添加后的数据实体</returns> public virtual Response Add(T entity) { Response _response = new Response(); if(Repository.Add(entity)>0) { _response.Code = 1; _response.Message = "添加数据成功!"; _response.Data = entity; } else { _response.Code = 0; _response.Message = "添加数据失败!"; } return _response; } /// <summary> /// 更新 /// </summary> /// <param name="entity">实体数据</param> /// <returns>成功时属性【Data】为更新后的数据实体</returns> public virtual Response Update(T entity) { Response _response = new Response(); if (Repository.Update(entity) > 0) { _response.Code = 1; _response.Message = "更新数据成功!"; _response.Data = entity; } else { _response.Code = 0; _response.Message = "更新数据失败!"; } return _response; } /// <summary> /// 删除 /// </summary> /// <param name="ID">主键</param> /// <returns>Code:0-删除失败;1-删除陈功;10-记录不存在</returns> public virtual Response Delete(int ID) { Response _response = new Response(); var _entity = Find(ID); if (_entity == null) { _response.Code = 10; _response.Message = "记录不存在!"; } else { if (Repository.Delete(_entity) > 0) { _response.Code = 1; _response.Message = "删除数据成功!"; } else { _response.Code = 0; _response.Message = "删除数据失败!"; } } return _response; } /// <summary> /// 查找实体 /// </summary> /// <param name="ID">主键</param> /// <returns>实体</returns> public virtual T Find(int ID) { return Repository.Find(ID); } /// <summary> /// 查找数据列表-【所有数据】 /// </summary> /// <returns>所有数据</returns> public IQueryable<T> FindList() { return Repository.FindList(); } /// <summary> /// 查找分页数据 /// </summary> /// <param name="paging">分页数据</param> /// <returns>分页数据</returns> public Paging<T> FindPageList(Paging<T> paging) { paging.Items = Repository.FindPageList(paging.PageSize, paging.PageIndex, out paging.TotalNumber).ToList(); return paging; } /// <summary> /// 总记录数 /// </summary> /// <returns>总记录数</returns> public virtual int Count() { return Repository.Count(); } } }
=====================================
代码见:https://ninesky.codeplex.com/SourceControl/latest
代码下载:https://ninesky.codeplex.com 点击SOURCE CODE 点击Download下载源文件。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持猪先飞。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持猪先飞。
相关文章
- 这篇文章主要为大家详细介绍了ASP.NET购物车的实现过程,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-22
- 在开发过程中,使用Visual Studio的断点调试功能可以很方便帮我们调试发现程序存在的错误,同样Visual Studio也支持对SQL Server里面的存储过程进行调试,下面就让我们看看具体的调试方法。...2021-09-22
- 获取网站icon,常用最简单的方法就是通过website/favicon.ico来获取,不过由于很多网站都是在页面里面设置favicon,所以此方法很多情况都不可用。 更好的办法是通过google提供的服务来实现:http://www.google.com/s2/favi...2014-06-07
mac下Apache + MySql + PHP搭建网站开发环境
首先为什不自己分别搭建Apache,PHP和MySql的环境呢?这样自己可以了解更多知识,说起来也更酷。可也许因为我懒吧,我是那种“既然有现成的,用就是了”的人。君子生非异也,善假于物也。两千年前的荀子就教导我们,要善于利用工具...2014-06-07ASP.NET Core根据环境变量支持多个 appsettings.json配置文件
这篇文章主要介绍了ASP.NET Core根据环境变量支持多个 appsettings.json配置文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-09-22- 这篇文章主要介绍了记一次EFCore类型转换错误及解决方案,帮助大家更好的理解和学习使用asp.net core,感兴趣的朋友可以了解下...2021-09-22
- 我要实现的就是下图的这种样式,可参考下面这两个网站的留言板,他们的实现原理都是一样的畅言留言板样式:网易跟帖样式:原理 需要在评论表添加两个主要字段 id 和 pid ,其他字段随意添加,比如文章id、回复时间、回复内容、...2015-11-08
网站广告怎么投放最好?首屏广告投放类型优化和广告位布局优化的案例
网站广告怎么投放最好?一个网站中广告位置最好的是哪几个地方呢,许多的朋友都不知道如何让自己的网站广告收效最好了,今天我们就一起来看看吧。 在说到联盟优化前,...2016-10-10详解ASP.NET Core 中基于工厂的中间件激活的实现方法
这篇文章主要介绍了ASP.NET Core 中基于工厂的中间件激活的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-09-22asp.net通过消息队列处理高并发请求(以抢小米手机为例)
这篇文章主要介绍了asp.net通过消息队列处理高并发请求(以抢小米手机为例),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-09-22ASP.NET单选按钮控件RadioButton常用属性和方法介绍
RadioButton又称单选按钮,其在工具箱中的图标为 ,单选按钮通常成组出现,用于提供两个或多个互斥选项,即在一组单选钮中只能选择一个...2021-09-22ASP.NET 2.0中的数据操作:使用两个DropDownList过滤的主/从报表
在前面的指南中我们研究了如何显示一个简单的主/从报表, 该报表使用DropDownList和GridView控件, DropDownList填充类别,GridView显示选定类别的产品. 这类报表用于显示具有...2016-05-19- 个人网站建设应该考虑哪些问题呢?这个问题我们先在这里不说,下文会一一列出来,希望这些建义能帮助到各位同学哦。 我相信VIP成员里面有很多站长,每个人几乎都拥有一个...2016-10-10
ASP.NET中iframe框架点击左边页面链接 右边显示链接页面内容
这篇文章主要介绍了ASP.NET中iframe框架点击左边页面链接,右边显示链接页面内容的实现代码,感兴趣的小伙伴们可以参考一下...2021-09-22- ASP.NET Web API具有与ASP.NET MVC类似的编程方式,ASP.NET Web API不仅仅具有一个完全独立的消息处理管道,而且这个管道比为ASP.NET MVC设计的管道更为复杂,功能也更为强大。下面创建一个简单的Web API项目,需要的朋友可以参考下...2021-09-22
- 这篇文章主要介绍了ASP.NET连接MySql数据库的2个方法及示例,使用的是MySQL官方组件和ODBC.NET,需要的朋友可以参考下...2021-09-22
- 分享一篇利用论坛签名提升网站权重的方法,在推广中论坛签名也是一种不错的外链推荐的方法,但现在权重越来越低了,有需要的朋友可以看看。 话说有一天在站长网上面看...2016-10-10
- 一、靠前排名成搜索关注的对象 从搜索引擎的角度考虑一下,就不难理解为什么搜索引擎对排名在首页的网站那么慎重,甚至对新进排名在首页的一些网站进行为期一个多月的...2016-10-10
- 这篇文章主要介绍了Asp.Net使用Bulk实现批量插入数据的方法,对于进行asp.net数据库程序设计非常有借鉴价值,需要的朋友可以参考下...2021-09-22
- 这篇文章主要介绍了获取DataTable选择第一行某一列值,需要的朋友可以参考下...2021-09-22