通用数据控制器

This commit is contained in:
陈淳
2022-09-28 18:05:49 +08:00
parent 4796a494de
commit 87a685b823
10 changed files with 155 additions and 80 deletions

View File

@@ -114,6 +114,24 @@
<param name="ids"></param> <param name="ids"></param>
<returns></returns> <returns></returns>
</member> </member>
<member name="M:Yi.Framework.ApiMicroservice.Controllers.BaseExcelController`1.Template">
<summary>
下载模板
</summary>
<returns></returns>
</member>
<member name="M:Yi.Framework.ApiMicroservice.Controllers.BaseExcelController`1.Export">
<summary>
导出数据
</summary>
<returns></returns>
</member>
<member name="M:Yi.Framework.ApiMicroservice.Controllers.BaseExcelController`1.Import(Microsoft.AspNetCore.Http.IFormFile)">
<summary>
导入数据
</summary>
<returns></returns>
</member>
<member name="T:Yi.Framework.ApiMicroservice.Controllers.BaseSimpleCrudController`1"> <member name="T:Yi.Framework.ApiMicroservice.Controllers.BaseSimpleCrudController`1">
<summary> <summary>
Json To Sql 类比模式,通用模型 Json To Sql 类比模式,通用模型
@@ -465,18 +483,6 @@
用户管理 用户管理
</summary> </summary>
</member> </member>
<member name="M:Yi.Framework.ApiMicroservice.Controllers.UserController.Template">
<summary>
下载模板
</summary>
<returns></returns>
</member>
<member name="M:Yi.Framework.ApiMicroservice.Controllers.UserController.Export">
<summary>
导出数据
</summary>
<returns></returns>
</member>
<member name="M:Yi.Framework.ApiMicroservice.Controllers.UserController.PageList(Yi.Framework.Model.Models.UserEntity,Yi.Framework.Common.Models.PageParModel,System.Nullable{System.Int64})"> <member name="M:Yi.Framework.ApiMicroservice.Controllers.UserController.PageList(Yi.Framework.Model.Models.UserEntity,Yi.Framework.Common.Models.PageParModel,System.Nullable{System.Int64})">
<summary> <summary>
动态条件分页查询 动态条件分页查询

View File

@@ -16,16 +16,14 @@ namespace Yi.Framework.ApiMicroservice.Controllers
/// </summary> /// </summary>
/// <typeparam name="T"></typeparam> /// <typeparam name="T"></typeparam>
[ApiController] [ApiController]
public class BaseCrudController<T> : ControllerBase where T : class,new() public class BaseCrudController<T> : BaseExcelController<T> where T : class,new()
{ {
private readonly ILogger<T> _logger; protected readonly ILogger<T> _logger;
private IBaseService<T> _baseService; protected IBaseService<T> _baseService;
private IRepository<T> _repository; public BaseCrudController(ILogger<T> logger, IBaseService<T> iBaseService):base(iBaseService._repository)
public BaseCrudController(ILogger<T> logger, IBaseService<T> iBaseService)
{ {
_logger = logger; _logger = logger;
_baseService = iBaseService; _baseService = iBaseService;
_repository = iBaseService._repository;
} }
/// <summary> /// <summary>

View File

@@ -0,0 +1,76 @@
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Localization;
using Yi.Framework.Common.Const;
using Yi.Framework.Common.Enum;
using Yi.Framework.Common.Helper;
using Yi.Framework.Common.Models;
using Yi.Framework.Interface;
using Yi.Framework.Language;
using Yi.Framework.Model.Models;
using Yi.Framework.Model.Query;
using Yi.Framework.Repository;
using Yi.Framework.WebCore.AttributeExtend;
namespace Yi.Framework.ApiMicroservice.Controllers
{
[ApiController]
public class BaseExcelController<T> : ControllerBase where T : class, new()
{
protected IRepository<T> _repository;
public BaseExcelController(IRepository<T> repository)
{
_repository = repository;
}
/// <summary>
/// 下载模板
/// </summary>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public IActionResult Template()
{
List<T> users = new();
var fileName = nameof(T) + PathConst.DataTemplate;
var path = ExcelHelper.DownloadImportTemplate(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Excel.ToString()));
var file = System.IO.File.OpenRead(path);
return File(file, "text/plain", $"{DateTime.Now.ToString("yyyyMMddHHmmssffff") + fileName }.xlsx");
}
/// <summary>
/// 导出数据
/// </summary>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public async Task<IActionResult> Export()
{
var users = await _repository.GetListAsync();
var fileName = DateTime.Now.ToString("yyyyMMddHHmmssffff") + nameof(T) + PathConst.DataExport;
var path = ExcelHelper.ExportExcel(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Temp.ToString()));
var file = System.IO.File.OpenRead(path);
return File(file, "text/plain", $"{ fileName }.xlsx");
}
/// <summary>
/// 导入数据
/// </summary>
/// <returns></returns>
[HttpPost]
[AllowAnonymous]
public async Task<Result> Import(IFormFile formFile)
{
List<T> datas = ExcelHelper.ImportData<T>(formFile.OpenReadStream());
//全量删除在重新插入
var res = await _repository.UseTranAsync(async () =>
{
await _repository.DeleteAsync(u => true);
await _repository.InsertRangeAsync(datas);
});
return Result.Success().SetStatus(res);
}
}
}

