PLC
yanjinhui
2025-04-24 461ccbda1d9d3fef42f250771c2fd30702755c16
ÏîÄ¿´úÂë/WIDESEAWCS_Server Õýʽ/WIDESEAWCS_SystemServices/Sys_UserService.cs
@@ -22,6 +22,8 @@
using Newtonsoft.Json;
using OfficeOpenXml.FormulaParsing.Excel.Functions.Math;
using System.Security.Policy;
using System.Runtime.InteropServices;
using System;
namespace WIDESEAWCS_SystemServices
{
@@ -51,110 +53,7 @@
        }
        //#region åŽŸæœ¬ç™»å…¥
        //public WebResponseContent Login(LoginInfo loginInfo)
        //{
        //    WebResponseContent content = new WebResponseContent();
        //    try
        //    {
        //        // BaseDal.QueryFirst(x => x.UserName == loginInfo.UserName);
        //        string msg = string.Empty;
        //        #region ä¸´æ—¶ä½¿ç”¨
        //        try
        //        {
        //            loginInfo.Password = loginInfo.Password.EncryptDES(AppSecret.User);
        //        }
        //        catch
        //        {
        //        }
        //        #endregion
        //        if (!string.IsNullOrEmpty(loginInfo.path))
        //        {
        //            var gruoid = _faceRecognitionRepository.QueryData().Select(x => x.GroupID).FirstOrDefault();
        //            if (gruoid == null)
        //            {
        //                return new WebResponseContent { Status = false, Message = "没找到该组" };
        //            }
        //            var faceResult = BaiDuFaceHelper.FaceSearch(loginInfo.path, gruoid);
        //            if (faceResult != null && faceResult.error_code == 0)
        //            {
        //                // èŽ·å–æœ€é«˜åŒ¹é…åº¦çš„ç”¨æˆ·
        //                var bestMatch = faceResult.result.user_list.OrderByDescending(u => u.score).FirstOrDefault();//拿第一个最高的
        //                if (bestMatch != null && double.TryParse(bestMatch.score, out double score) && score > 80) // è®¾å®š80分为可信度阈值
        //                {
        //                    //return new WebResponseContent {Status=true,Data = true,Message="识别登入成功" };
        //                }
        //            }
        //            return WebResponseContent.Instance.Error("人脸识别失败,请重试");
        //        }
        //        UserInfo user = BaseDal.GetUserInfo(loginInfo.UserName, loginInfo.Password);
        //        var disbled = BaseDal.QueryFirst(x => x.UserName == loginInfo.UserName);//根据这个用户名来查看用户
        //        if (user != null)
        //        {
        //            object obj = _menuService.GetMenuActionList(user.RoleId);
        //            if (obj is not IEnumerable<object> list)
        //            {
        //                return WebResponseContent.Instance.Error("无登录权限");
        //            }
        //            if (!list.Any())
        //            {
        //                return WebResponseContent.Instance.Error("无登录权限");
        //            }
        //            if (disbled.Enable != 1)
        //            {
        //                return WebResponseContent.Instance.Error("你的账号已被禁用,请联系管理员");
        //            }
        //            string token = JwtHelper.IssueJwt(new TokenModelJwt()
        //            {
        //                UserId = user.UserId,
        //                RoleId = user.RoleId,
        //                UserName = user.UserName,
        //                TenantId = user.TenantId,
        //            });
        //            //登入历史记录
        //            var loghis = new Dt_LoginHistory
        //            {
        //                Account = user.UserName,
        //                TrurName = user.UserTrueName,
        //                CreateDate = DateTime.Now
        //            };
        //            _cacheService.AddOrUpdate(user.UserId.ToString(), token);
        //            _loginHistoryRepository.AddData(loghis);
        //            content = WebResponseContent.Instance.OK(data: new { token, userName = user.UserTrueName, img = user.HeadImageUrl, ID = user.UserId, RoleId = user.RoleId });
        //        }
        //        else
        //        {
        //            content = WebResponseContent.Instance.Error("账号或密码错误");
        //        }
        //    }
        //    catch (Exception ex)
        //    {
        //        content = WebResponseContent.Instance.Error(ex.Message);
        //    }
        //    return content;
        //}
        //#endregion
        #region  äººè„¸è¯†åˆ«ç™»å…¥æŽ¥å£
        /// <summary>
        /// äººè„¸è¯†åˆ«ç™»å…¥æŽ¥å£
        /// </summary>
