好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > ASP.NET MVC5網站開發之業務邏輯層的架構和基本功能 (四)

ASP.NET MVC5網站開發之業務邏輯層的架構和基本功能 (四)

熱門標簽:廣西房產智能外呼系統推薦 威力最大的電銷機器人 地圖標注位置怎么弄圖 400電話唐山辦理 電銷專用外呼線路 旅游地圖標注線路 電銷外呼系統是違法的嗎 電話機器人鑰匙扣 漯河外呼調研線路

業務邏輯層在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 響應返回類。

PagingT> 分頁數據類。

二、基礎功能的實現

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.SetInitializerNineskyContext>(new CreateDatabaseIfNotExistsNineskyContext>());
  }
 }
}

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、PagingT>類

PagingT>類是一個查詢分頁數據時使用的類,包含當前頁、每頁記錄數、總記錄數、和當前頁數據列表等幾個屬性。

在Types文件夾[右鍵]->添加->類,在彈出的添加新項對話框中輸入類名Paging。代碼如下:

using System.Collections.Generic;

namespace Ninesky.Core.Types
{
 public class PagingT>
 {
  /// summary>
  /// 當前頁。從1計數
  /// /summary>
  public int PageIndex { get; set; }

  /// summary>
  /// 每頁記錄數。默認20
  /// /summary>
  public int PageSize { get; set; }

  /// summary>
  /// 總記錄數
  /// /summary>
  public int TotalNumber;/// summary>
  /// 當前頁記錄列表
  /// /summary>
  public ListT> 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 BaseManagerT> where T :class
 {
  /// summary>
  /// 數據倉儲類
  /// /summary>
  protected RepositoryT> Repository;

  /// summary>
  /// 默認構造函數
  /// /summary>
  public BaseManager():this(ContextFactory.CurrentContext())
  {
  }
  /// summary>
  /// 構造函數
  /// /summary>
  /// param name="dbContext">數據上下文/param>
  public BaseManager(DbContext dbContext){
   Repository = new RepositoryT>(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 IQueryableT> FindList()
  {
   return Repository.FindList();
  }

  /// summary>
  /// 查找分頁數據
  /// /summary>
  /// param name="paging">分頁數據/param>
  /// returns>分頁數據/returns>
  public PagingT> FindPageList(PagingT> 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下載源文件。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • java學生信息管理系統MVC架構詳解
  • SpringMVC架構的項目 js,css等靜態文件導入有問題的解決方法
  • thinkPHP5.0框架整體架構總覽【應用,模塊,MVC,驅動,行為,命名空間等】
  • SpringMVC互聯網軟件架構REST使用詳解
  • mvc架構實現商品的購買(二)
  • ASP.NET MVC5網站開發之展示層架構(五)
  • ssi框架學習總結(mvc三層架構)
  • PHP MVC模式在網站架構中的實現分析
  • MayFish PHP的MVC架構的開發框架
  • SpringMVC MVC架構原理及實現方法詳解

標簽:無錫 銅陵 湖北 焦作 湘西 欽州 試駕邀約 綏化

巨人網絡通訊聲明:本文標題《ASP.NET MVC5網站開發之業務邏輯層的架構和基本功能 (四)》,本文關鍵詞  ASP.NET,MVC5,網,站開,發之,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP.NET MVC5網站開發之業務邏輯層的架構和基本功能 (四)》相關的同類信息!
  • 本頁收集關于ASP.NET MVC5網站開發之業務邏輯層的架構和基本功能 (四)的相關信息資訊供網民參考!
  • 推薦文章