IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> ABP vnext 应用服务知识整理 -> 正文阅读

[开发工具]ABP vnext 应用服务知识整理

使用

用法
ICrudAppService创建应用服务例3
IAsyncCrudAppService例1
IApplicationService创建应用服务例2
获取服务例4

例1

为Task实体创建一个CRUD应用服务

  1. Task.cs

    public class Task : Entity, IHasCreationTime
    {
        public string Title { get; set; }
        public string Description { get; set; }
        public DateTime CreationTime { get; set; }
        public TaskState State { get; set; }
        public Person AssignedPerson { get; set; }
        public Guid? AssignedPersonId { get; set; }
        public Task()
        {
            CreationTime = Clock.Now;
            State = TaskState.Open;
        }
    }
    
  2. 为该Task实体创建一个DTO

    [AutoMap(typeof(Task))]//用AutoMap特性,自动创建实体和DTO的映射配置
    public class TaskDto : EntityDto, IHasCreationTime
    {
        public string Title { get; set; }
        public string Description { get; set; }
        public DateTime CreationTime { get; set; }
        public TaskState State { get; set; }
        public Guid? AssignedPersonId { get; set; }
        public string AssignedPersonName { get; set; }
    }
    
  3. 创建应用服务接口类
    ITaskAppService.cs

    public interface ITaskAppService : IAsyncCrudAppService<TaskDto>
    { }
    
  4. 实现应用服务接口类
    TaskAppService.cs

    public class TaskAppService : AsyncCrudAppService<Task, TaskDto>,ITaskAppService
    {
        public TaskAppService(IRepository<Task> repository)
        : base(repository)//注入了仓储并且传递该参数给基类
        { }
    }
    

例2

  1. Application.Contracts\XXXs\IXXXAppService.cs
/// <summary>
/// 管理服务接口
/// </summary>
public interface IXXXAppService : IApplicationService
{
    /// <summary>
    /// 新增数据
    /// </summary>
    /// <param name="model">参数模型</param>
    /// <returns>新增操作结果</returns>
    Task<bool> InsertAsync(XXXDto model);

    /// <summary>
    /// 删除数据
    /// </summary>
    /// <param name="id">id</param>
    /// <returns>删除操作结果</returns>
    Task<bool> DeleteAsync(Guid id);

    /// <summary>
    /// 更新数据
    /// </summary>
    /// <param name="model">参数模型</param>
    /// <returns>更新操作结果</returns>
    Task<bool> UpdateAsync(XXXDto model);

    /// <summary>
    /// 根据id查询
    /// </summary>
    /// <param name="id">id</param>
    /// <returns>查询结果</returns>
    Task<XXXDto> GetAsync(Guid id);
    
    /// <summary>
    /// 获取分页
    /// </summary>
    /// <param name="dto">分页请求Dto</param>
    /// <returns>分页结果</returns>
    Task<PagedResultDto<XXXDto>> GetPagedListAsync(PagedResultRequestDto dto);
}
  1. Application\XXXs\XXXAppService.cs
public class XXXAppService : XXXXAppService, IXXXAppService
{
    /// <summary>
    /// 仓储
    /// </summary>
    private readonly IXXXRepository repository;
    
    /// <summary>
    /// Guid生成器
    /// </summary>
    private readonly IGuidGenerator guidGenerator;
    
    /// <summary>
    /// 初始化
    /// </summary>
    public XXXAppService(IXXXRepository repository,IGuidGenerator guidGenerator)
    {
        this.repository = repository;
        this.guidGenerator = guidGenerator;
    }
    
    /// <summary>
    /// 新增数据
    /// </summary>
    /// <param name="model">参数模型</param>
    /// <returns>新增操作结果</returns>
    public async Task<bool> InsertAsync(XXXDto model)
    {
        var newEntity = new XXX(GuidGenerator.Create(), model.Name, model.Author, model.Type);
        EntityHelper.TrySetId((IEntity<Guid>)newEntity, () => guidGenerator.Create());
        await repository.InsertAsync(newEntity);
        return true;
    }
    
    /// <summary>
    /// 新增多条数据
    /// </summary>
    /// <param name="modelList">参数模型列表</param>
    /// <returns>新增操作结果</returns>
    public async Task<bool> InsertManyAsync(List<XXXDto> modelList)
    {
        var newEntityList = ObjectMapper.Map<List<XXXDto>, List<XXX>>(modelList);
        foreach (var entity in newEntityList)
        {
            EntityHelper.TrySetId(entity, () => guidGenerator.Create());
            var find = await repository.FindAsync(p => p.SourceTable == entity.SourceTable && p.TargetTable == entity.TargetTable);
            if (find != default)
            {
                continue;
            }
            await repository.InsertAsync(entity, true);
        }
        return true;
    }

    
    /// <summary>
    /// 删除数据
    /// </summary>
    /// <param name="id">id</param>
    /// <returns>删除操作结果</returns>
    public async Task<bool> DeleteAsync(Guid id)
    {
        var find = await repository.FindAsync(id);
        if (find == default)
        {
            throw new BusinessException("要删除的记录不存在!");
        }
        await repository.DeleteAsync(find, true);
        return true;
    }
    
