BaseController.cs 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. using Infrastructure;
  2. using Infrastructure.Model;
  3. using Microsoft.AspNetCore.Mvc;
  4. using MiniExcelLibs;
  5. using Newtonsoft.Json;
  6. using Newtonsoft.Json.Serialization;
  7. using System.Web;
  8. using FF = System.IO;
  9. namespace ZR.Admin.WebApi.Controllers
  10. {
  11. /// <summary>
  12. /// WebApi 基类
  13. /// </summary>
  14. public class BaseController : ControllerBase
  15. {
  16. /// <summary>
  17. /// Json字符串自定义的时间格式化
  18. /// </summary>
  19. public const string TIME_FORMAT_FULL = "yyyy-MM-dd HH:mm:ss.fff";
  20. /// <summary>
  21. /// 封装 WebApi接口操作成功的返回结果
  22. /// </summary>
  23. /// <param name="data"></param>
  24. /// <param name="timeFormatStr"></param>
  25. /// <returns></returns>
  26. protected IActionResult SUCCESS(object data, string timeFormatStr = TIME_FORMAT_FULL)
  27. {
  28. string jsonStr = GetJsonStr(GetApiResult(data != null ? ResultCode.SUCCESS : ResultCode.FAIL, data), timeFormatStr);
  29. return Content(jsonStr, "application/json");
  30. }
  31. /// <summary>
  32. /// 封装 WebApi接口操作的返回结果
  33. /// json输出的字符串带有自定义的时间格式
  34. /// </summary>
  35. /// <param name="apiResult">返回结果对象</param>
  36. /// <param name="timeFormatStr">自定义的时间格式</param>
  37. /// <returns></returns>
  38. protected IActionResult ToResponse(ApiResult apiResult, string timeFormatStr = TIME_FORMAT_FULL)
  39. {
  40. string jsonStr = GetJsonStr(apiResult, timeFormatStr);
  41. return Content(jsonStr, "application/json");
  42. }
  43. /// <summary>
  44. /// 封装 WebApi接口操作的返回结果
  45. /// json输出的字符串带有自定义的时间格式
  46. /// </summary>
  47. /// <param name="rows">受影响行数</param>
  48. /// <param name="timeFormatStr">自定义的时间格式</param>
  49. /// <returns></returns>
  50. protected IActionResult ToResponse(long rows, string timeFormatStr = TIME_FORMAT_FULL)
  51. {
  52. string jsonStr = GetJsonStr(ToJson(rows), timeFormatStr);
  53. return Content(jsonStr, "application/json");
  54. }
  55. /// <summary>
  56. /// 封装 WebApi接口操作的返回结果
  57. /// json输出的字符串带有自定义的时间格式
  58. /// </summary>
  59. /// <param name="resultCode">返回的状态码</param>
  60. /// <param name="msg">返回信息</param>
  61. /// <returns></returns>
  62. protected IActionResult ToResponse(ResultCode resultCode, string msg = "")
  63. {
  64. return ToResponse(GetApiResult(resultCode, msg));
  65. }
  66. /// <summary>
  67. /// 导出Excel
  68. /// </summary>
  69. /// <param name="path">完整文件路径</param>
  70. /// <param name="fileName">带扩展文件名</param>
  71. /// <returns></returns>
  72. protected IActionResult ExportExcel(string path, string fileName)
  73. {
  74. //IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
  75. //string fileDir = Path.Combine(webHostEnvironment.WebRootPath, path, fileName);
  76. var stream = FF.File.OpenRead(path); //创建文件流
  77. return File(stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", HttpUtility.UrlEncode(fileName));
  78. }
  79. #region 方法
  80. /// <summary>
  81. /// 响应返回结果
  82. /// </summary>
  83. /// <param name="rows">受影响行数</param>
  84. /// <returns></returns>
  85. protected ApiResult ToJson(long rows)
  86. {
  87. return rows > 0 ? GetApiResult(ResultCode.SUCCESS) : GetApiResult(ResultCode.FAIL);
  88. }
  89. /// <summary>
  90. /// 响应返回结果
  91. /// </summary>
  92. /// <param name="rows">受影响行数</param>
  93. /// <param name="data"></param>
  94. /// <returns></returns>
  95. protected ApiResult ToJson(long rows, object data)
  96. {
  97. return rows > 0 ? GetApiResult(ResultCode.SUCCESS, data) : GetApiResult(ResultCode.FAIL);
  98. }
  99. /// <summary>
  100. /// 全局Code使用
  101. /// </summary>
  102. /// <param name="resultCode"></param>
  103. /// <param name="data"></param>
  104. /// <returns></returns>
  105. protected ApiResult GetApiResult(ResultCode resultCode, object? data = null)
  106. {
  107. ApiResult apiResult = new((int)resultCode, resultCode.ToString())
  108. {
  109. Data = data
  110. };
  111. return apiResult;
  112. }
  113. /// <summary>
  114. ///
  115. /// </summary>
  116. /// <param name="resultCode"></param>
  117. /// <param name="msg"></param>
  118. /// <returns></returns>
  119. protected ApiResult GetApiResult(ResultCode resultCode, string msg)
  120. {
  121. return new ApiResult((int)resultCode, msg);
  122. }
  123. private static string GetJsonStr(ApiResult apiResult, string timeFormatStr)
  124. {
  125. if (string.IsNullOrEmpty(timeFormatStr))
  126. {
  127. timeFormatStr = TIME_FORMAT_FULL;
  128. }
  129. var serializerSettings = new JsonSerializerSettings
  130. {
  131. // 设置为驼峰命名
  132. ContractResolver = new CamelCasePropertyNamesContractResolver(),
  133. DateFormatString = timeFormatStr
  134. };
  135. return JsonConvert.SerializeObject(apiResult, Formatting.Indented, serializerSettings);
  136. }
  137. #endregion
  138. /// <summary>
  139. /// 导出Excel
  140. /// </summary>
  141. /// <typeparam name="T"></typeparam>
  142. /// <param name="list"></param>
  143. /// <param name="sheetName"></param>
  144. /// <param name="fileName"></param>
  145. protected string ExportExcel<T>(List<T> list, string sheetName, string fileName)
  146. {
  147. return ExportExcelMini(list, sheetName, fileName).Item1;
  148. }
  149. /// <summary>
  150. ///
  151. /// </summary>
  152. /// <typeparam name="T"></typeparam>
  153. /// <param name="list"></param>
  154. /// <param name="sheetName"></param>
  155. /// <param name="fileName"></param>
  156. /// <returns></returns>
  157. protected (string, string) ExportExcelMini<T>(List<T> list, string sheetName, string fileName)
  158. {
  159. IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
  160. string sFileName = $"{fileName}{DateTime.Now:MM-dd-HHmmss}.xlsx";
  161. string fullPath = Path.Combine(webHostEnvironment.WebRootPath, "export", sFileName);
  162. Directory.CreateDirectory(Path.GetDirectoryName(fullPath));
  163. MiniExcel.SaveAs(fullPath, list, sheetName: sheetName);
  164. return (sFileName, fullPath);
  165. }
  166. /// <summary>
  167. /// 导出多个工作表(Sheet)
  168. /// </summary>
  169. /// <param name="sheets"></param>
  170. /// <param name="fileName"></param>
  171. /// <returns></returns>
  172. protected (string, string) ExportExcelMini(Dictionary<string, object> sheets, string fileName)
  173. {
  174. IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
  175. string sFileName = $"{fileName}{DateTime.Now:MM-dd-HHmmss}.xlsx";
  176. string fullPath = Path.Combine(webHostEnvironment.WebRootPath, "export", sFileName);
  177. Directory.CreateDirectory(Path.GetDirectoryName(fullPath));
  178. MiniExcel.SaveAs(fullPath, sheets);
  179. return (sFileName, fullPath);
  180. }
  181. /// <summary>
  182. /// 下载导入模板
  183. /// </summary>
  184. /// <typeparam name="T"></typeparam>
  185. /// <param name="list"></param>
  186. /// <param name="stream"></param>
  187. /// <param name="fileName">下载文件名</param>
  188. /// <returns></returns>
  189. protected (string,string) DownloadImportTemplate<T>(List<T> list,Stream stream, string fileName)
  190. {
  191. IWebHostEnvironment webHostEnvironment = (IWebHostEnvironment)App.ServiceProvider.GetService(typeof(IWebHostEnvironment));
  192. string sFileName = $"{fileName}模板.xlsx";
  193. string sFilePath = Path.Combine(webHostEnvironment.WebRootPath, "importTemplate");
  194. string fullPath = Path.Combine(sFilePath, sFileName);
  195. //判断模板路径是否存在 2023年4月24日 赵
  196. if (!Directory.Exists(sFilePath))
  197. {
  198. Directory.CreateDirectory(Path.GetDirectoryName(sFilePath));
  199. }
  200. //判断模板文件是否存在 2023年4月24日 赵
  201. if (!FF.File.Exists(fullPath))
  202. {
  203. //在服务器生成模板文件,用来提供下载 2023年4月24日 赵
  204. MiniExcel.SaveAs(fullPath, list);
  205. }
  206. return (fullPath,sFileName);
  207. }
  208. }
  209. }