You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
347 lines
11 KiB
347 lines
11 KiB
using Magicodes.ExporterAndImporter.Core;
|
|
using Magicodes.ExporterAndImporter.Core.Extension;
|
|
using Magicodes.ExporterAndImporter.Excel;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Extensions.Configuration;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data;
|
|
using System.Linq;
|
|
using System.Linq.Expressions;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using TaskManager.Entity;
|
|
using TaskManager.EntityFramework;
|
|
using TaskManager.EntityFramework.Repository;
|
|
using Wood.Entity;
|
|
using Wood.Util;
|
|
using Wood.Util.Filters;
|
|
|
|
|
|
namespace Wood.Service.Controllers
|
|
{
|
|
[AllowAnonymous]
|
|
public class NormalBaseController<T>:ControllerBase,ITransient where T:BaseEntity ,new()
|
|
{
|
|
|
|
protected readonly JobDbContext _context;
|
|
protected readonly IServiceProvider _builder;
|
|
protected readonly IConfiguration _configuration;
|
|
protected readonly IRepository<T> _repository;
|
|
|
|
|
|
|
|
public NormalBaseController(JobDbContext context, IServiceProvider builder, IConfiguration configuration, IRepository<T> repository)
|
|
{
|
|
_builder = builder;
|
|
_context = context;
|
|
_configuration = configuration;
|
|
_repository = repository;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 通过UID获得实体
|
|
/// </summary>
|
|
/// <param name="id"></param>
|
|
/// <returns></returns>
|
|
[HttpGet("{id}")]
|
|
public async virtual Task<ActionResult<T>> GetById(int id)
|
|
{
|
|
var entity = await _repository.GetByIdAsync(id);
|
|
if (entity == null) return NotFound();
|
|
return entity;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 创建实体
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async virtual Task<ActionResult<T>> Create(T entity)
|
|
{
|
|
entity.CreationTime = DateTime.Now;
|
|
var createdEntity = await _repository.AddAsync(entity);
|
|
return new JsonResult(new { Code = 200, Message = "创建成功!" });
|
|
}
|
|
/// <summary>
|
|
/// 更新实体UID
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPut]
|
|
[Route("Update/{UId}")]
|
|
public async virtual Task<IActionResult> Update(T entity)
|
|
{
|
|
if (entity.UId == 0)
|
|
{
|
|
throw new Exception("更新时,实体主键UId不能为空或0");
|
|
}
|
|
var _first = await _repository.GetByIdAsync(entity.UId);
|
|
if (_first == null)
|
|
{
|
|
throw new Exception($"NormalBaseController.Update报错:根据UId{entity.UId}没有找到记录");
|
|
return new JsonResult(new { Code = 400, Message = "修改失败!" });
|
|
}
|
|
EntityMapper.Trans(_first, entity, "UId");
|
|
|
|
await _repository.UpdateAsync(_first);
|
|
return new JsonResult(new { Code = 200, Message = "修改成功!" });
|
|
}
|
|
/// <summary>
|
|
/// 删除实体通过UID
|
|
/// </summary>
|
|
/// <param name="id"></param>
|
|
/// <returns></returns>
|
|
[HttpDelete("{id}")]
|
|
public async virtual Task<IActionResult> Delete(int id)
|
|
{
|
|
await _repository.DeleteAsync(id);
|
|
return new JsonResult(new { Code = 200, Message = "删除成功!" }); ;
|
|
}
|
|
|
|
|
|
|
|
|
|
///// <summary>
|
|
///// 分页
|
|
///// </summary>
|
|
///// <param name="pageNumber"></param>
|
|
///// <param name="pageSize"></param>
|
|
///// <param name="sortBy"></param>
|
|
///// <param name="isAscending"></param>
|
|
///// <param name="filters"></param>
|
|
///// <returns></returns>
|
|
//[HttpGet]
|
|
//public async virtual Task<ActionResult> GetPaged(
|
|
//[FromQuery] int pageNumber = 1,
|
|
//[FromQuery] int pageSize = 10,
|
|
//[FromQuery] string sortBy = "",
|
|
//[FromQuery] bool isAscending = true,
|
|
//[FromQuery] Dictionary<string, string> filters = null)
|
|
//{
|
|
// var pagingParams = new PagingParams
|
|
// {
|
|
// PageNumber = pageNumber,
|
|
// PageSize = pageSize,
|
|
// SortBy = sortBy,
|
|
// IsAscending = isAscending,
|
|
// Filters = filters
|
|
// };
|
|
|
|
// // 可以在这里构建表达式树过滤条件
|
|
// Expression<Func<T, bool>> filter = null;
|
|
|
|
// var pagedResult = await _repository.GetPagedAsync(filter, pagingParams);
|
|
// return Ok(pagedResult);
|
|
//}
|
|
/// <summary>
|
|
/// 分页New
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async virtual Task<ActionResult<TaskManager.EntityFramework.Repository.PagedResult<T>>> GetDataPaged(RequestInputBase input)
|
|
{
|
|
var pagingParams = new PagingParams
|
|
{
|
|
PageNumber = input.pageNumber,
|
|
PageSize = input.pageSize,
|
|
SortBy = input.sortBy,
|
|
IsAscending = input.isAscending,
|
|
};
|
|
|
|
// 可以在这里构建表达式树过滤条件
|
|
Expression<Func<T, bool>> filter = null;
|
|
|
|
var pagedResult = await _repository.GetDataPagedAsync(filter, pagingParams, input.Condition);
|
|
return Ok(pagedResult);
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 导出New
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async virtual Task<FileStreamResult> ExportData(RequestInputBase input)
|
|
{
|
|
var pagingParams = new PagingParams
|
|
{
|
|
PageNumber = input.pageNumber,
|
|
PageSize = input.pageSize,
|
|
SortBy = input.sortBy,
|
|
IsAscending = input.isAscending,
|
|
|
|
};
|
|
|
|
// 可以在这里构建表达式树过滤条件
|
|
//Expression<Func<T, bool>> filter = null;
|
|
|
|
var pagedResult = await _repository.GetDataPagedAsync(null, pagingParams, input.Condition);
|
|
return await ExportFile(pagedResult.Data, Guid.NewGuid().ToString() + ".xlsx");
|
|
}
|
|
|
|
|
|
|
|
// /// <summary>
|
|
// /// 导出
|
|
// /// </summary>
|
|
// /// <param name="pageNumber"></param>
|
|
// /// <param name="pageSize"></param>
|
|
// /// <param name="sortBy"></param>
|
|
// /// <param name="isAscending"></param>
|
|
// /// <param name="filters"></param>
|
|
// /// <returns></returns>
|
|
|
|
// [HttpGet]
|
|
// public async virtual Task<FileStreamResult> Export([FromQuery] int pageNumber = 1,
|
|
//[FromQuery] int pageSize = 10,
|
|
//[FromQuery] string sortBy = "",
|
|
//[FromQuery] bool isAscending = true,
|
|
//[FromQuery] Dictionary<string, string> filters = null)
|
|
// {
|
|
// var pagingParams = new PagingParams
|
|
// {
|
|
// PageNumber = pageNumber,
|
|
// PageSize = pageSize,
|
|
// SortBy = sortBy,
|
|
// IsAscending = isAscending,
|
|
// Filters = filters
|
|
// };
|
|
|
|
// // 可以在这里构建表达式树过滤条件
|
|
// //Expression<Func<T, bool>> filter = null;
|
|
|
|
// var pagedResult = await _repository.GetPagedAsync(null, pagingParams);
|
|
// return await ExportFile(pagedResult.Data, Guid.NewGuid().ToString() + ".xlsx");
|
|
|
|
|
|
// }
|
|
protected async Task<FileStreamResult> ExportFile(ICollection<T> dtos, string fileName)
|
|
{
|
|
var excelExporter = HttpContext.RequestServices.GetRequiredService<IExcelExporter>();
|
|
var res = await excelExporter.ExportAsByteArray(dtos);
|
|
return new FileStreamResult(new MemoryStream(res), "application/octet-stream") { FileDownloadName = DateTime.Now.ToString("yyyyMMddHHmm") + "_" + fileName };
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 导入模板
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
|
|
[HttpGet]
|
|
|
|
public async virtual Task<IActionResult> GetImportTemplate()
|
|
{
|
|
try
|
|
{
|
|
// 创建导入模板生成器
|
|
var importer = new ExcelImporter();
|
|
|
|
// 生成导入模板流(这里假设使用 YourModel 作为导入模型)
|
|
var bytes = await importer.GenerateTemplateBytes<T>();
|
|
|
|
|
|
//using var stream = new MemoryStream(bytes);
|
|
//stream.Seek(0, SeekOrigin.Begin);
|
|
|
|
// 设置友好的文件名,例如:"导入模板_20250530.xlsx"
|
|
var fileName = $"导入模板_{DateTime.Now:yyyyMMdd}.xlsx";
|
|
|
|
// 返回文件流结果
|
|
|
|
return new FileStreamResult(new MemoryStream(bytes), "application/octet-stream") { FileDownloadName = DateTime.Now.ToString("yyyyMMddHHmm") + "_" + fileName };
|
|
|
|
|
|
|
|
//return File(
|
|
// fileStream: stream,
|
|
// contentType: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
|
|
// fileDownloadName: fileName);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
// 记录异常日志
|
|
Console.WriteLine($"生成导入模板时出错: {ex.Message}");
|
|
|
|
// 返回错误响应
|
|
return StatusCode(500, "生成导入模板时发生错误");
|
|
}
|
|
}
|
|
/// <summary>
|
|
/// 导入
|
|
/// </summary>
|
|
/// <param name="file"></param>
|
|
/// <returns></returns>
|
|
[HttpPost("Import")]
|
|
public async virtual Task<IActionResult> Import(IFormFile file)
|
|
{
|
|
if (file == null || file.Length <= 0)
|
|
{
|
|
return BadRequest("No file uploaded.");
|
|
}
|
|
|
|
try
|
|
{
|
|
var excelImporter = HttpContext.RequestServices.GetRequiredService<IExcelImporter>();
|
|
var importResult = await excelImporter.Import<T>(file.OpenReadStream());
|
|
//if (importResult.HasError)
|
|
//{
|
|
// return BadRequest(importResult.ErrorMessage);
|
|
//}
|
|
|
|
// 处理导入的数据
|
|
List<T> list = new List<T>();
|
|
foreach (var item in importResult.Data)
|
|
{
|
|
list.Add(item);
|
|
|
|
}
|
|
await ImportBefore(list);
|
|
|
|
await _context.BulkInsertAsync(list);
|
|
|
|
await ImportAfter(list);
|
|
|
|
|
|
return new JsonResult(new { Code = 200, Message = "修改成功!" });
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Exception("NormalBaseController.Import报错:" + ex.Message);
|
|
// await _logger.AddError(ex.Message, TaskName);
|
|
return new JsonResult(new { Code = 400, Message = "导入失败!" });
|
|
}
|
|
}
|
|
|
|
|
|
protected virtual async Task ImportBefore(List<T> p_list)
|
|
{
|
|
|
|
}
|
|
|
|
|
|
protected virtual async Task ImportAfter(List<T> p_list)
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|