From 74907784c7005b7307b690d010ce6f8292e0dc9b Mon Sep 17 00:00:00 2001
From: yanjinhui <3306209981@qq.com>
Date: 星期五, 22 八月 2025 09:36:56 +0800
Subject: [PATCH] 修改单机版bug
---
项目代码/后端/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs | 173 ++++++++++++++++++++++++++++++++++++++-------------------
1 files changed, 116 insertions(+), 57 deletions(-)
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/\345\220\216\347\253\257/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/\345\220\216\347\253\257/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs"
index 8f4080e..d9ddf8c 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/\345\220\216\347\253\257/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/\345\220\216\347\253\257/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs"
@@ -18,6 +18,8 @@
using System.Runtime.InteropServices;
using System.IO;
using WIDESEAWCS_DTO.Telescopic;
+using System.Reflection.PortableExecutable;
+using Microsoft.AspNetCore.Mvc;
namespace WIDESEAWCS_SystemServices
{
@@ -31,9 +33,11 @@
private readonly IRepository<Dt_Maintenance> _MainServer;
private readonly IRepository<Sys_Role> _RoleServer;
private readonly IRepository<Dt_AuthorizationRecord> _AuthorizatRecServer;
+ private readonly IRepository<Sys_UserFace> _userFace;
- public Sys_UserService(IRepository<Dt_AuthorizationRecord> AuthorizatRecServer,IRepository<Sys_Role> RoleServer,IRepository<Dt_Loginhsy> LoginhsyServer,IRepository<Dt_FaceRecognition> faceServer, IRepository<Sys_User> repository, IUnitOfWorkManage unitOfWorkManage, ICacheService cacheService, ISys_MenuService menuService, IRepository<Dt_Maintenance> MainServer) : base(repository)
+ public Sys_UserService(IRepository<Sys_UserFace> userFace,IRepository<Dt_AuthorizationRecord> AuthorizatRecServer,IRepository<Sys_Role> RoleServer,IRepository<Dt_Loginhsy> LoginhsyServer,IRepository<Dt_FaceRecognition> faceServer, IRepository<Sys_User> repository, IUnitOfWorkManage unitOfWorkManage, ICacheService cacheService, ISys_MenuService menuService, IRepository<Dt_Maintenance> MainServer) : base(repository)
{
+ _userFace = userFace;
_faceServer = faceServer;
_LoginhsyServer = LoginhsyServer;
_unitOfWorkManage = unitOfWorkManage;
@@ -693,7 +697,7 @@
UserTeam = addUserDTO.userteam,
EnableTime = addUserDTO.enable == 1 ? DateTime.Now : (DateTime?)null, //鍚敤
DisableTime = addUserDTO.enable == 0 ? DateTime.Now : (DateTime?)null,//涓嶅惎鐢�
-
+
};
@@ -725,34 +729,43 @@
{
try
{
+ // 1. 妫�鏌ョ敤鎴锋槸鍚﹀瓨鍦�
+ var user = BaseDal.QueryData(x => x.UserName == account).FirstOrDefault();
+ if (user == null)
+ {
+ return WebResponseContent.Instance.Error("鐢ㄦ埛涓嶅瓨鍦�");
+ }
- // 2. 鏌ヨ浜鸿劯搴撳垎缁� ID
- //var faceGroupID = _faceServer.QueryData().Select(x => x.GroupID).FirstOrDefault();
-
- //WIDESEAWCS_Common.DeleteUserImg deleteUserImg = new WIDESEAWCS_Common.DeleteUserImg();
- //deleteUserImg.group_id = faceGroupID;
- //deleteUserImg.user_id = account;
-
- //string apiResult = BaiDuFaceHelper.DeleteUser(deleteUserImg);//鍙缁檛oken鍜宭og_id
-
- //// 2. 瑙f瀽杩斿洖缁撴灉锛屽垽鏂垹闄ゆ槸鍚︽垚鍔�
- //dynamic resultObj = JsonConvert.DeserializeObject(apiResult);
- //if (resultObj.error_code == 0)
- //{
- // 鐧惧害鍒犻櫎鎴愬姛鍚庯紝鍒犻櫎鏁版嵁搴撲腑鐨勭敤鎴�
- var user = BaseDal.QueryData(x => x.UserName == account).FirstOrDefault();
+ // 2. 妫�鏌ヤ富璁板綍鏄惁瀛樺湪鍙婄姸鎬�
var main = _MainServer.QueryData(x => x.UserAccount == account).FirstOrDefault();
- if (user != null&&main!=null)
- {
- BaseDal.DeleteData(user);
+ if (main == null)
+ {
+ return WebResponseContent.Instance.Error("鐢ㄦ埛涓昏褰曚笉瀛樺湪");
+ }
+ if (main.MaintenanceStatus == 1)
+ {
+ return WebResponseContent.Instance.Error("璇ョ敤鎴疯繕鍦ㄦ淇腑锛屾棤娉曞垹闄�");
+ }
+
+ // 3. 妫�鏌ヤ汉鑴歌褰曟槸鍚﹀瓨鍦�
+ var face = _userFace.QueryFirst(x => x.UserName == account);
+
+ // 4. 鎸夋潯浠跺垹闄�
+ if (face == null)
+ {
+ // 浠呭垹闄� user 鍜� main
+ BaseDal.DeleteData(user);
_MainServer.DeleteData(main);
}
- return WebResponseContent.Instance.OK("鐢ㄦ埛鍒犻櫎鎴愬姛");
- //}
- //else
- //{
- // return WebResponseContent.Instance.Error("鐧惧害 API 鍒犻櫎澶辫触锛�" + resultObj.error_msg);
- //}
+ else
+ {
+ // 鍒犻櫎鎵�鏈変笁涓褰�
+ _userFace.DeleteData(face);
+ BaseDal.DeleteData(user);
+ _MainServer.DeleteData(main);
+ }
+
+ return WebResponseContent.Instance.OK("鐢ㄦ埛鍒犻櫎鎴愬姛");
}
catch (Exception ex)
{
@@ -936,22 +949,27 @@
try
{
int totalCount = 0;
- var Role = _RoleServer.Db.Queryable<Sys_Role>();
- var query = Role.InnerJoin<Sys_User>((a, b) => a.RoleId == b.Role_Id);
+ //var Role = _RoleServer.Db.Queryable<Sys_Role>();
+ //var query = Role.InnerJoin<Sys_User>((a, b) => a.RoleId == b.Role_Id)
+ // .InnerJoin<Sys_UserFace>((a, b, c) => b.UserName == c.UserName);
+
+ var User = BaseDal.Db.Queryable<Sys_User>(); //鏌ュ嚭鐢ㄦ埛琛�
+ var query = User.LeftJoin<Sys_UserFace>((a, b) => a.UserName == b.UserName);
+
//鎼滅储鍏抽敭瀛�
if (!string.IsNullOrEmpty(pagination.searchKeyword))
{
query = query.Where((a, b) =>
- b.UserName.Contains(pagination.searchKeyword) ||
- b.UserTrueName.Contains(pagination.searchKeyword) ||
- b.PhoneNo.Contains(pagination.searchKeyword) ||
+ a.UserName.Contains(pagination.searchKeyword) ||
+ a.UserTrueName.Contains(pagination.searchKeyword) ||
+ a.PhoneNo.Contains(pagination.searchKeyword) ||
a.RoleName.Contains(pagination.searchKeyword));
}
//鏃堕棿鏌ヨ
if (pagination.startDate.HasValue && pagination.endDate.HasValue)
{
- query = query.Where((a, b) => b.CreateDate >= pagination.startDate.Value && b.CreateDate <= pagination.endDate.Value);
+ query = query.Where((a, b) => a.CreateDate >= pagination.startDate.Value && a.CreateDate <= pagination.endDate.Value);
}
//鎺掑簭
if (!string.IsNullOrEmpty(pagination.sortField))
@@ -961,38 +979,38 @@
{
- "CreateDate" => isAcs ? query.OrderBy((a, b) => b.CreateDate) : query.OrderByDescending((a, b) => b.CreateDate),
+ "CreateDate" => isAcs ? query.OrderBy((a, b) => a.CreateDate) : query.OrderByDescending((a, b) => a.CreateDate),
- _ => query.OrderByDescending((a, b) => b.Creater) // 榛樿鎸夊垱寤烘椂闂撮檷搴�
+ _ => query.OrderByDescending((a, b) => a.Creater) // 榛樿鎸夊垱寤烘椂闂撮檷搴�
};
}
else
{
- query = query.OrderByDescending((a, b) => b.Creater);
+ query = query.OrderByDescending((a, b) => a.Creater);
}
var reslut = query.Select((a, b) => new
{
- b.User_Id,
- b.UserName,
- b.UserTrueName,
- b.Unit,
- b.Userteam,
- b.Role_Id,
- b.IsLeader,
- //b.RoleName,
- b.CardNumber,
- b.PhoneNo,
- b.UserPwd,
- b.DeptName,
- b.Dept_Id,
- b.Email,
- b.Enable,
- b.Gender,
- b.HeadImageUrl,
- b.Address,
- b.CreateDate,
- b.Creater,
+ a.User_Id,
+ a.UserName,
+ a.UserTrueName,
+ a.Unit,
+ a.Userteam,
+ a.Role_Id,
+ a.IsLeader,
+ a.CardNumber,
+ a.PhoneNo,
+ a.UserPwd,
+ a.DeptName,
+ a.Dept_Id,
+ a.Email,
+ a.Enable,
+ a.Gender,
+ //b.UserFaceImagePath,
+ b.UserFaceImageName,
+ a.Address,
+ a.CreateDate,
+ a.Creater,
a.RoleName,
}).ToPageList(pagination.pageIndex, pagination.pageSize, ref totalCount);
@@ -1016,8 +1034,49 @@
return new WebResponseContent { Status = false, Message = ex.Message };
}
- }
-
+ }
+
+
+ /// <summary>
+ /// 鎵归噺鍒犻櫎
+ /// </summary>
+ /// <param name="keys">鐢ㄦ埛id</param>
+ /// <returns></returns>
+ public WebResponseContent DelUserList(int[] keys)
+ {
+ WebResponseContent webResponse = new WebResponseContent();
+ foreach (int key in keys)
+ {
+ var user = BaseDal.QueryData(x => x.User_Id == key).FirstOrDefault();
+ if (user == null)
+ {
+ return webResponse.Error("娌℃湁鎵惧埌璇ョ敤鎴�");
+ }
+ var main = _MainServer.QueryData(x => x.UserAccount == user.UserName).FirstOrDefault();
+ var face = _userFace.QueryData(x => x.UserName == user.UserName).FirstOrDefault();
+ if (main.MaintenanceStatus == 1)
+ {
+ return WebResponseContent.Instance.Error("璇ョ敤鎴疯繕鍦ㄦ淇腑锛屾棤娉曞垹闄�");
+ }
+ if (face==null)
+ {
+ BaseDal.DeleteData(user);
+ _MainServer.DeleteData(main);
+ }
+ else
+ {
+ BaseDal.DeleteData(user);
+ _MainServer.DeleteData(main);
+ _userFace.DeleteData(face);
+ }
+ }
+
+ return webResponse.OK();
+ }
+
+
+
+
}
}
--
Gitblit v1.9.3