中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

ASP.NETCore使用AutoFac依賴注入

實現代碼

成都創新互聯公司是一家網站建設、網站制作,提供網頁設計,網站設計,網站制作,建網站,按需求定制設計,網站開發公司,2013年至今是互聯行業建設者,服務者。以提升客戶品牌價值為核心業務,全程參與項目的網站策劃設計制作,前端開發,后臺程序制作以及后期項目運營并提出專業建議和思路。

1、新建接口類:IRepository.cs,規范各個操作類的都有那些方法,方便管理。

using System;using System.Collections.Generic;using System.Linq;using System.Linq.Expressions;using System.Text;namespace CMS.Entity.Interfaces
{    public  interface IRepository<T> where T:class
    {        /// <summary>
        /// 添加        /// </summary>
        /// <param name="entity">實體對象</param>
        void Add(T entity);        /// <summary>
        /// 更新        /// </summary>
        /// <param name="entity">實體對象</param>
        void Update(T entity);        /// <summary>
        /// 刪除        /// </summary>
        /// <param name="entity">實體對象</param>
        void Delete(T entity);        /// <summary>
        /// 刪除        /// </summary>
        /// <param name="where">條件(lambda表達式)</param>
        void Delete(Expression<Func<T, bool>> where);        /// <summary>
        /// 根據ID獲取一個對象        /// </summary>
        /// <param name="Id">主鍵ID</param>
        /// <returns>對象</returns>
        T GetById(long Id);        /// <summary>
        /// 根據ID獲取一個對象        /// </summary>
        /// <param name="Id">主鍵ID</param>
        /// <returns>對象</returns>
        T GetById(string Id);        /// <summary>
        /// 根據條件獲取一個對象        /// </summary>
        /// <param name="where">條件(lambda表達式)</param>
        /// <returns>對象</returns>
        T Get(Expression<Func<T, bool>> where);        /// <summary>
        /// 獲取所有數據        /// </summary>
        /// <returns>所有數據</returns>
        IQueryable<T> GetAll();        /// <summary>
        /// 根據條件獲取數據        /// </summary>
        /// <param name="where">條件(lambda表達式)</param>
        /// <returns>數據</returns>
        IQueryable<T> GetMany(Expression<Func<T, bool>> where);        /// <summary>
        /// 根據條件獲取記錄數        /// </summary>
        /// <param name="where">條件(lambda表達式)</param>
        /// <returns></returns>
        int GetCount(Expression<Func<T, bool>> where);        /// <summary>
        /// 關閉代理        /// </summary>
        void CloseProxy();        /// <summary>
        /// 打開代理        /// </summary>
        void OpenProxy();        /// <summary>
        /// 是否有指定條件的元素        /// </summary>
        /// <param name="where">條件(lambda表達式)</param>
        /// <returns></returns>
        bool IsHasValue(Expression<Func<T, bool>> where);
    }
}

2、新建倉儲基礎操作類RepositoryBase.cs,注意要一一對應實現IRepositroy接口的方法

using System;using System.Collections.Generic;using System.Text;using System.Linq;namespace CMS.Entity.Interfaces
{    public abstract class BaseRepository<T>  where T: class
    {        private BcmfDBContext db;//數據庫上下文        public BaseRepository(BcmfDBContext _db) {
            db = _db;
        }        public virtual void Save()
        {
            db.SaveChanges();
        }        public  virtual  void Add(T entity)
        {
            db.Set<T>().Add(entity);
        }        public virtual void CloseProxy()
        {
            db.Database.CommitTransaction();
        }        public virtual void Delete(T entity)
        {
            db.Set<T>().Remove(entity);
        }        public virtual void Delete(System.Linq.Expressions.Expression<Func<T, bool>> where)
        {            var dataList = db.Set<T>().Where(where).AsEnumerable();
            db.Set<T>().RemoveRange(dataList);
        }        public virtual T Get(System.Linq.Expressions.Expression<Func<T, bool>> where)
        {           return db.Set<T>().FirstOrDefault(where);
        }        public virtual System.Linq.IQueryable<T> GetAll()
        {            return db.Set<T>();
        }        public virtual T GetById(long Id)
        {            return db.Set<T>().Find(Id);
        }        public virtual T GetById(string Id)
        {            return db.Set<T>().Find(Id);
        }        public virtual int GetCount(System.Linq.Expressions.Expression<Func<T, bool>> where)
        {            return db.Set<T>().Count(where);
        }        public virtual System.Linq.IQueryable<T> GetMany(System.Linq.Expressions.Expression<Func<T, bool>> where)
        {            return db.Set<T>().Where(where);
        }        public virtual bool IsHasValue(System.Linq.Expressions.Expression<Func<T, bool>> where)
        {            return db.Set<T>().Any(where);
        }        public virtual void OpenProxy()
        {
            db.Database.BeginTransaction();
        }        public virtual void Update(T entity)
        {
            db.Set<T>().Attach(entity);
            db.Entry<T>(entity).State = Microsoft.EntityFrameworkCore.EntityState.Modified;
        }
    }
}

3、新建倉儲類TUserRepository與TOperateLogRepository,TUserRepository用于操作用戶表,TOperateLogRepository用于操作用戶記錄表,對應的User類與OperateLog類根據項目需求自行創建