@@ -225,58 +124,58 @@
                    user = BaseDal.GetUserInfo(loginInfo.UserName, loginInfo.Password);
                }
                    // å¦‚果找到用户
                    if (user != null)
                // å¦‚果找到用户
                if (user != null)
                {
                    var disbled = BaseDal.QueryFirst(x => x.UserName == loginInfo.UserName);
                    if (disbled.Enable != 1)
                    {
                        var disbled = BaseDal.QueryFirst(x => x.UserName == loginInfo.UserName);
                        if (disbled.Enable != 1)
                        {
                            return WebResponseContent.Instance.Error("你的账号已被禁用,请联系管理员");
                        }
                        // èŽ·å–è§’è‰²æƒé™
                        object obj = _menuService.GetMenuActionList(user.RoleId);
                        if (obj is not IEnumerable<object> list || !list.Any())
                        {
                            return WebResponseContent.Instance.Error("无登录权限");
                        }
                        // ç”Ÿæˆ JWT Token
                        string token = JwtHelper.IssueJwt(new TokenModelJwt()
                        {
                            UserId = user.UserId,
                            RoleId = user.RoleId,
                            UserName = user.UserName,
                            TenantId = user.TenantId,
                        });
                        // è®°å½•登录历史
                        var loghis = new Dt_LoginHistory
                        {
                            Account = user.UserName,
                            TrurName = user.UserTrueName,
                            CreateDate = DateTime.Now
                        };
                        // ä¿å­˜ç”¨æˆ·ç™»å½•信息
                        _cacheService.AddOrUpdate(user.UserId.ToString(), token);
                        _loginHistoryRepository.AddData(loghis);
                        // è¿”回响应
                        content = WebResponseContent.Instance.OK(data: new
                        {
                            token,
                            userName = user.UserTrueName,
                            img = user.HeadImageUrl,
                            ID = user.UserId,
                            RoleId = user.RoleId
                        });
                        return WebResponseContent.Instance.Error("你的账号已被禁用,请联系管理员");
                    }
                    else
                    // èŽ·å–è§’è‰²æƒé™
                    object obj = _menuService.GetMenuActionList(user.RoleId);
                    if (obj is not IEnumerable<object> list || !list.Any())
                    {
                        content = WebResponseContent.Instance.Error("账号或密码错误");
                        return WebResponseContent.Instance.Error("无登录权限");
                    }
                    // ç”Ÿæˆ JWT Token
                    string token = JwtHelper.IssueJwt(new TokenModelJwt()
                    {
                        UserId = user.UserId,
                        RoleId = user.RoleId,
                        UserName = user.UserName,
                        TenantId = user.TenantId,
                    });
                    // è®°å½•登录历史
                    var loghis = new Dt_LoginHistory
                    {
                        Account = user.UserName,
                        TrurName = user.UserTrueName,
                        CreateDate = DateTime.Now
                    };
                    // ä¿å­˜ç”¨æˆ·ç™»å½•信息
                    _cacheService.AddOrUpdate(user.UserId.ToString(), token);
                    _loginHistoryRepository.AddData(loghis);
                    // è¿”回响应
                    content = WebResponseContent.Instance.OK(data: new
                    {
                        token,
                        userName = user.UserTrueName,
                        img = user.HeadImageUrl,
                        ID = user.UserId,
                        RoleId = user.RoleId
                    });
                }
                else
                {
                    content = WebResponseContent.Instance.Error("账号或密码错误");
                }
            }
            catch (Exception ex)
            {
@@ -285,8 +184,8 @@
            return content;
        }
        #endregion
        public override WebResponseContent UpdateData(SaveModel saveModel)
@@ -421,7 +320,12 @@
            }
        }
        /// <summary>
        /// æ ¹æ®ç”¨æˆ·ç»„来查看当前作业的权限
        /// </summary>
        /// <param name="userId">用户id</param>
        /// <param name="group">用户分组</param>
        /// <returns></returns>
        public WebResponseContent PermissionView(int userId, string group)
        {
            try
@@ -731,7 +635,7 @@
        /// <summary>
        /// æ›´æ–°ç”¨æˆ·
        ///百度云 æ›´æ–°ç”¨æˆ·
        /// </summary>
        /// <param name="addUserDTO"></param>
        /// <returns></returns>
@@ -740,48 +644,57 @@
            try
            {
                // 1. æŸ¥è¯¢ç”¨æˆ·
                var sys = BaseDal.QueryData(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 = _faceRecognitionRepository.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;
                // 7. æ›´æ–°æ•°æ®åº“
                // 4. æŸ¥è¯¢äººè„¸åº“分组 ID
                var faceGroupID = _faceRecognitionRepository.QueryData().Select(x => x.GroupID).FirstOrDefault();
                // 5. åˆ¤æ–­æ˜¯å¦éœ€è¦æ›´æ–°äººè„¸ä¿¡æ¯Equals æ˜¯ .NET ä¸­ç”¨äºŽæ¯”较两个对象是否相等
                if (!string.Equals(sys.HeadImageUrl, addUserDTO.path)) // æœ‰æ–°å›¾ç‰‡æ‰å¤„理人脸注册=> å‰é¢çš„写法等于=if (sys.HeadImageUrl!=addUserDTO.path)
                {
                    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;
                }
                // 8. æ›´æ–°æ•°æ®åº“
                BaseDal.UpdateData(sys);
                return new WebResponseContent { Status = true, Data = sys };
@@ -791,6 +704,7 @@
                return new WebResponseContent { Status = false, Message = "失败:" + ex.Message };
            }
        }
@@ -812,7 +726,7 @@
                deleteUserImg.group_id = faceGroupID;
                deleteUserImg.user_id = account;
                string apiResult = BaiDuFaceHelper.DeleteUser(deleteUserImg);//只要给token和log_id
                string apiResult = BaiDuFaceHelper.DeleteUser(deleteUserImg);//只要给用户账号和用户组id
                // 2. è§£æžè¿”回结果,判断删除是否成功
                dynamic resultObj = JsonConvert.DeserializeObject(apiResult);
@@ -926,6 +840,54 @@
            }
        }
        /// <summary>
        /// äººè„¸åˆ é™¤ï¼ˆåˆ é™¤ç”¨æˆ·çš„æŸä¸€å¼ äººè„¸ï¼Œå¦‚果该用户只有一张人脸图片,则同时删除用户。)
        /// </summary>
        /// <param name="addUserDTO"></param>
        /// <returns></returns>
        /// <exception cref="NotImplementedException"></exception>
        public WebResponseContent DeleteUserIsface(string account)
        {
            try
            {
                // 1. æŸ¥è¯¢äººè„¸åº“分组 ID
                var faceGroupID = _faceRecognitionRepository.QueryData().Select(x => x.GroupID).FirstOrDefault();
                //2.查询要删那个用户的
                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);//给用户账号/用户组id/Face_token/Log_id
                // 2. è§£æžè¿”回结果,判断删除是否成功
                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);
            }
        }
    }
}