From cdade79054bddf08239bdbdbbc4d0eafb9497adb Mon Sep 17 00:00:00 2001
From: yanjinhui <3306209981@qq.com>
Date: 星期五, 11 四月 2025 13:42:53 +0800
Subject: [PATCH] 优化更新人脸识别

---
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Common/BaiDuFaceHelper.cs                       |    2 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350013863.png          |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Sys_UserController.cs |   13 ++++
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350001861.png          |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_DTO/System/AddUserDTO.cs                        |   16 ++--
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350004852.png          |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744349998854.png          |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350007862.png          |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350010852.png          |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/2025.jpg                   |    0 
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs               |  117 ++++++++++++++++++++++++++++----------
 项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/ISys_UserService.cs             |    7 ++
 12 files changed, 114 insertions(+), 41 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Common/BaiDuFaceHelper.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Common/BaiDuFaceHelper.cs"
index 5f19dce..4710227 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Common/BaiDuFaceHelper.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Common/BaiDuFaceHelper.cs"
@@ -351,7 +351,7 @@
         /// <summary>
         /// 璇锋眰鏍囪瘑鐮侊紝闅忔満鏁帮紝鍞竴
         /// </summary>
-        public int log_id { get; set;}
+        public string log_id { get; set;}
         /// <summary>
         /// 鐢ㄦ埛id锛堢敱鏁板瓧銆佸瓧姣嶃�佷笅鍒掔嚎缁勬垚锛夛紝闀垮害闄愬埗48B
         /// </summary>
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_DTO/System/AddUserDTO.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_DTO/System/AddUserDTO.cs"
index ec3c6c2..9391b1f 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_DTO/System/AddUserDTO.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_DTO/System/AddUserDTO.cs"
@@ -17,10 +17,7 @@
 
         public string usertruename { get; set; }
 
-        /// <summary>
-        /// 鐧惧害浜戝垎缁�
-        /// </summary>
-      //  public int log_id { get; set; }
+       
 
 
         public string  phoneno { get; set; }
@@ -47,11 +44,14 @@
         public string?path { get; set; }
 
 
-        /// <summary>
-        /// 鍥剧墖token
-        /// </summary>
+        ///// <summary>
+        ///// 鍥剧墖token
+        ///// </summary>
         //public string ?face_token { get; set; }
 
-        
+        ///// <summary>
+        ///// 鐧惧害浜戝垎缁�
+        ///// </summary>
+        //  public int log_id { get; set; }
     }
 }
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/ISys_UserService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/ISys_UserService.cs"
index 288a4a8..f337f41 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/ISys_UserService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/ISys_UserService.cs"
@@ -71,5 +71,12 @@
         /// <returns></returns>
         WebResponseContent SaveFaceFiles(IFormCollection files);
 
+
+        //浜鸿劯鍒犻櫎锛堝垹闄ょ敤鎴风殑鏌愪竴寮犱汉鑴革紝濡傛灉璇ョ敤鎴峰彧鏈変竴寮犱汉鑴稿浘鐗囷紝鍒欏悓鏃跺垹闄ょ敤鎴枫�傦級
+        WebResponseContent DeleteUserIsface(string account);
+
+
+
+
     }
 }
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Sys_UserController.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Sys_UserController.cs"
index 8cef055..30be21b 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Sys_UserController.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Sys_UserController.cs"
@@ -227,6 +227,19 @@
             return Service.SaveFaceFiles(files);
         }
 
+
+
+        /// <summary>
+        ///  //浜鸿劯鍒犻櫎锛堝垹闄ょ敤鎴风殑鏌愪竴寮犱汉鑴革紝濡傛灉璇ョ敤鎴峰彧鏈変竴寮犱汉鑴稿浘鐗囷紝鍒欏悓鏃跺垹闄ょ敤鎴枫�傦級
+        /// </summary>
+        /// <param name="addUserDTO"></param>
+        /// <returns></returns>
+        [HttpPost, Route("DeleteUserIsface"), AllowAnonymous]
+        public WebResponseContent DeleteUserIsface(string account)
+        {
+            return Service.DeleteUserIsface(account);
+        }
+
     }
 
     public class SwaggerLoginRequest
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744349998854.png" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744349998854.png"
new file mode 100644
index 0000000..bc1a709
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744349998854.png"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350001861.png" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350001861.png"
new file mode 100644
index 0000000..c94514a
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350001861.png"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350004852.png" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350004852.png"
new file mode 100644
index 0000000..d8c7e64
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350004852.png"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350007862.png" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350007862.png"
new file mode 100644
index 0000000..c12ede2
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350007862.png"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350010852.png" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350010852.png"
new file mode 100644
index 0000000..378c996
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350010852.png"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350013863.png" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350013863.png"
new file mode 100644
index 0000000..fe676b5
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/1744350013863.png"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/2025.jpg" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/2025.jpg"
new file mode 100644
index 0000000..40c1c10
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Server/wwwroot/image/2025.jpg"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs"
index d1cff0e..9a6cab0 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Sys_UserService.cs"
@@ -469,7 +469,7 @@
                 {
                     return new WebResponseContent { Status = false, Message = "璐﹀彿閲嶅锛岃閲嶆柊褰曞叆" };
                 }