View File

@@ -16,16 +16,14 @@ namespace Yi.Framework.ApiMicroservice.Controllers
/// </summary> /// </summary>
/// <typeparam name="T"></typeparam> /// <typeparam name="T"></typeparam>
[ApiController] [ApiController]
public class BaseSimpleCrudController<T> : ControllerBase where T : class, new() public class BaseSimpleCrudController<T> : BaseExcelController<T> where T : class, new()
{ {
private readonly ILogger<T> _logger; protected readonly ILogger<T> _logger;
private IBaseService<T> _baseService; protected IBaseService<T> _baseService;
private IRepository<T> _repository; public BaseSimpleCrudController(ILogger<T> logger, IBaseService<T> iBaseService):base(iBaseService._repository)
public BaseSimpleCrudController(ILogger<T> logger, IBaseService<T> iBaseService)
{ {
_logger = logger; _logger = logger;
_baseService = iBaseService; _baseService = iBaseService;
_repository = iBaseService._repository;
} }
/// <summary> /// <summary>

View File

@@ -16,16 +16,14 @@ namespace Yi.Framework.ApiMicroservice.Controllers
/// </summary> /// </summary>
/// <typeparam name="T"></typeparam> /// <typeparam name="T"></typeparam>
[ApiController] [ApiController]
public class BaseSimpleRdController<T> : ControllerBase where T : class, new() public class BaseSimpleRdController<T> : BaseExcelController<T> where T : class, new()
{ {
private readonly ILogger<T> _logger; protected readonly ILogger<T> _logger;
private IBaseService<T> _baseService; protected IBaseService<T> _baseService;
private IRepository<T> _repository; public BaseSimpleRdController(ILogger<T> logger, IBaseService<T> iBaseService):base(iBaseService._repository)
public BaseSimpleRdController(ILogger<T> logger, IBaseService<T> iBaseService)
{ {
_logger = logger; _logger = logger;
_baseService = iBaseService; _baseService = iBaseService;
_repository = iBaseService._repository;
} }
/// <summary> /// <summary>

View File

@@ -37,58 +37,58 @@ namespace Yi.Framework.ApiMicroservice.Controllers
//数据导入导出将会被写入到基类 //数据导入导出将会被写入到基类
/// <summary> ///// <summary>
/// 下载模板 ///// 下载模板
/// </summary> ///// </summary>
/// <returns></returns> ///// <returns></returns>
[HttpGet] //[HttpGet]
[AllowAnonymous] //[AllowAnonymous]
public IActionResult Template() //public IActionResult Template()
{ //{
List<UserEntity> users = new(); // List<UserEntity> users = new();
var fileName = nameof(UserEntity) + PathConst.DataTemplate; // var fileName = nameof(UserEntity) + PathConst.DataTemplate;
var path = ExcelHelper.DownloadImportTemplate(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Excel.ToString())); // var path = ExcelHelper.DownloadImportTemplate(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Excel.ToString()));
var file = System.IO.File.OpenRead(path); // var file = System.IO.File.OpenRead(path);
return File(file, "text/plain", $"{DateTime.Now.ToString("yyyyMMddHHmmssffff") + fileName }.xlsx"); // return File(file, "text/plain", $"{DateTime.Now.ToString("yyyyMMddHHmmssffff") + fileName }.xlsx");
} //}
/// <summary> ///// <summary>
/// 导出数据 ///// 导出数据
/// </summary> ///// </summary>
/// <returns></returns> ///// <returns></returns>
[HttpGet] //[HttpGet]
[AllowAnonymous] //[AllowAnonymous]
public async Task<IActionResult> Export() //public async Task<IActionResult> Export()
{ //{
var users = await _iUserService._repository.GetListAsync(); // var users = await _iUserService._repository.GetListAsync();
var fileName = DateTime.Now.ToString("yyyyMMddHHmmssffff") + nameof(UserEntity) + PathConst.DataExport; // var fileName = DateTime.Now.ToString("yyyyMMddHHmmssffff") + nameof(UserEntity) + PathConst.DataExport;
var path = ExcelHelper.ExportExcel(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Temp.ToString())); // var path = ExcelHelper.ExportExcel(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Temp.ToString()));
var file = System.IO.File.OpenRead(path); // var file = System.IO.File.OpenRead(path);
return File(file, "text/plain", $"{ fileName }.xlsx"); // return File(file, "text/plain", $"{ fileName }.xlsx");
} //}
/// <summary> ///// <summary>
/// 导入数据 ///// 导入数据
/// </summary> ///// </summary>
/// <returns></returns> ///// <returns></returns>
[HttpGet] //[HttpPost]
[AllowAnonymous] //[AllowAnonymous]
public async Task<Result> Import([FromForm(Name = "file")] IFormFile formFile) //public async Task<Result> Import(IFormFile formFile)
{ //{
List<UserEntity> users = ExcelHelper.ImportData<UserEntity>(formFile.OpenReadStream()); // List<UserEntity> users = ExcelHelper.ImportData<UserEntity>(formFile.OpenReadStream());
var _repository = _iUserService._repository; // var _repository = _iUserService._repository;
//全量删除在重新插入 // //全量删除在重新插入
var res = await _repository.UseTranAsync(async () => // var res = await _repository.UseTranAsync(async () =>
{ // {
await _repository.DeleteAsync(u => true); // await _repository.DeleteAsync(u => true);
await _repository.InsertRangeAsync(users); // await _repository.InsertRangeAsync(users);
}); // });
return Result.Success().SetStatus(res); // return Result.Success().SetStatus(res);
} //}
/// <summary> /// <summary>
/// 动态条件分页查询 /// 动态条件分页查询
@@ -114,8 +114,7 @@ namespace Yi.Framework.ApiMicroservice.Controllers
[Permission("system:user:edit")] [Permission("system:user:edit")]
public async Task<Result> UpdateStatus(long userId, bool isDel) public async Task<Result> UpdateStatus(long userId, bool isDel)
{ {
return Result.Success().SetData(await _iUserService._repository.UpdateIgnoreNullAsync(new UserEntity() { Id = userId, IsDeleted = isDel })); return Result.Success().SetData(await _repository.UpdateIgnoreNullAsync(new UserEntity() { Id = userId, IsDeleted = isDel }));
} }
/// <summary> /// <summary>
@@ -153,7 +152,7 @@ namespace Yi.Framework.ApiMicroservice.Controllers
[Permission("system:user:edit")] [Permission("system:user:edit")]
public async Task<Result> Update(UserInfoDto userDto) public async Task<Result> Update(UserInfoDto userDto)
{ {
if (await _iUserService._repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName) && !userDto.User.Id.Equals(u.Id))) if (await _repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName) && !userDto.User.Id.Equals(u.Id)))
{ {
return Result.Error("用户名已存在,修改失败!"); return Result.Error("用户名已存在,修改失败!");
} }
@@ -182,7 +181,7 @@ namespace Yi.Framework.ApiMicroservice.Controllers
[Permission("system:user:add2")] [Permission("system:user:add2")]
public async Task<Result> Add(UserInfoDto userDto) public async Task<Result> Add(UserInfoDto userDto)
{ {
if (await _iUserService._repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName))) if (await _repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName)))
{ {
return Result.Error("用户已经存在,添加失败!"); return Result.Error("用户已经存在,添加失败!");
} }