291 lines
11 KiB
C#
291 lines
11 KiB
C#
using Microsoft.AspNetCore.Mvc;
|
||
using Microsoft.Extensions.Localization;
|
||
using Microsoft.Extensions.Options;
|
||
using MiniExcelLibs;
|
||
using DOAN.Admin.WebApi.Filters;
|
||
using DOAN.Infrastructure.IPTools;
|
||
using DOAN.Model.Dto;
|
||
using DOAN.Model.System;
|
||
using DOAN.ServiceCore.Resources;
|
||
|
||
namespace DOAN.Admin.WebApi.Controllers
|
||
{
|
||
/// <summary>
|
||
/// 公共模块
|
||
/// </summary>
|
||
[Route("[controller]/[action]")]
|
||
[ApiExplorerSettings(GroupName = "sys")]
|
||
public class CommonController : BaseController
|
||
{
|
||
private OptionsSetting OptionsSetting;
|
||
private NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger();
|
||
|
||
private IWebHostEnvironment WebHostEnvironment;
|
||
private ISysFileService SysFileService;
|
||
private readonly IStringLocalizer<SharedResource> _localizer;
|
||
|
||
/// <summary>
|
||
///
|
||
/// </summary>
|
||
/// <param name="stringLocalizer"></param>
|
||
/// <param name="options"></param>
|
||
/// <param name="webHostEnvironment"></param>
|
||
/// <param name="fileService"></param>
|
||
public CommonController(
|
||
IStringLocalizer<SharedResource> stringLocalizer,
|
||
IOptions<OptionsSetting> options,
|
||
IWebHostEnvironment webHostEnvironment,
|
||
ISysFileService fileService)
|
||
{
|
||
WebHostEnvironment = webHostEnvironment;
|
||
SysFileService = fileService;
|
||
OptionsSetting = options.Value;
|
||
_localizer = stringLocalizer;
|
||
}
|
||
|
||
/// <summary>
|
||
/// home
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
[Route("/")]
|
||
[HttpGet]
|
||
public IActionResult Index()
|
||
{
|
||
var hello = _localizer["hello"].Value;
|
||
return Ok($"{hello}看到这里页面说明你已经成功启动了本项目:)\n\n" +
|
||
"如果觉得项目有用,打赏作者喝杯咖啡作为奖励\n☛☛http://www.izhaorui.cn/vip\n");
|
||
}
|
||
|
||
/// <summary>
|
||
/// 查询IP信息
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
[Route("/ip")]
|
||
[HttpGet]
|
||
public IActionResult IPInfo(string ip)
|
||
{
|
||
if (ip.IsEmpty()) return ToResponse(ResultCode.CUSTOM_ERROR, "IP异常");
|
||
|
||
var region = IpTool.GetRegion(ip);
|
||
|
||
return SUCCESS(region);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 企业消息测试
|
||
/// </summary>
|
||
/// <param name="msg">要发送的消息</param>
|
||
/// <param name="toUser">要发送的人@all所有,xxx单独发送对个人</param>
|
||
/// <returns></returns>
|
||
[Route("/sendMsg")]
|
||
[HttpGet]
|
||
[Log(Title = "企业消息测试")]
|
||
public IActionResult SendMsg(string msg, string toUser = "")
|
||
{
|
||
WxNoticeHelper.SendMsg("消息测试", msg, toUser, WxNoticeHelper.MsgType.markdown);
|
||
return SUCCESS(msg);
|
||
}
|
||
|
||
#region 上传
|
||
|
||
/// <summary>
|
||
/// 存储文件
|
||
/// </summary>
|
||
/// <param name="uploadDto">自定义文件名</param>
|
||
/// <param name="storeType">上传类型1、保存到本地 2、保存到阿里云</param>
|
||
/// <returns></returns>
|
||
[HttpPost()]
|
||
[Verify]
|
||
[ActionPermissionFilter(Permission = "common")]
|
||
public async Task<IActionResult> UploadFile([FromForm] UploadDto2 uploadDto, StoreType storeType = StoreType.LOCAL)
|
||
{
|
||
IFormFile formFile = uploadDto.File;
|
||
if (formFile == null) throw new CustomException(ResultCode.PARAM_ERROR, "上传文件不能为空");
|
||
SysFile file = new();
|
||
string fileExt = Path.GetExtension(formFile.FileName);//文件后缀
|
||
double fileSize = Math.Round(formFile.Length / 1024.0, 2);//文件大小KB
|
||
|
||
if (OptionsSetting.Upload.NotAllowedExt.Contains(fileExt))
|
||
{
|
||
return ToResponse(ResultCode.CUSTOM_ERROR, "上传失败,未经允许上传类型");
|
||
}
|
||
if (uploadDto.FileNameType == 1)
|
||
{
|
||
uploadDto.FileName = Path.GetFileNameWithoutExtension(formFile.FileName);
|
||
}
|
||
else if (uploadDto.FileNameType == 3)
|
||
{
|
||
uploadDto.FileName = SysFileService.HashFileName();
|
||
}
|
||
switch (storeType)
|
||
{
|
||
case StoreType.LOCAL:
|
||
string savePath = null;
|
||
if (string.IsNullOrEmpty(OptionsSetting.Upload.rootDirectory))
|
||
{
|
||
savePath = Path.Combine(WebHostEnvironment.WebRootPath);
|
||
|
||
}
|
||
else
|
||
{
|
||
savePath = Path.Combine(OptionsSetting.Upload.rootDirectory);
|
||
if (!Directory.Exists(savePath))
|
||
{
|
||
Directory.CreateDirectory(savePath);
|
||
}
|
||
}
|
||
|
||
if (uploadDto.FileDir.IsEmpty())
|
||
{
|
||
uploadDto.FileDir = OptionsSetting.Upload.LocalSavePath;
|
||
}
|
||
//savePath 根目录 uploadDto.FileName uploadDto.FileName
|
||
file = await SysFileService.SaveFileToLocal(savePath, uploadDto.FileName, uploadDto.FileName, HttpContext.GetName(), formFile, uploadDto.filePath);
|
||
break;
|
||
case StoreType.REMOTE:
|
||
break;
|
||
case StoreType.ALIYUN:
|
||
int AlimaxContentLength = OptionsSetting.ALIYUN_OSS.MaxSize;
|
||
if (OptionsSetting.ALIYUN_OSS.REGIONID.IsEmpty())
|
||
{
|
||
return ToResponse(ResultCode.CUSTOM_ERROR, "配置文件缺失");
|
||
}
|
||
if ((fileSize / 1024) > AlimaxContentLength)
|
||
{
|
||
return ToResponse(ResultCode.CUSTOM_ERROR, "上传文件过大,不能超过 " + AlimaxContentLength + " MB");
|
||
}
|
||
file = new(formFile.FileName, uploadDto.FileName, fileExt, fileSize + "kb", uploadDto.FileDir, HttpContext.GetName())
|
||
{
|
||
StoreType = (int)StoreType.ALIYUN,
|
||
FileType = formFile.ContentType
|
||
};
|
||
file = await SysFileService.SaveFileToAliyun(file, formFile);
|
||
|
||
if (file.Id <= 0) { return ToResponse(ApiResult.Error("阿里云连接失败")); }
|
||
break;
|
||
case StoreType.TENCENT:
|
||
break;
|
||
case StoreType.QINIU:
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
return SUCCESS(new
|
||
{
|
||
url = file.AccessUrl,
|
||
fileName = file.FileName,
|
||
fileId = file.Id.ToString()
|
||
});
|
||
}
|
||
public class UploadDto2
|
||
{
|
||
/// <summary>
|
||
/// 自定文件名
|
||
/// </summary>
|
||
public string? FileName { get; set; }
|
||
/// <summary>
|
||
/// 存储目录
|
||
/// </summary>
|
||
public string? FileDir { get; set; }
|
||
/// <summary>
|
||
/// 文件名生成类型 1 原文件名 2 自定义 3 自动生成
|
||
/// </summary>
|
||
public int FileNameType { get; set; }
|
||
/// <summary>
|
||
/// 存储目录 比FileDir 优先
|
||
/// </summary>
|
||
public string filePath { get; set; }
|
||
public IFormFile? File { get; set; }
|
||
}
|
||
#endregion
|
||
|
||
/// <summary>
|
||
/// 下载文件
|
||
/// </summary>
|
||
/// <param name="path"></param>
|
||
/// <param name="fileId"></param>
|
||
/// <returns></returns>
|
||
[HttpGet]
|
||
[Verify]
|
||
[ActionPermissionFilter(Permission = "common")]
|
||
[Log(Title = "下载文件", IsSaveResponseData = false)]
|
||
public IActionResult DownloadFile(string? path, long fileId = 0)
|
||
{
|
||
var tempPath = path;
|
||
if (fileId > 0)
|
||
{
|
||
var fileInfo = SysFileService.GetById(fileId);
|
||
if (fileInfo != null)
|
||
{
|
||
tempPath = fileInfo.FileUrl;
|
||
}
|
||
}
|
||
string fullPath = tempPath;
|
||
if (tempPath.StartsWith("/"))
|
||
{
|
||
fullPath = Path.Combine(WebHostEnvironment.WebRootPath, tempPath.ReplaceFirst("/", ""));
|
||
}
|
||
string fileName = Path.GetFileName(fullPath);
|
||
return DownFile(fullPath, fileName);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 初始化种子数据
|
||
/// </summary>
|
||
/// <param name="clean">是否清空数据</param>
|
||
/// <returns></returns>
|
||
[HttpGet]
|
||
[ActionPermissionFilter(Permission = "common")]
|
||
[Log(BusinessType = BusinessType.INSERT, Title = "初始化数据")]
|
||
public IActionResult InitSeedData(bool clean = false)
|
||
{
|
||
if (!WebHostEnvironment.IsDevelopment())
|
||
{
|
||
return ToResponse(ResultCode.CUSTOM_ERROR, "导入数据失败,请在开发模式下初始化");
|
||
}
|
||
var path = Path.Combine(WebHostEnvironment.WebRootPath, "data.xlsx");
|
||
SeedDataService seedDataService = new();
|
||
var result = seedDataService.InitSeedData(path, clean);
|
||
Console.ForegroundColor = ConsoleColor.Red;
|
||
foreach (var item in result)
|
||
{
|
||
Console.WriteLine(item);
|
||
}
|
||
Console.ForegroundColor = ConsoleColor.White;
|
||
return SUCCESS(new
|
||
{
|
||
result
|
||
});
|
||
}
|
||
|
||
/// <summary>
|
||
///
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
[HttpGet]
|
||
[ActionPermissionFilter(Permission = "common")]
|
||
[Log(BusinessType = BusinessType.INSERT, Title = "初始化数据")]
|
||
public IActionResult UpdateSeedData()
|
||
{
|
||
if (!WebHostEnvironment.IsDevelopment())
|
||
{
|
||
return ToResponse(ResultCode.CUSTOM_ERROR, "导入数据失败,请在开发模式下初始化");
|
||
}
|
||
var path = Path.Combine(WebHostEnvironment.WebRootPath, "data.xlsx");
|
||
SeedDataService seedDataService = new();
|
||
|
||
var sysNotice = MiniExcel.Query<SysNotice>(path, sheetName: "notice").ToList();
|
||
var result = seedDataService.InitNoticeData(sysNotice);
|
||
|
||
var sysMenu = MiniExcel.Query<SysMenu>(path, sheetName: "menu").Where(f => f.MenuId >= 1104).ToList();
|
||
var result5 = seedDataService.InitMenuData(sysMenu);
|
||
|
||
return SUCCESS(new
|
||
{
|
||
result,
|
||
result5
|
||
});
|
||
}
|
||
}
|
||
}
|