Files
shgx_tz_mes_backend_sync/ZR.Admin.WebApi/Controllers/BaseController.cs

194 lines
7.4 KiB
C#
Raw Normal View History

2021-08-23 16:57:25 +08:00
using Infrastructure;
using Infrastructure.Model;
2021-11-21 15:48:24 +08:00
using Microsoft.AspNetCore.Hosting;
2021-08-23 16:57:25 +08:00
using Microsoft.AspNetCore.Mvc;
using Newtonsoft.Json;
using Newtonsoft.Json.Serialization;
2021-11-21 15:48:24 +08:00
using OfficeOpenXml;
using System;
using System.Collections.Generic;
using System.IO;
using System.Web;
using ff = System.IO;
2021-08-23 16:57:25 +08:00
namespace ZR.Admin.WebApi.Controllers
{
public class BaseController : ControllerBase
{
public static string TIME_FORMAT_FULL = "yyyy-MM-dd HH:mm:ss";
public static string TIME_FORMAT_FULL_2 = "MM-dd HH:mm:ss";
2022-01-11 10:49:38 +08:00
/// <summary>
/// 返回成功封装
/// </summary>
/// <param name="data"></param>
/// <param name="timeFormatStr"></param>
/// <returns></returns>
2021-12-27 10:11:22 +08:00
protected IActionResult SUCCESS(object data, string timeFormatStr = "yyyy-MM-dd HH:mm:ss")
2021-08-23 16:57:25 +08:00
{
string jsonStr = GetJsonStr(GetApiResult(data != null ? ResultCode.SUCCESS : ResultCode.FAIL, data), timeFormatStr);
return Content(jsonStr, "application/json");
}
/// <summary>
/// json输出带时间格式的
/// </summary>
/// <param name="apiResult"></param>
/// <param name="timeFormatStr"></param>
/// <returns></returns>
2021-12-27 10:11:22 +08:00
protected IActionResult ToResponse(ApiResult apiResult, string timeFormatStr = "yyyy-MM-dd HH:mm:ss")
2021-08-23 16:57:25 +08:00
{
string jsonStr = GetJsonStr(apiResult, timeFormatStr);
return Content(jsonStr, "application/json");
}
2022-01-11 10:49:38 +08:00
2021-12-27 10:11:22 +08:00
protected IActionResult ToResponse(long rows, string timeFormatStr = "yyyy-MM-dd HH:mm:ss")
2021-08-23 16:57:25 +08:00
{
string jsonStr = GetJsonStr(ToJson(rows), timeFormatStr);
return Content(jsonStr, "application/json");
}
2022-01-11 10:49:38 +08:00
protected IActionResult ToResponse(ResultCode resultCode, string msg = "")
{
return ToResponse(GetApiResult(resultCode, msg));
}
/// <summary>
/// 导出Excel
/// </summary>
/// <param name="path"></param>
/// <param name="fileName"></param>
/// <returns></returns>
protected IActionResult ExportExcel(string path, string fileName)
{
IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
string fileDir = Path.Combine(webHostEnvironment.WebRootPath, path, fileName);
var stream = ff.File.OpenRead(fileDir); //创建文件流
return File(stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", HttpUtility.UrlEncode(fileName));
}
2022-01-11 10:49:38 +08:00
#region
2021-08-23 16:57:25 +08:00
/// <summary>
/// 响应返回结果
/// </summary>
/// <param name="rows">受影响行数</param>
/// <returns></returns>
protected ApiResult ToJson(long rows)
{
return rows > 0 ? GetApiResult(ResultCode.SUCCESS) : GetApiResult(ResultCode.FAIL);
}
protected ApiResult ToJson(long rows, object data)
{
return rows > 0 ? GetApiResult(ResultCode.SUCCESS, data) : GetApiResult(ResultCode.FAIL);
}
/// <summary>
/// 全局Code使用
/// </summary>
/// <param name="resultCode"></param>
/// <param name="data"></param>
/// <returns></returns>
2022-03-06 14:26:05 +08:00
protected ApiResult GetApiResult(ResultCode resultCode, object? data = null)
2021-08-23 16:57:25 +08:00
{
var apiResult = new ApiResult((int)resultCode, resultCode.ToString())
{
Data = data
};
return apiResult;
}
protected ApiResult GetApiResult(ResultCode resultCode, string msg)
{
return new ApiResult((int)resultCode, msg);
}
private static string GetJsonStr(ApiResult apiResult, string timeFormatStr)
{
if (string.IsNullOrEmpty(timeFormatStr))
{
timeFormatStr = TIME_FORMAT_FULL;
}
var serializerSettings = new JsonSerializerSettings
{
// 设置为驼峰命名
ContractResolver = new CamelCasePropertyNamesContractResolver(),
DateFormatString = timeFormatStr
};
return JsonConvert.SerializeObject(apiResult, Formatting.Indented, serializerSettings);
}
2022-01-11 10:49:38 +08:00
#endregion
2021-11-21 15:48:24 +08:00
/// <summary>
/// 导出Excel
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="list"></param>
/// <param name="sheetName"></param>
/// <param name="fileName"></param>
protected string ExportExcel<T>(List<T> list, string sheetName, string fileName)
2022-11-15 18:10:02 +08:00
{
var fileInfo = ExportExcelNew(list, sheetName, fileName);
return fileInfo.Item1;
}
protected (string, string) ExportExcelNew<T>(List<T> list, string sheetName, string fileName)
2021-11-21 15:48:24 +08:00
{
IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
2021-12-22 16:53:44 +08:00
string sFileName = $"{fileName}{DateTime.Now:MMddHHmmss}.xlsx";
2021-11-21 15:48:24 +08:00
string newFileName = Path.Combine(webHostEnvironment.WebRootPath, "export", sFileName);
//调试模式需要加上
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
Directory.CreateDirectory(Path.GetDirectoryName(newFileName));
2021-12-04 13:15:57 +08:00
using (ExcelPackage package = new(new FileInfo(newFileName)))
2021-11-21 15:48:24 +08:00
{
// 添加worksheet
ExcelWorksheet worksheet = package.Workbook.Worksheets.Add(sheetName);
2022-01-11 11:25:01 +08:00
//单元格自动适应大小
worksheet.Cells.Style.ShrinkToFit = true;
2021-11-21 15:48:24 +08:00
//全部字段导出
2021-12-04 13:15:57 +08:00
worksheet.Cells.LoadFromCollection(list, true, OfficeOpenXml.Table.TableStyles.Light13);
2021-11-21 15:48:24 +08:00
package.Save();
}
2022-11-15 18:10:02 +08:00
return (sFileName, newFileName);
2021-11-21 15:48:24 +08:00
}
/// <summary>
/// 下载导入模板
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="list"></param>
/// <param name="stream"></param>
/// <param name="fileName">下载文件名</param>
/// <returns></returns>
protected string DownloadImportTemplate<T>(List<T> list, Stream stream, string fileName)
{
IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
string sFileName = $"{fileName}模板.xlsx";
string newFileName = Path.Combine(webHostEnvironment.WebRootPath, "importTemplate", sFileName);
//调试模式需要加上
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
if (!Directory.Exists(newFileName))
{
Directory.CreateDirectory(Path.GetDirectoryName(newFileName));
}
using (ExcelPackage package = new(new FileInfo(newFileName)))
{
// 添加worksheet
ExcelWorksheet worksheet = package.Workbook.Worksheets.Add(fileName);
2022-04-15 17:07:35 +08:00
//单元格自动适应大小
worksheet.Cells.Style.ShrinkToFit = true;
//全部字段导出
worksheet.Cells.LoadFromCollection(list, true, OfficeOpenXml.Table.TableStyles.Light13);
package.SaveAs(stream);
}
return sFileName;
}
2021-08-23 16:57:25 +08:00
}
}