using System;using System.Collections.Generic;using System.Text;using CMS.Entity.Repository;using CMS.Entity.Entity;using Microsoft.EntityFrameworkCore;using System.Linq;using CMS.Entity.Interfaces;namespace CMS.Entity.Repository
{    public class TUserRepository :BaseRepository<User>,IUserRepository
    {        public TUserRepository(BcmfDBContext db) : base(db) { }
    }    public interface IUserRepository : IRepository<User> { }
}
using System;using System.Collections.Generic;using System.Text;using CMS.Entity.Repository;using CMS.Entity.Entity;using Microsoft.EntityFrameworkCore;using System.Linq;using CMS.Entity.Interfaces;namespace CMS.Entity.Repository
{    public class TOperateLogRepository : BaseRepository<OperateLog>, IOperateLogRepository
    {        public TOperateLogRepository(BcmfDBContext db) : base(db) { }
    }    public interface IOperateLogRepository : IRepository<OperateLog>
    {
    }
}

4、分別在UserController與OperateLogController控制器中的構造函數注入倉儲類

using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using Microsoft.AspNetCore.Http;using Microsoft.AspNetCore.Mvc;using CMS.Entity;using CMS.Entity.Entity;using Newtonsoft.Json;using CMS.WebApi.Core;using Microsoft.EntityFrameworkCore.Query;using CMS.Entity.Repository;namespace CMS.WebApi.Controllers
{    /// <summary>
    /// 用戶中心    /// </summary>
    //[Produces("application/json")]
    [Route("api/[controller]")]
    [ApiController]    public class UsersController : ControllerBase
    {        private readonly IUserRepository userRepository;        public UsersController(IUserRepository _userRepository)
        {
            userRepository = _userRepository;
        }        /// <summary>
        /// 獲取用戶列表        /// </summary>
        /// <returns></returns>        [HttpGet]        public string Get()
        {            var userList= userRepository.GetAll().ToList();            return JsonConvert.SerializeObject(userList);
        }
    }
}
using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using Microsoft.AspNetCore.Http;using Microsoft.AspNetCore.Mvc;using CMS.Entity.Repository;using Newtonsoft.Json;namespace CMS.WebApi.Controllers
{
    [Route("api/[controller]")]
    [ApiController]    public class OperateLogController : ControllerBase
    {        private readonly IOperateLogRepository operateLogRepository;        public OperateLogController(IOperateLogRepository _operateLogRepository)
        {
            operateLogRepository = _operateLogRepository;
        }
        [HttpGet]        public string Get()
        {            var result = operateLogRepository.GetMany(m=>m.ActionLogId<100);            return JsonConvert.SerializeObject(result);
        }
    }
}

5、完成上述操作后,運行獲取數據時會系統報錯,那是由于還沒將倉儲類注入到服務中,接下來就實現用AutoFac注入倉儲類到項目服務中

添加引用Autofac,Auto.Configuration,Autofac.Extensions.DependencyInjection到項目中

ASP.NETCore使用AutoFac依賴注入

這里貼出Nuget程序控制臺命令:

Install-Package Autofac -Version 4.9.2
Install-Package Autofac.Configuration -Version 4.1.0
Install-Package Autofac.Extensions.DependencyInjection -Version 4.4.0

6、打開項目Startup.cs,找到ConfigureServices方法,將void改為IServiceProvider返回值,如下

 //先引用命名空間
using Autofac;
using Autofac.Extensions.DependencyInjection;
            
             builder = 
         builder.RegisterAssemblyTypes(=> t.Name.EndsWith( container =

7、重新生成發布項目,完成

網頁標題:ASP.NETCore使用AutoFac依賴注入
網站地址:http://m.2m8n56k.cn/article22/ihghjc.html

成都網站建設公司_創新互聯,為您提供企業建站App設計網站制作網站設計定制網站自適應網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設
主站蜘蛛池模板: 美女黄18 | 91免费国产高清观看 | 日本高清在线精品一区二区三区 | 五月色婷婷综合开心网4438 | 美女张开腿让我 | 亚洲欧美国产精品久久久 | 成年人在线看片 | 亚洲一区二区三区久久久久 | 成人免费小视频 | 美美女高清毛片视频免费观看 | 日本一在线中文字幕天堂 | aaa在线观看高清免费 | 亚洲国产小视频 | 亚洲欧洲一区二区三区久久 | 日韩综合 | 国产99视频精品一区 | 伊人色综合久久天天人手人停 | 国产免费自拍视频 | 狠狠88综合久久久久综合网 | 国产成人精品午夜二三区 | 亚洲成人午夜影院 | 亚洲综合视频网 | 日韩美女在线视频 | 手机在线看a | 欧美视频在线一区 | 国产a级精品特黄毛片 | avhd101天天看新片 | 国产精品va一级二级三级 | 亚洲成人在线免费 | 欧毛片 | 国产一区二区三区久久精品小说 | 欧美大片一级毛片 | 99国产精品免费视频观看 | 99精品视频在线视频免费观看 | 国产午夜三级 | 伊人久久大香线焦综合四虎 | 久久91精品牛牛 | 亚洲系列第一页 | 亚洲乱人伦精品图片 | 国产成人v视频在线观看 | 97久久精品国产精品青草 |