    /// <summary>
    /// 删除所有数据
    /// </summary>
    /// <returns>删除操作结果</returns>
    public async Task<bool> DeleteManyAsync()
    {
        var list = (await repository.GetListAsync()).Select(x => x.Id).ToList();
        await repository.DeleteManyAsync(list,true);
        return true;
    }
    
    /// <summary>
    /// 更新数据
    /// </summary>
    /// <param name="model">参数模型</param>
    /// <returns>更新操作结果</returns>
    public async Task<bool> UpdateAsync(XXXDto model)
    {
        var find = await repository.FindAsync(model.Id);
        if (find == default)
        {
            throw new BusinessException("要修改的记录不存在");
        }
        find.Update(
            model.Config,
            model.RegisterType,
            model.RegisterSubtype,
            model.SingleCertificate,
            model.Batch,
            model.Media,model.CustomizeQuery,
            ObjectMapper.Map<List<ParameterConfigurationDto>, List<ParameterConfiguration>>(model.ParameterConfig)
        );
        await repository.UpdateAsync(find);
        return true;
    }
    
    /// <summary>
    /// 根据id查询
    /// </summary>
    /// <param name="id">id</param>
    /// <returns>查询结果</returns>
    public async Task<XXXDto> GetAsync(Guid id)
    {
        var find = await repository.FindAsync(id);
        if (find == default)
        {
            throw new BusinessException("所查询的记录不存在");
        }
        return ObjectMapper.Map<XXX,XXXDto>(find);
    }
    
    /// <summary>
    /// 获取分页
    /// </summary>
    /// <param name="dto">分页请求Dto</param>
    /// <returns>分页结果</returns>
    public PagedResultDto<XXXDto> GetPagedList(PagedResultRequestDto dto)
    {
        var count = repository.Count();
        var t = repository
            .Where(
             x=> !x.IsDeleted)
            .OrderByDescending(x => x.RegisterType)
            .PageBy(dto)
            .ToList();
        return new PagedResultDto<XXXDto> {
            TotalCount = count,
            Items = ObjectMapper.Map<List<XXX>, List<XXXDto>>(t)
        };
    }
    
    /// <summary>
    /// 异步获取分页
    /// </summary>
    /// <param name="dto">分页请求Dto</param>
    /// <returns>分页结果</returns>
    public async Task<PagedResultDto<EnterpriseInfoDto>> GetPagedList(PagedResultRequestDto dto)
    {
        var count = await repository.GetCountAsync();
        var t = await repository.GetPagedListAsync(dto.SkipCount,dto.MaxResultCount,nameof(RegisterTypeConfig.TemplateId));
        return new PagedResultDto<EnterpriseInfoDto>
        {
            TotalCount = count,
            Items = ObjectMapper.Map<List<EnterpriseInfo>, List<EnterpriseInfoDto>>(t)
        };
    }

}

例3

  1. Application\Books\BookAppService.cs
public interface IBookAppService :
        ICrudAppService< //Defines CRUD methods
            BookDto, //Used to show books
            Guid, //Primary key of the book entity
            PagedAndSortedResultRequestDto, //Used for paging/sorting
            CreateUpdateBookDto> //Used to create/update a book
{
}
  1. Application.Contracts\Books\IBookAppService.cs
public class BookAppService :
CrudAppService< //CrudAppService实现 `ICrudAppService` 定义的CRUD方法
    Book, //The Book entity
    BookDto, //Used to show books
    Guid, //Primary key of the book entity
    PagedAndSortedResultRequestDto, //Used for paging/sorting
    CreateUpdateBookDto>, //Used to create/update a book
IBookAppService //implement the IBookAppService
{
    public BookAppService(IRepository<Book, Guid> repository)
        : base(repository)
    {
    }
}

例4

利用IServiceProvider获取服务

public class UserService<T> : IUserService<T> where T : IUserMessage
{
    private readonly IServiceProvider _serviceProvider;
 
    public UserService(ServiceProvider serviceProvider)
    {
         _serviceProvider = serviceProvider;
    }
 
    public async Task UpdateUser(int id)
    {
        var userRoleService = _serviceProvider.GetRequiredService<IUserRoleService>();
        var roles = await userRoleService.GetRoleForUser(id);
    }
}
  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-05-09 12:56:36  更:2022-05-09 12:57:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/14 15:08:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码