商務邏輯層在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下載源檔案。
以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。
以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。