-                var face = _faceServer.QueryData().Select(x => x.GroupID).FirstOrDefault(); ;
+                var face = _faceServer.QueryData().Select(x => x.GroupID).FirstOrDefault(); 
                 var baiduResult = BaiDuFaceHelper.AddUser(new BDUserInfo
                 {
                     ImgPath = addUserDTO.path,
@@ -523,55 +523,58 @@
         {
             try
             {
-
                 // 1. 鏌ヨ鐢ㄦ埛
-                var user = BaseDal.QueryData();
-                var sys = user.Where(x => x.User_Id == addUserDTO.id).FirstOrDefault();
+                var userList = BaseDal.QueryData();
+                var sys = userList.FirstOrDefault(x => x.User_Id == addUserDTO.id);
                 if (sys == null)
                 {
                     return new WebResponseContent { Status = false, Message = "娌℃壘鍒拌鐢ㄦ埛" };
                 }
 
-                // 2. 鏌ヨ浜鸿劯搴撳垎缁� ID
-                var faceGroupID = _faceServer.QueryData().Select(x => x.GroupID).FirstOrDefault();
-
-                // 3. 鍒ゆ柇鏄惁闇�瑕佹洿鏂颁汉鑴镐俊鎭�
-                string faceToken = null;
-                if (!string.IsNullOrEmpty(addUserDTO.path)) // 鍙湁浼犱簡鏂板浘鐗囷紝鎵嶆洿鏂颁汉鑴镐俊鎭�
+                // 2. 妫�鏌ヨ处鍙锋槸鍚︿慨鏀癸紝骞跺垽鏂槸鍚﹂噸澶�//StringComparison.OrdinalIgnoreCase锛氳〃绀哄拷鐣ュぇ灏忓啓杩涜姣旇緝锛屾瘮濡� "admin" 鍜� "ADMIN" 涔熻涓烘槸鐩哥瓑鐨�
+                if (!string.Equals(sys.UserName ,addUserDTO.username))
                 {
-                    var baiduResult = BaiDuFaceHelper.AddUser(new BDUserInfo
+                    var existUser = userList.FirstOrDefault(a => a.UserName == addUserDTO.username);
+                    if (existUser != null)
                     {
-                        ImgPath = addUserDTO.path,
-                        user_id = addUserDTO.username,
-                        group_id = faceGroupID // 杩欓噷搴旇濉櫨搴︿汉鑴稿簱鍒嗙粍
-                    });
-
-                    // 4. 鍒ゆ柇鐧惧害 API 鏄惁鎴愬姛
-                    if (baiduResult == null || baiduResult.error_code != 0)
-                    {
-                        return new WebResponseContent { Status = false, Message = "璇ュ浘鐗囦篃瀛樺湪锛屼笉瑕侀噸澶嶄笂浼狅細" + baiduResult.error_msg };
+                        return new WebResponseContent { Status = false, Message = "璐﹀彿閲嶅锛岃閲嶆柊褰曞叆" };
                     }
-
-                    // 5. 鍙湁褰撲笂浼犱簡鏂板浘鐗囧苟鎴愬姛鏃讹紝鎵嶆洿鏂拌繖浜涘瓧娈�
-                    faceToken = baiduResult.result.face_token;
-                    sys.Log_id = baiduResult.log_id;
-                    sys.HeadImageUrl = addUserDTO.path;
+                    sys.UserName = addUserDTO.username; // 纭鍙互鏀规椂鎵嶄慨鏀�
                 }
 
-                // 6. 鏇存柊鐢ㄦ埛鍏朵粬淇℃伅
-                sys.UserName = addUserDTO.username;
+                // 3. 鏇存柊鍏朵粬鐢ㄦ埛淇℃伅
                 sys.UserTrueName = addUserDTO.usertruename;
-                sys.Face_token = faceToken ?? sys.Face_token; // 鍙湁褰� faceToken 鏈夊�兼椂鎵嶆洿鏂帮紝鍚﹀垯淇濇寔鍘熷��
                 sys.PhoneNo = addUserDTO.phoneno;
                 sys.Role_Id = addUserDTO.roleid;
                 sys.RoleName = addUserDTO.rolename;
                 sys.Enable = addUserDTO.enable;
-                var list = user.Where(a => a.UserName == addUserDTO.username).FirstOrDefault();
-                if (list != null)
+
+                // 4. 鏌ヨ浜鸿劯搴撳垎缁� ID
+                var faceGroupID = _faceServer.QueryData().Select(x => x.GroupID).FirstOrDefault();
+
+                // 5. 鍒ゆ柇鏄惁闇�瑕佹洿鏂颁汉鑴镐俊鎭�
+                if (!string.Equals(sys.HeadImageUrl,addUserDTO.path)) // 鏈夋柊鍥剧墖鎵嶅鐞嗕汉鑴告敞鍐�
                 {
-                    return new WebResponseContent { Status = false, Message = "璐﹀彿閲嶅锛岃閲嶆柊褰曞叆" };
+                    var baiduResult = BaiDuFaceHelper.AddUser(new BDUserInfo
+                    {
+                        ImgPath = addUserDTO.path,
+                        user_id = sys.UserName,
+                        group_id = faceGroupID
+                    });
+
+                    // 6. 鍒ゆ柇鐧惧害 API 鏄惁鎴愬姛
+                    if (baiduResult == null || baiduResult.error_code != 0)
+                    {
+                        return new WebResponseContent { Status = false, Message = "浜鸿劯鏇存柊澶辫触锛�" + baiduResult.error_msg };
+                    }
+
+                    // 7. 鏇存柊浜鸿劯鐩稿叧瀛楁
+                    sys.Log_id = baiduResult.log_id;
+                    sys.HeadImageUrl = addUserDTO.path;
+                    sys.Face_token = baiduResult.result.face_token;
                 }
-                // 7. 鏇存柊鏁版嵁搴�
+
+                // 8. 鏇存柊鏁版嵁搴�
                 BaseDal.UpdateData(sys);
 
                 return new WebResponseContent { Status = true, Data = sys };
@@ -581,6 +584,7 @@
                 return new WebResponseContent { Status = false, Message = "澶辫触锛�" + ex.Message };
             }
         }
+
 
 
 
@@ -726,5 +730,54 @@
         {
             return BaseDal.QueryFirst(x => x.UserName == userName && x.UserPwd == password, x => new UserInfo { HeadImageUrl = x.HeadImageUrl, RoleId = x.Role_Id, TenantId = x.TenantId, UserId = x.User_Id, UserName = x.UserName, UserTrueName = x.UserTrueName });
         }
+
+        /// <summary>
+        /// 浜鸿劯鍒犻櫎锛堝垹闄ょ敤鎴风殑鏌愪竴寮犱汉鑴革紝濡傛灉璇ョ敤鎴峰彧鏈変竴寮犱汉鑴稿浘鐗囷紝鍒欏悓鏃跺垹闄ょ敤鎴枫�傦級
+        /// </summary>
+        /// <param name="addUserDTO"></param>
+        /// <returns></returns>
+        /// <exception cref="NotImplementedException"></exception>
+        public WebResponseContent DeleteUserIsface(string account)
+        {
+            try
+            {
+
+                // 1. 鏌ヨ浜鸿劯搴撳垎缁� ID
+                var faceGroupID = _faceServer.QueryData().Select(x => x.GroupID).FirstOrDefault();
+                //2.鏌ヨ瑕佸垹閭d釜鐢ㄦ埛鐨�
+                var user = BaseDal.QueryData(x => x.UserName == account).FirstOrDefault();
+                if (user == null)
+                {
+                    return new WebResponseContent { Status = false, Message = "鐢ㄦ埛涓嶅瓨鍦紝璇锋鏌ヨ处鍙锋槸鍚﹁緭鍏ユ纭�" };
+                }
+
+                WIDESEAWCS_Common.DeleteUserImg deleteUserImg = new WIDESEAWCS_Common.DeleteUserImg();
+                deleteUserImg.group_id = faceGroupID;
+                deleteUserImg.user_id = account;
+                deleteUserImg.face_token = user.Face_token;
+                deleteUserImg.log_id = user.Log_id;
+
+                string apiResult = BaiDuFaceHelper.DeleteUserImg(deleteUserImg);//缁欑敤鎴疯处鍙�/鐢ㄦ埛缁刬d/Face_token/Log_id
+
+                // 2. 瑙f瀽杩斿洖缁撴灉锛屽垽鏂垹闄ゆ槸鍚︽垚鍔�
+                dynamic resultObj = JsonConvert.DeserializeObject(apiResult);
+                if (resultObj.error_code == 0)
+                {
+                    if (user != null)
+                    {
+                        BaseDal.DeleteData(user);
+                    }
+                    return WebResponseContent.Instance.OK("鍒犻櫎鎴愬姛");
+                }
+                else
+                {
+                    return WebResponseContent.Instance.Error("鐧惧害 API 鍒犻櫎澶辫触锛�" + resultObj.error_msg);
+                }
+            }
+            catch (Exception ex)
+            {
+                return WebResponseContent.Instance.Error("鍒犻櫎鐢ㄦ埛澶辫触锛�" + ex.Message);
+            }
+        }
     }
 }

--
Gitblit v1.9.3