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类
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类
在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>类
在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类
将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();} }}=====================================