From 0d794d748f61b5c719d665bfcae24a4d9b2b6224 Mon Sep 17 00:00:00 2001 From: Administrator <Administrator@DESKTOP-JIE70N9> Date: 星期四, 08 五月 2025 15:02:49 +0800 Subject: [PATCH] 请验图片处理 --- Wms/Wms/Controllers/BllQualityController.cs | 162 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 162 insertions(+), 0 deletions(-) diff --git a/Wms/Wms/Controllers/BllQualityController.cs b/Wms/Wms/Controllers/BllQualityController.cs index 9f93f4b..fffe319 100644 --- a/Wms/Wms/Controllers/BllQualityController.cs +++ b/Wms/Wms/Controllers/BllQualityController.cs @@ -9,6 +9,11 @@ using Model.ModelVm; using Wms.Tools; using Microsoft.Extensions.Options; +using System.Collections.Generic; +using System.IO; +using System.Threading.Tasks; +using System.Linq; + namespace Wms.Controllers { @@ -164,6 +169,32 @@ } } + [HttpPost] + public IActionResult upLoadRequest(IdVm model) + { + try + { + var claimsIdentity = this.User.Identity as ClaimsIdentity; + if (claimsIdentity == null) + { + return Ok(new { code = 1, msg = "鏈幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" }); + } + var userId = claimsIdentity.FindFirst(ClaimTypes.Name)?.Value; + if (string.IsNullOrWhiteSpace(userId)) + { + return Ok(new { code = 1, msg = "鏈幏鍙栧埌褰撳墠鎿嶄綔浜轰俊鎭�" }); + } + var userName = claimsIdentity.FindFirst(ClaimTypes.NameIdentifier)?.Value; + + + return Ok(new { code = 0, count = 0, msg = "涓婁紶鍥剧墖鎴愬姛!"}); + } + catch (Exception e) + { + return Ok(new { code = 1, msg = e.Message }); + } + } + /// <summary> /// 鍙戦�佽楠屽崟鎹� /// </summary> @@ -292,6 +323,137 @@ return Ok(new { code = 1, msg = e.Message }); } } + + /// <summary> + /// 鍥剧墖涓婁紶 + /// </summary> + /// <param name="file"></param> + /// <param name="qualityId"></param> + /// <returns></returns> + [HttpPost] + public async Task<IActionResult> UploadImage([FromForm] IFormFile file, [FromForm] int qualityId) + { + try + { + var claimsIdentity = this.User.Identity as ClaimsIdentity; + var userId = claimsIdentity.FindFirst(ClaimTypes.Name)?.Value; + if (file == null || file.Length == 0) + return BadRequest(new { code = 1, msg = "璇烽�夋嫨涓婁紶鏂囦欢" }); + + // 楠岃瘉鏂囦欢绫诲瀷 + var allowedExtensions = new[] { ".jpg", ".jpeg", ".png", ".gif" }; + var fileExtension = Path.GetExtension(file.FileName).ToLower(); + if (!allowedExtensions.Contains(fileExtension)) + return BadRequest(new { code = 2, msg = "鍙厑璁镐笂浼犲浘鐗囨枃浠�" }); + + // 闄愬埗鏂囦欢澶у皬 (5MB) + if (file.Length > 5 * 1024 * 1024) + return BadRequest(new { code = 3, msg = "鏂囦欢澶у皬涓嶈兘瓒呰繃5MB" }); + + // 鍒涘缓璐ㄩ噺鐩稿叧鐨勫浘鐗囩洰褰� + var uploadPath = Path.Combine(Directory.GetCurrentDirectory(), "wwwRoot", "uploads", "quality", qualityId.ToString()); + if (!Directory.Exists(uploadPath)) + Directory.CreateDirectory(uploadPath); + + // 鐢熸垚鍞竴鏂囦欢鍚� + var fileName = $"{DateTime.Now:yyyyMMddHHmmss}_{userId}{fileExtension}"; + var filePath = Path.Combine(uploadPath, fileName); + + // 淇濆瓨鏂囦欢 + using (var stream = new FileStream(filePath, FileMode.Create)) + { + await file.CopyToAsync(stream); + } + + // 杩斿洖鏂囦欢璁块棶璺緞 + var fileUrl = $"/wwwRoot/uploads/quality/{qualityId}/{fileName}"; + + // 杩欓噷鍙互娣诲姞鏁版嵁搴撹褰曠瓑鎿嶄綔 + // _qualityService.AddImageRecord(qualityId, userId, fileUrl, fileName); + + return Ok(new + { + code = 0, + msg = "涓婁紶鎴愬姛", + data = new + { + url = fileUrl, + fileName = fileName + } + }); + } + catch (Exception ex) + { + return StatusCode(500, new { code = 500, msg = $"涓婁紶澶辫触: {ex.Message}" }); + } + } + + /// <summary> + /// 鍥剧墖鑾峰彇 + /// </summary> + /// <param name="model"></param> + /// <returns></returns> + [HttpPost] + public IActionResult GetImage(BllQualityInspect model) + { + try + { + + var fullPath = Path.Combine(Directory.GetCurrentDirectory(), "wwwRoot", "uploads", "quality", model.Id.ToString()); + if (!Directory.Exists(fullPath)) + { + return StatusCode(1, new { code = 1, msg = "鍥剧墖涓嶅瓨鍦�" }); + } + var files = Directory.GetFiles(fullPath); + if (files.Length <= 0) + return StatusCode(1, new { code = 1, msg = "鍥剧墖涓嶅瓨鍦�" }); + List<string> images = new List<string>(); + foreach (var file in files) + { + images.Add($"{Request.Scheme}://{Request.Host}/uploads/quality/{model.Id.ToString()}/{Path.GetFileName(file)}"); + } + return Ok(new + { + code = 0, + msg = "鍥剧墖" + files.Length + "寮�", + data = images + }); + } + catch (Exception ex) + { + return StatusCode(500, new { code = 500, msg = $"鑾峰彇鍥剧墖澶辫触: {ex.Message}" }); + } + } + + /// <summary> + /// 鍒犻櫎鍥剧墖 + /// </summary> + /// <param name="data">鍥剧墖淇℃伅</param> + /// <returns></returns> + [HttpPost] + public IActionResult DeleteImage(QualityImageVM data) + { + try + { + string fileName = Path.GetFileName(data.ImageUrl); + + var filePath = Path.Combine(Directory.GetCurrentDirectory(), "wwwRoot", "uploads", "quality", data.QualityId.ToString(), fileName); + if (System.IO.File.Exists(filePath)) + { + System.IO.File.Delete(filePath); + + return Ok(new { code = 0, msg = "鍒犻櫎鎴愬姛" }); + } + else + { + return Ok(new { code = 1, msg = "鍥剧墖涓嶅瓨鍦�" }); + } + } + catch (Exception ex) + { + return Ok(new { code = 1, msg = ex.Message }); + } + } #endregion } } -- Gitblit v1.8.0