【無私分享:從入門到精通ASP.NET MVC】從0開始,一塊兒搭框架、作項目 (10)部門管理、崗位管理和員工管理

索引html

【無私分享:從入門到精通ASP.NET MVC】從0開始,一塊兒搭框架、作項目 目錄索引

簡述數據庫

今天咱們來增長部門管理、崗位管理和員工管理json

項目準備服務器

咱們用的工具是:VS 2013 + SqlServer 2012 + IIS7.5微信

但願你們對ASP.NET MVC有一個初步的理解,理論性的東西咱們不作過多解釋,有些地方不理解也不要緊,會用就好了,用的多了,用的久了,天然就理解了。mvc

項目開始框架

咱們前面講過不少增刪改查和列表的操做了,這裏再也不繼續羅列這些操做了,直接上代碼,員工管理是比較複雜的部門,要爲員工分配角色、部門崗位、還有檔案信息,咱們重點介紹一下這一塊ide

1、部門管理

首先,部門表SYS_DEPARTMENT工具

表名:SYS_DEPARTMENT
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID nvarchar 36 0       主鍵ID
2 CODE nvarchar 100 0         部門編號,橫向增加
3 NAME nvarchar 200 0         部門名稱
4 BUSINESSLEVEL int 4 0         業務等級
5 SHOWORDER int 4 0         部門排序
6 CREATEPERID nvarchar 36 0         建立者編號
7 CREATEDATE date 3 0         建立時間
8 PARENTID nvarchar 36 0         上級部門ID
9 UPDATEDATE date 3 0         修改時間
10 UPDATEUSER nvarchar 36 0         修改人
11 PARENTCODE nvarchar 100 0          

T-SQL:post

 1 USE [wkmvc_db]
 2 GO
 3 /****** Object:  Table [dbo].[SYS_DEPARTMENT]    Script Date: 2016/6/20 15:55:28 ******/
 4 SET ANSI_NULLS ON
 5 GO
 6 SET QUOTED_IDENTIFIER ON
 7 GO
 8 CREATE TABLE [dbo].[SYS_DEPARTMENT](
 9     [ID] [nvarchar](36) NOT NULL,
10     [CODE] [nvarchar](100) NULL,
11     [NAME] [nvarchar](200) NULL,
12     [BUSINESSLEVEL] [int] NULL,
13     [SHOWORDER] [int] NULL,
14     [CREATEPERID] [nvarchar](36) NULL,
15     [CREATEDATE] [date] NULL,
16     [PARENTID] [nvarchar](36) NULL,
17     [UPDATEDATE] [date] NULL,
18     [UPDATEUSER] [nvarchar](36) NULL,
19     [PARENTCODE] [nvarchar](100) NULL,
20  CONSTRAINT [PK_SYS_DEPARTMENT] PRIMARY KEY CLUSTERED 
21 (
22     [ID] ASC
23 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
24 ) ON [PRIMARY]
25 
26 GO
27 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'ID'
28 GO
29 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'部門編號,橫向增加' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'CODE'
30 GO
31 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'部門名稱' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'NAME'
32 GO
33 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'業務等級' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'BUSINESSLEVEL'
34 GO
35 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'部門排序' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'SHOWORDER'
36 GO
37 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立者編號' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'CREATEPERID'
38 GO
39 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'CREATEDATE'
40 GO
41 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'上級部門ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'PARENTID'
42 GO
43 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'UPDATEDATE'
44 GO
45 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改人' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_DEPARTMENT', @level2type=N'COLUMN',@level2name=N'UPDATEUSER'
46 GO
View Code

 

一、在SysManage下新建控制器

 

二、仍是注意的 別忘了配置xml注入,否則會提示未將對象設置引用到實例的啊

 

三、聲明容器

 

四、部門管理就是簡單的一個 增刪改查,咱們前面作過不少不少這樣的操做了,這裏我就不在單步解釋了,我把方法給你們

4.1加載主頁

 1 /// <summary>
 2         /// 加載主頁
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "Department", OperaAction = "View")]
 5         public ActionResult Index()
 6         {
 7             try
 8             {
 9                 ViewBag.Search = base.keywords;
10                 return View(BindList());
11             }
12             catch (Exception e)
13             {
14                 WriteLog(Common.Enums.enumOperator.Select, "部門管理加載主頁:", e);
15                 throw e.InnerException;
16             }
17         }
View Code
/// <summary>
        /// 分頁查詢部門列表
        /// </summary>
        private object BindList()
        {
            //基礎數據
            var query = this.DepartmentManage.LoadAll(null);

            //遞歸排序(無分頁)
            var result = this.DepartmentManage.RecursiveDepartment(query.ToList())
                .Select(p => new
            {
                p.ID,
                p.NAME,
                DepartName=DepartmentManage.GetDepartmentName(p.NAME,p.BUSINESSLEVEL),
                p.BUSINESSLEVEL,
                p.SHOWORDER,
                p.CREATEDATE
            });

            //查詢關鍵字
            if (!string.IsNullOrEmpty(keywords))
            {
                result = result.Where(p => p.NAME.Contains(keywords));
            }

            return Common.JsonConverter.JsonClass(result);
        }
View Code

4.2加載詳情頁

 1 /// <summary>
 2         /// 加載詳情頁
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "Department", OperaAction = "Detail")]
 5         public ActionResult Detail(string id)
 6         {
 7             try
 8             {
 9                 var entity = new Domain.SYS_DEPARTMENT();
10 
11                 ViewBag.moduleparent = this.DepartmentManage.GetDepartmentByDetail();
12 
13                 //添加子部門
14                 string parentId = Request.QueryString["parentId"];
15 
16                 if (!string.IsNullOrEmpty(parentId))
17                 {
18                     entity.PARENTID = parentId;
19                 }
20                 if (!string.IsNullOrEmpty(id))
21                 {
22                     entity = this.DepartmentManage.Get(p => p.ID == id);
23                 }
24                 return View(entity);
25             }
26             catch (Exception e)
27             {
28                 WriteLog(Common.Enums.enumOperator.Select, "部門管理加載詳情頁:", e);
29                 throw e.InnerException;
30             }
31         }
View Code

4.3保存部門

  1 /// <summary>
  2         /// 保存部門
  3         /// </summary>
  4         [ValidateInput(false)]
  5         [UserAuthorizeAttribute(ModuleAlias = "Department", OperaAction = "Add,Edit")]
  6         public ActionResult Save(Domain.SYS_DEPARTMENT entity)
  7         {
  8             bool isEdit = false;
  9             var json = new JsonHelper() { Msg = "保存成功", Status = "n" };
 10             try
 11             {
 12                 var _entity = new Domain.SYS_DEPARTMENT();
 13                 if (entity != null)
 14                 {
 15                     if (!string.IsNullOrEmpty(entity.ID))
 16                     {
 17                         #region 修改
 18                         _entity = this.DepartmentManage.Get(p => p.ID == entity.ID);
 19                         entity.CREATEDATE = _entity.CREATEDATE;
 20                         entity.CREATEPERID = _entity.CREATEPERID;
 21                         entity.UPDATEDATE = DateTime.Now;
 22                         entity.UPDATEUSER = this.CurrentUser.Name;
 23                         if (entity.PARENTID != _entity.PARENTID)
 24                         {
 25                             entity.CODE = this.DepartmentManage.CreateCode(entity.PARENTID);
 26                         }
 27                         else
 28                         {
 29                             entity.CODE = _entity.CODE;
 30                         }
 31                         //獲取父級記錄
 32                         if (string.IsNullOrEmpty(_entity.PARENTID))
 33                         {
 34                             //業務等級
 35                             entity.BUSINESSLEVEL = 1;
 36                             entity.PARENTCODE = null;
 37                         }
 38                         else
 39                         {
 40                             var parententity = this.DepartmentManage.Get(p => p.ID == entity.PARENTID);
 41                             entity.BUSINESSLEVEL = parententity.BUSINESSLEVEL + 1;
 42                             entity.PARENTCODE = parententity.CODE;
 43                         }
 44                         #endregion
 45                         isEdit = true;
 46                         _entity = entity;
 47                     }
 48                     else
 49                     {
 50                         #region 添加
 51                         _entity = entity;
 52                         _entity.ID = Guid.NewGuid().ToString();
 53                         _entity.CREATEDATE = DateTime.Now;
 54                         _entity.CREATEPERID = this.CurrentUser.Name;
 55                         _entity.UPDATEDATE = DateTime.Now;
 56                         _entity.UPDATEUSER = this.CurrentUser.Name;
 57                         //根據上級部門的ID肯定當前部門的CODE
 58                         _entity.CODE = this.DepartmentManage.CreateCode(entity.PARENTID);
 59                         //獲取父級記錄
 60                         if (string.IsNullOrEmpty(entity.PARENTID))
 61                         {
 62                             //業務等級
 63                             entity.BUSINESSLEVEL = 1;
 64                             entity.PARENTCODE = null;
 65                         }
 66                         else
 67                         {
 68                             var parententity = this.DepartmentManage.Get(p => p.ID == entity.PARENTID);
 69                             entity.BUSINESSLEVEL = parententity.BUSINESSLEVEL + 1;
 70                             entity.PARENTCODE = parententity.CODE;
 71                         }
 72                         #endregion
 73                     }
 74                     //判斷同一個部門下,是否重名 
 75                     var predicate = PredicateBuilder.True<Domain.SYS_DEPARTMENT>();
 76                     predicate = predicate.And(p => p.PARENTID == _entity.PARENTID);
 77                     predicate = predicate.And(p => p.NAME == _entity.NAME);
 78                     predicate = predicate.And(p => p.ID != _entity.ID);
 79                     if (!this.DepartmentManage.IsExist(predicate))
 80                     {
 81                         if (this.DepartmentManage.SaveOrUpdate(_entity, isEdit))
 82                         {
 83                             json.Status = "y";
 84                         }
 85                         else
 86                         {
 87                             json.Msg = "保存失敗";
 88                         }
 89                     }
 90                     else
 91                     {
 92                         json.Msg = "部門" + entity.NAME + "已存在,不能重複添加";
 93                     }
 94                 }
 95                 else
 96                 {
 97                     json.Msg = "未找到須要保存的部門信息";
 98                 }
 99                 if (isEdit)
100                 {
101                     WriteLog(Common.Enums.enumOperator.Edit, "修改部門信息,結果:" + json.Msg, Common.Enums.enumLog4net.INFO);
102                 }
103                 else
104                 {
105                     WriteLog(Common.Enums.enumOperator.Add, "添加部門信息,結果:" + json.Msg, Common.Enums.enumLog4net.INFO);
106                 }
107             }
108             catch (Exception e)
109             {
110                 json.Msg = "保存部門信息發生內部錯誤!";
111                 WriteLog(Common.Enums.enumOperator.None, "保存部門信息:", e);
112             }
113             return Json(json);
114 
115         }
View Code

4.4刪除部門

 1 /// <summary>
 2         /// 刪除部門
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "Department", OperaAction = "Remove")]
 5         public ActionResult Delete(string idList)
 6         {
 7             JsonHelper json = new JsonHelper() { Msg = "刪除部門成功", ReUrl = "/Department/Index", Status = "n" };
 8             try
 9             {
10                 if (!string.IsNullOrEmpty(idList))
11                 {
12                     idList = idList.TrimEnd(',');
13                     //判斷是否有下屬部門
14                     if (!this.DepartmentManage.DepartmentIsExists(idList))
15                     {
16                         //判斷該部門是否有崗位
17                         if (!this.PostManage.IsExist(p => idList.Contains(p.FK_DEPARTID)))
18                         {                           
19                                 var idList1 = idList.Split(',').ToList();
20                                 this.DepartmentManage.Delete(p => idList.Contains(p.ID));
21                                 json.Status = "y";                          
22                         }
23                         else
24                         {
25                             json.Msg = "該部門有崗位信息不能刪除";
26                         }
27                     }
28                     else
29                     {
30                         json.Msg = "該部門有下屬部門不能刪除";
31                     }
32                 }
33                 else
34                 {
35                     json.Msg = "未找到要刪除的部門記錄";
36                 }
37                 WriteLog(Common.Enums.enumOperator.Remove, "刪除部門:" + json.Msg, Common.Enums.enumLog4net.WARN);
38             }
39             catch (Exception e)
40             {
41                 json.Msg = "刪除部門發生內部錯誤!";
42                 WriteLog(Common.Enums.enumOperator.Remove, "刪除部門:", e);
43             }
44             return Json(json);
45         }
View Code

4.5在崗位管理中 咱們須要用到的部門的樹形菜單

 1 /// <summary>
 2         /// 獲取部門樹形菜單
 3         /// </summary>
 4         public ActionResult GetTree()
 5         {
 6             var json = new JsonHelper() { Msg = "Success", Status = "y" };
 7 
 8             try
 9             {
10                 //獲取部門列表 按照 SHOWORDER字段 升序排列
11                 var query = this.DepartmentManage.LoadAll(null).OrderBy(p => p.SHOWORDER).ToList();
12                 var result = query.Select(m => new
13                 {
14                     id = m.ID,
15                     parent = !string.IsNullOrEmpty(m.PARENTID) ? m.PARENTID.ToString() : "#",
16                     text = m.NAME,
17                     icon = m.BUSINESSLEVEL == 0 ? "fa fa-circle text-warning" : "fa fa-circle text-navy"
18                 }).ToList();
19 
20                 json.Data = result;
21             }
22             catch (Exception e)
23             {
24                 json.Status = "n";
25                 json.Msg = "服務器忙,請稍後再試!";
26                 WriteLog(Common.Enums.enumOperator.Select, "權限管理,獲取模塊樹:", e);
27             }
28             return Json(json);
29         }
View Code

 

2、崗位管理

崗位管理,咱們參照權限管理的展現方式,左右分欄展現,左側顯示部門,右側顯示部門下的崗位

 

一、崗位表SYS_POST

 

表名:SYS_POST
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID nvarchar 36 0       主鍵ID
2 FK_DEPARTID nvarchar 36 0        
3 POSTNAME nvarchar 100 0         崗位名稱
4 POSTTYPE nvarchar 36 0         崗位類型
5 REMARK nvarchar 500 0         崗位備註
6 SHOWORDER int 4 0         排序
7 CREATEUSER nvarchar 50 0         建立者ID
8 CREATEDATE datetime 8 3         建立時間
9 UPDATEDATE datetime 8 3         修改時間
10 UPDATEUSER nvarchar 36 0         修改者

T-SQL:

 1 USE [wkmvc_db]
 2 GO
 3 /****** Object:  Table [dbo].[SYS_POST]    Script Date: 2016/6/20 16:13:10 ******/
 4 SET ANSI_NULLS ON
 5 GO
 6 SET QUOTED_IDENTIFIER ON
 7 GO
 8 CREATE TABLE [dbo].[SYS_POST](
 9     [ID] [nvarchar](36) NOT NULL,
10     [FK_DEPARTID] [nvarchar](36) NOT NULL,
11     [POSTNAME] [nvarchar](100) NULL,
12     [POSTTYPE] [nvarchar](36) NOT NULL,
13     [REMARK] [nvarchar](500) NULL,
14     [SHOWORDER] [int] NULL,
15     [CREATEUSER] [nvarchar](50) NULL,
16     [CREATEDATE] [datetime] NOT NULL,
17     [UPDATEDATE] [datetime] NULL,
18     [UPDATEUSER] [nvarchar](36) NULL,
19  CONSTRAINT [PK_SYS_POST] PRIMARY KEY CLUSTERED 
20 (
21     [ID] ASC
22 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
23 ) ON [PRIMARY]
24 
25 GO
26 ALTER TABLE [dbo].[SYS_POST]  WITH CHECK ADD  CONSTRAINT [FK_SYS_POST_SYS_DEPARTMENT] FOREIGN KEY([FK_DEPARTID])
27 REFERENCES [dbo].[SYS_DEPARTMENT] ([ID])
28 GO
29 ALTER TABLE [dbo].[SYS_POST] CHECK CONSTRAINT [FK_SYS_POST_SYS_DEPARTMENT]
30 GO
31 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'ID'
32 GO
33 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'崗位名稱' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'POSTNAME'
34 GO
35 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'崗位類型' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'POSTTYPE'
36 GO
37 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'崗位備註' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'REMARK'
38 GO
39 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'排序' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'SHOWORDER'
40 GO
41 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立者ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'CREATEUSER'
42 GO
43 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'CREATEDATE'
44 GO
45 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'UPDATEDATE'
46 GO
47 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改者' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST', @level2type=N'COLUMN',@level2name=N'UPDATEUSER'
48 GO
View Code

 

二、一樣在SysManage 下新建崗位控制器 PostController

 

三、聲明容器

 1 #region 聲明容器
 2         /// <summary>
 3         /// 崗位
 4         /// </summary>
 5         IPostManage PostManage { get; set; }
 6         /// <summary>
 7         /// 部門
 8         /// </summary>
 9         IDepartmentManage DepartmentManage { get; set; }
10         /// <summary>
11         /// 字典編碼
12         /// </summary>
13         ICodeManage CodeManage { get; set; }
14         /// <summary>
15         /// 崗位人員
16         /// </summary>
17         IPostUserManage PostUserManage { get; set; }
18         #endregion
View Code

 

四、既然是左右分欄,因此咱們須要一個Home視圖頁,

 

五、當點擊左側的部門的時候 咱們就爲Iframe 賦值了頁面地址 Post/Index 而且傳入了部門ID 

5.1崗位管理 崗位列表

 1  /// <summary>
 2         /// 崗位管理 崗位列表
 3         /// </summary>
 4         /// <returns></returns>
 5         [UserAuthorizeAttribute(ModuleAlias = "Post", OperaAction = "View")]
 6         public ActionResult Index()
 7         {
 8             try
 9             {
10                 #region 處理查詢參數
11                 //獲取部門ID
12                 var departId = Request.QueryString["departId"] ?? (Request.Form["departId"] ?? "");
13                 //崗位類型
14                 string posttype = Request.QueryString["posttype"];
15 
16                 ViewBag.Search = base.keywords;
17                 #endregion
18 
19                 //若是部門ID不爲空或NULL
20                 if (!string.IsNullOrEmpty(departId))
21                 {                    
22                     //部門信息
23                     var department = this.DepartmentManage.Get(p => p.ID == departId);
24 
25                     ViewBag.Department = department;
26 
27                     ViewData["post"] = posttype;
28 
29                     ViewData["PostType"] = this.CodeManage.GetCode("POSTTYPE");
30 
31                     return View(BindList(posttype, departId));
32                 }
33 
34                 return View();
35             }
36             catch (Exception e)
37             {
38                 WriteLog(Common.Enums.enumOperator.Select, "對模塊權限按鈕的管理加載主頁:", e);
39                 throw e.InnerException;
40             }
41         }
View Code
 1 /// <summary>
 2         /// 分頁查詢崗位列表
 3         /// </summary>
 4         private Common.PageInfo BindList(string posttype, string departId)
 5         {
 6             //基礎數據
 7             var query = this.PostManage.LoadAll(null);
 8             //崗位類型
 9             if (!string.IsNullOrEmpty(posttype))
10             {
11                 query = query.Where(p => p.POSTTYPE == posttype && p.FK_DEPARTID == departId);
12             }
13             else
14             {
15                 query = query.Where(p =>  p.FK_DEPARTID == departId);
16             }
17             //查詢關鍵字
18             if (!string.IsNullOrEmpty(keywords))
19             {
20                 query = query.Where(p => p.POSTNAME.Contains(keywords));
21             }
22             //排序
23             query = query.OrderBy(p => p.SHOWORDER);
24             //分頁
25             var result = this.PostManage.Query(query, page, pagesize);
26 
27             var list = result.List.Select(p => new
28             {
29                 p.ID,
30                 p.POSTNAME,
31                 POSTTYPE = this.CodeManage.GetCode("POSTTYPE", p.POSTTYPE).First().NAMETEXT,
32                 p.CREATEDATE,
33                 USERCOUNT = PostUserManage.LoadAll(m=>m.FK_POSTID==p.ID).Count()
34 
35             }).ToList();
36 
37             return new Common.PageInfo(result.Index, result.PageSize, result.Count, Common.JsonConverter.JsonClass(list));
38         }
View Code

5.2加載詳情

 1 /// <summary>
 2         /// 加載詳情
 3         /// </summary>
 4         /// <returns></returns>
 5         [HttpGet]
 6         [UserAuthorizeAttribute(ModuleAlias = "Post", OperaAction = "Detail")]
 7         public ActionResult Detail(string id)
 8         {
 9             try
10             {
11                 //崗位類型
12                 ViewData["PostType"] = this.CodeManage.GetCode("POSTTYPE");
13                 //獲取部門ID
14                 var departId = Request.QueryString["departId"];
15 
16                 var _entity = this.PostManage.Get(p => p.ID == id) ?? new Domain.SYS_POST() { FK_DEPARTID = departId };
17 
18                 return View(_entity);
19             }
20             catch (Exception e)
21             {
22                 WriteLog(Common.Enums.enumOperator.Select, "崗位管理加載詳情:", e);
23                 throw e.InnerException;
24             }
25         }
View Code

5.3保存崗位

 1 /// <summary>
 2         /// 保存崗位
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "Post", OperaAction = "Add,Edit")]
 5         public ActionResult Save(Domain.SYS_POST entity)
 6         {
 7 
 8             bool isEdit = false;
 9             var json = new JsonHelper() { Msg = "保存崗位成功", Status = "n", ReUrl = "/Post/Index" };
10             try
11             {
12                 if (entity != null)
13                 {
14                     //添加
15                     if (string.IsNullOrEmpty(entity.ID))
16                     {
17                         entity.ID = Guid.NewGuid().ToString();
18                         entity.CREATEDATE = DateTime.Now;
19                         entity.CREATEUSER = CurrentUser.Name;
20                         entity.UPDATEDATE = DateTime.Now;
21                         entity.UPDATEUSER = this.CurrentUser.Name;
22                     }
23                     else //修改
24                     {
25                         entity.UPDATEDATE = DateTime.Now;
26                         entity.UPDATEUSER = this.CurrentUser.Name;
27                         isEdit = true;
28                     }
29                     //判斷崗位是否重名 
30                     if (!this.PostManage.IsExist(p => p.POSTNAME == entity.POSTNAME && p.ID != entity.ID))
31                     {
32                         if (PostManage.SaveOrUpdate(entity, isEdit))
33                         {
34                             json.Status = "y";
35                         }
36                         else
37                         {
38                             json.Msg = "保存失敗";
39                         }
40                     }
41                     else
42                     {
43                         json.Msg = "崗位" + entity.POSTNAME + "已存在,不能重複添加";
44                     }
45                 }
46                 else
47                 {
48                     json.Msg = "未找到須要保存的崗位";
49                 }
50                 if (isEdit)
51                 {
52                     WriteLog(Common.Enums.enumOperator.Edit, "修改崗位,結果:" + json.Msg, Common.Enums.enumLog4net.INFO);
53                 }
54                 else
55                 {
56                     WriteLog(Common.Enums.enumOperator.Add, "添加崗位,結果:" + json.Msg, Common.Enums.enumLog4net.INFO);
57                 }
58             }
59             catch (Exception e)
60             {
61                 json.Msg = "保存崗位發生內部錯誤!";
62                 WriteLog(Common.Enums.enumOperator.None, "保存崗位:", e);
63             }
64             return Json(json);
65 
66 
67         }
View Code

5.4刪除崗位

 1 /// <summary>
 2         /// 刪除崗位
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "Post", OperaAction = "Remove")]
 5         public ActionResult Delete(string idList)
 6         {
 7             JsonHelper json = new JsonHelper() { Msg = "刪除崗位完畢", Status = "n" };
 8             try
 9             {
10                 if (!string.IsNullOrEmpty(idList))
11                 {
12                     idList = idList.Trim(',');
13                         //判斷崗位是否分配人員
14                         if (!this.PostUserManage.IsExist(p => idList.Contains(p.FK_POSTID)))
15                         {
16                             this.PostManage.Delete(p => idList.Contains(p.ID));
17                             json.Status = "y";
18                         }
19                         else
20                         {
21                             json.Msg = "該崗位已經分配人員,不能刪除";
22                         }                   
23                 }
24                 else
25                 {
26                     json.Msg = "未找到要刪除的崗位記錄";
27                 }
28                 WriteLog(Common.Enums.enumOperator.Remove, "刪除崗位,結果:" + json.Msg, Common.Enums.enumLog4net.WARN);
29             }
30             catch (Exception e)
31             {
32                 json.Msg = "刪除崗位發生內部錯誤!";
33                 WriteLog(Common.Enums.enumOperator.Remove, "刪除崗位:", e);
34             }
35             return Json(json);
36         }
View Code

5.5員工管理須要用到的獲取崗位列表

 1  /// <summary>
 2         /// 獲取崗位列表
 3         /// </summary>
 4         /// <returns></returns>
 5         public ActionResult GetPostByDepart()
 6         {
 7             var departId = Request.Form["departId"];
 8             if (!string.IsNullOrEmpty(departId))
 9             {
10                 return Json(this.PostManage.LoadAll(p=>p.FK_DEPARTID==departId)
11                 .Select(p => new
12                 {
13                     ID = p.ID,
14                     NAME=p.POSTNAME
15                 }).ToList(), JsonRequestBehavior.AllowGet);
16             }
17             return new EmptyResult();
18         }
View Code

 

3、員工管理

一、員工管理相關的一些表

數據庫名:wkmvc_db
表名:SYS_POST_USER
 
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID int 4 0     主鍵ID
2 FK_USERID int 4 0         用戶ID
3 FK_POSTID nvarchar 36 0         崗位部門ID
表名:SYS_USER
 
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID int 4 0     主鍵ID
2 NAME nvarchar 50 0         真實姓名
3 ACCOUNT nvarchar 20 0         用戶賬號
4 PASSWORD nvarchar 1000 0         用戶密碼
5 ISCANLOGIN bit 1 0         是否鎖定(0否1是)
6 SHOWORDER1 int 4 0         部門內的排序
7 SHOWORDER2 int 4 0         公司內的排序
8 PINYIN1 nvarchar 50 0         姓名全拼
9 PINYIN2 nvarchar 50 0         姓名首字符
10 FACE_IMG nvarchar 200 0         用戶頭像
11 LEVELS nvarchar 36 0         級別(對接SYS_CODE)
12 DPTID nvarchar 36 0         主部門ID,用戶所在的部門
13 CREATEPER nvarchar 36 0         建立者
14 CREATEDATE datetime 8 3         建立時間
15 UPDATEUSER nvarchar 36 0         修改者
16 UPDATEDATE datetime 8 3         修改時間
17 LastLoginIP nvarchar 50 0         最後一次登陸IP
表名:SYS_USER_PERMISSION
 
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID int 4 0     主鍵ID
2 FK_USERID int 4 0         用戶ID
3 FK_PERMISSIONID int 4 0       受權ID
表名:SYS_USER_ROLE
 
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID int 4 0     主鍵ID
2 FK_USERID int 4 0       用戶ID
3 FK_ROLEID int 4 0         角色ID
表名:SYS_USERINFO
 
序號 列名 數據類型 長度 小數位 標識 主鍵 外鍵 容許空 默認值 說明
1 ID int 4 0     主鍵ID
2 USERID int 4 0       用戶ID,外鍵
3 POSTCODE int 4 0         職務,編碼
4 PHONE nvarchar 200 0         手機號碼
5 OFFICEPHONE nvarchar 200 0         辦公電話
6 EMAILADDRESS nvarchar 200 0         Email
7 SECONDPHONE nvarchar 200 0         第二手機號碼
8 WORKCODE int 4 0         在崗狀態,編碼
9 SEXCODE int 4 0         性別,編碼
10 BIRTHDAY datetime 8 3         出生日期
11 NATIONCODE int 4 0         民族,編碼
12 IDNUMBER nvarchar 18 0         身份證號碼
13 MARRYCODE int 4 0         婚姻情況,編碼
14 IDENTITYCODE int 4 0         政治面貌,編碼
15 HomeTown nvarchar 200 0         籍貫,編碼(關聯至TBCode_Area的CodeValue)
16 ACCOUNTLOCATION nvarchar 200 0         戶籍所在地
17 XUELI int 4 0         學歷,編碼
18 ZHICHENG int 4 0         職稱,編碼
19 GRADUATIONSCHOOL nvarchar 200 0         畢業院校
20 SPECIALTY nvarchar 200 0         專業
21 PHOTOOLDNAME nvarchar 200 0         照片原文件名
22 PHOTONEWNAME nvarchar 200 0         照片新文件名
23 PHOTOTYPE nvarchar 200 0         照片格式
24 RESUMEOLDNAME nvarchar 200 0         簡歷原文件名
25 RESUMENEWNAME nvarchar 200 0         簡歷新文件名
26 RESUMETYPE nvarchar 200 0         簡歷格式
27 HuJiSuoZaiDi nvarchar 200 0         戶籍所在地,編碼(關聯至TBCode_Area的CodeValue)
28 HUJIPAICHUSUO nvarchar 200 0         戶籍所在派出所
29 WORKDATE datetime 8 3         工做時間
30 JINRUDATE datetime 8 3         加入公司時間
31 CARNUMBER nvarchar 200 0         車牌號
32 QQ nvarchar 15 0         QQ號
33 WEBCHATOPENID nvarchar 200 0         微信公衆帳號對應的OpenID
34 CREATEDATE datetime 8 3         建立時間
35 CREATEUSER nvarchar 36 0         建立者
36 UPDATEDATE datetime 8 3         修改時間
37 UPDATEUSER nvarchar 36 0         修改者

 

T-SQL:

  1 USE [wkmvc_db]
  2 GO
  3 /****** Object:  Table [dbo].[SYS_POST_USER]    Script Date: 2016/6/20 16:28:44 ******/
  4 SET ANSI_NULLS ON
  5 GO
  6 SET QUOTED_IDENTIFIER ON
  7 GO
  8 CREATE TABLE [dbo].[SYS_POST_USER](
  9     [ID] [int] IDENTITY(1,1) NOT NULL,
 10     [FK_USERID] [int] NOT NULL,
 11     [FK_POSTID] [nvarchar](36) NOT NULL,
 12  CONSTRAINT [PK_SYS_POST_USER] PRIMARY KEY CLUSTERED 
 13 (
 14     [ID] ASC
 15 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
 16 ) ON [PRIMARY]
 17 
 18 GO
 19 /****** Object:  Table [dbo].[SYS_USER]    Script Date: 2016/6/20 16:28:44 ******/
 20 SET ANSI_NULLS ON
 21 GO
 22 SET QUOTED_IDENTIFIER ON
 23 GO
 24 CREATE TABLE [dbo].[SYS_USER](
 25     [ID] [int] IDENTITY(1,1) NOT NULL,
 26     [NAME] [nvarchar](50) NULL,
 27     [ACCOUNT] [nvarchar](20) NULL,
 28     [PASSWORD] [nvarchar](1000) NULL,
 29     [ISCANLOGIN] [bit] NOT NULL,
 30     [SHOWORDER1] [int] NULL,
 31     [SHOWORDER2] [int] NULL,
 32     [PINYIN1] [nvarchar](50) NULL,
 33     [PINYIN2] [nvarchar](50) NULL,
 34     [FACE_IMG] [nvarchar](200) NULL,
 35     [LEVELS] [nvarchar](36) NULL,
 36     [DPTID] [nvarchar](36) NULL,
 37     [CREATEPER] [nvarchar](36) NULL,
 38     [CREATEDATE] [datetime] NULL,
 39     [UPDATEUSER] [nvarchar](36) NULL,
 40     [UPDATEDATE] [datetime] NULL,
 41     [LastLoginIP] [nvarchar](50) NULL,
 42  CONSTRAINT [PK_SYS_USER] PRIMARY KEY CLUSTERED 
 43 (
 44     [ID] ASC
 45 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
 46 ) ON [PRIMARY]
 47 
 48 GO
 49 /****** Object:  Table [dbo].[SYS_USER_PERMISSION]    Script Date: 2016/6/20 16:28:44 ******/
 50 SET ANSI_NULLS ON
 51 GO
 52 SET QUOTED_IDENTIFIER ON
 53 GO
 54 CREATE TABLE [dbo].[SYS_USER_PERMISSION](
 55     [ID] [int] IDENTITY(1,1) NOT NULL,
 56     [FK_USERID] [int] NOT NULL,
 57     [FK_PERMISSIONID] [int] NOT NULL,
 58  CONSTRAINT [PK_SYS_USER_PERMISSION] PRIMARY KEY CLUSTERED 
 59 (
 60     [ID] ASC
 61 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
 62 ) ON [PRIMARY]
 63 
 64 GO
 65 /****** Object:  Table [dbo].[SYS_USER_ROLE]    Script Date: 2016/6/20 16:28:44 ******/
 66 SET ANSI_NULLS ON
 67 GO
 68 SET QUOTED_IDENTIFIER ON
 69 GO
 70 CREATE TABLE [dbo].[SYS_USER_ROLE](
 71     [ID] [int] IDENTITY(1,1) NOT NULL,
 72     [FK_USERID] [int] NOT NULL,
 73     [FK_ROLEID] [int] NOT NULL,
 74  CONSTRAINT [PK_SYS_USER_ROLE] PRIMARY KEY CLUSTERED 
 75 (
 76     [ID] ASC
 77 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
 78 ) ON [PRIMARY]
 79 
 80 GO
 81 /****** Object:  Table [dbo].[SYS_USERINFO]    Script Date: 2016/6/20 16:28:44 ******/
 82 SET ANSI_NULLS ON
 83 GO
 84 SET QUOTED_IDENTIFIER ON
 85 GO
 86 CREATE TABLE [dbo].[SYS_USERINFO](
 87     [ID] [int] IDENTITY(1,1) NOT NULL,
 88     [USERID] [int] NOT NULL,
 89     [POSTCODE] [int] NULL,
 90     [PHONE] [nvarchar](200) NULL,
 91     [OFFICEPHONE] [nvarchar](200) NULL,
 92     [EMAILADDRESS] [nvarchar](200) NULL,
 93     [SECONDPHONE] [nvarchar](200) NULL,
 94     [WORKCODE] [int] NULL,
 95     [SEXCODE] [int] NULL,
 96     [BIRTHDAY] [datetime] NULL,
 97     [NATIONCODE] [int] NULL,
 98     [IDNUMBER] [nvarchar](18) NULL,
 99     [MARRYCODE] [int] NULL,
100     [IDENTITYCODE] [int] NULL,
101     [HomeTown] [nvarchar](200) NULL,
102     [ACCOUNTLOCATION] [nvarchar](200) NULL,
103     [XUELI] [int] NULL,
104     [ZHICHENG] [int] NULL,
105     [GRADUATIONSCHOOL] [nvarchar](200) NULL,
106     [SPECIALTY] [nvarchar](200) NULL,
107     [PHOTOOLDNAME] [nvarchar](200) NULL,
108     [PHOTONEWNAME] [nvarchar](200) NULL,
109     [PHOTOTYPE] [nvarchar](200) NULL,
110     [RESUMEOLDNAME] [nvarchar](200) NULL,
111     [RESUMENEWNAME] [nvarchar](200) NULL,
112     [RESUMETYPE] [nvarchar](200) NULL,
113     [HuJiSuoZaiDi] [nvarchar](200) NULL,
114     [HUJIPAICHUSUO] [nvarchar](200) NULL,
115     [WORKDATE] [datetime] NULL,
116     [JINRUDATE] [datetime] NULL,
117     [CARNUMBER] [nvarchar](200) NULL,
118     [QQ] [nvarchar](15) NULL,
119     [WEBCHATOPENID] [nvarchar](200) NULL,
120     [CREATEDATE] [datetime] NULL,
121     [CREATEUSER] [nvarchar](36) NULL,
122     [UPDATEDATE] [datetime] NULL,
123     [UPDATEUSER] [nvarchar](36) NULL,
124  CONSTRAINT [PK_SYS_USERINFO] PRIMARY KEY CLUSTERED 
125 (
126     [ID] ASC
127 )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
128 ) ON [PRIMARY]
129 
130 GO
131 ALTER TABLE [dbo].[SYS_USER_PERMISSION]  WITH CHECK ADD  CONSTRAINT [FK_SYS_USER_PERMISSION_PERID] FOREIGN KEY([FK_PERMISSIONID])
132 REFERENCES [dbo].[SYS_PERMISSION] ([ID])
133 GO
134 ALTER TABLE [dbo].[SYS_USER_PERMISSION] CHECK CONSTRAINT [FK_SYS_USER_PERMISSION_PERID]
135 GO
136 ALTER TABLE [dbo].[SYS_USER_PERMISSION]  WITH CHECK ADD  CONSTRAINT [FK_SYS_USER_PERMISSION_USERID] FOREIGN KEY([FK_USERID])
137 REFERENCES [dbo].[SYS_USER] ([ID])
138 GO
139 ALTER TABLE [dbo].[SYS_USER_PERMISSION] CHECK CONSTRAINT [FK_SYS_USER_PERMISSION_USERID]
140 GO
141 ALTER TABLE [dbo].[SYS_USER_ROLE]  WITH CHECK ADD  CONSTRAINT [FK_SYS_USER_ROLE_ROLEID] FOREIGN KEY([FK_ROLEID])
142 REFERENCES [dbo].[SYS_ROLE] ([ID])
143 GO
144 ALTER TABLE [dbo].[SYS_USER_ROLE] CHECK CONSTRAINT [FK_SYS_USER_ROLE_ROLEID]
145 GO
146 ALTER TABLE [dbo].[SYS_USER_ROLE]  WITH CHECK ADD  CONSTRAINT [FK_SYS_USER_ROLE_USERID] FOREIGN KEY([FK_USERID])
147 REFERENCES [dbo].[SYS_USER] ([ID])
148 GO
149 ALTER TABLE [dbo].[SYS_USER_ROLE] CHECK CONSTRAINT [FK_SYS_USER_ROLE_USERID]
150 GO
151 ALTER TABLE [dbo].[SYS_USERINFO]  WITH CHECK ADD  CONSTRAINT [FK_SYS_USERINFO_SYSUSERID] FOREIGN KEY([USERID])
152 REFERENCES [dbo].[SYS_USER] ([ID])
153 GO
154 ALTER TABLE [dbo].[SYS_USERINFO] CHECK CONSTRAINT [FK_SYS_USERINFO_SYSUSERID]
155 GO
156 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST_USER', @level2type=N'COLUMN',@level2name=N'ID'
157 GO
158 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST_USER', @level2type=N'COLUMN',@level2name=N'FK_USERID'
159 GO
160 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'崗位部門ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_POST_USER', @level2type=N'COLUMN',@level2name=N'FK_POSTID'
161 GO
162 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'ID'
163 GO
164 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'真實姓名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'NAME'
165 GO
166 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶賬號' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'ACCOUNT'
167 GO
168 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶密碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'PASSWORD'
169 GO
170 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'是否鎖定(0否1是)' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'ISCANLOGIN'
171 GO
172 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'部門內的排序' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'SHOWORDER1'
173 GO
174 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'公司內的排序' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'SHOWORDER2'
175 GO
176 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名全拼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'PINYIN1'
177 GO
178 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名首字符' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'PINYIN2'
179 GO
180 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶頭像' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'FACE_IMG'
181 GO
182 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'級別(對接SYS_CODE)' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'LEVELS'
183 GO
184 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主部門ID,用戶所在的部門' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'DPTID'
185 GO
186 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立者' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'CREATEPER'
187 GO
188 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'CREATEDATE'
189 GO
190 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改者' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'UPDATEUSER'
191 GO
192 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'UPDATEDATE'
193 GO
194 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'最後一次登陸IP' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER', @level2type=N'COLUMN',@level2name=N'LastLoginIP'
195 GO
196 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER_PERMISSION', @level2type=N'COLUMN',@level2name=N'ID'
197 GO
198 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER_PERMISSION', @level2type=N'COLUMN',@level2name=N'FK_USERID'
199 GO
200 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'受權ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER_PERMISSION', @level2type=N'COLUMN',@level2name=N'FK_PERMISSIONID'
201 GO
202 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER_ROLE', @level2type=N'COLUMN',@level2name=N'ID'
203 GO
204 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER_ROLE', @level2type=N'COLUMN',@level2name=N'FK_USERID'
205 GO
206 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'角色ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USER_ROLE', @level2type=N'COLUMN',@level2name=N'FK_ROLEID'
207 GO
208 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'主鍵ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'ID'
209 GO
210 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'用戶ID,外鍵' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'USERID'
211 GO
212 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'職務,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'POSTCODE'
213 GO
214 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'手機號碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'PHONE'
215 GO
216 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'辦公電話' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'OFFICEPHONE'
217 GO
218 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Email' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'EMAILADDRESS'
219 GO
220 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'第二手機號碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'SECONDPHONE'
221 GO
222 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'在崗狀態,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'WORKCODE'
223 GO
224 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'性別,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'SEXCODE'
225 GO
226 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'出生日期' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'BIRTHDAY'
227 GO
228 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'民族,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'NATIONCODE'
229 GO
230 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'身份證號碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'IDNUMBER'
231 GO
232 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'婚姻情況,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'MARRYCODE'
233 GO
234 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'政治面貌,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'IDENTITYCODE'
235 GO
236 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'籍貫,編碼(關聯至TBCode_Area的CodeValue)' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'HomeTown'
237 GO
238 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'戶籍所在地' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'ACCOUNTLOCATION'
239 GO
240 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'學歷,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'XUELI'
241 GO
242 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'職稱,編碼' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'ZHICHENG'
243 GO
244 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'畢業院校' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'GRADUATIONSCHOOL'
245 GO
246 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'專業' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'SPECIALTY'
247 GO
248 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'照片原文件名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'PHOTOOLDNAME'
249 GO
250 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'照片新文件名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'PHOTONEWNAME'
251 GO
252 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'照片格式' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'PHOTOTYPE'
253 GO
254 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'簡歷原文件名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'RESUMEOLDNAME'
255 GO
256 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'簡歷新文件名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'RESUMENEWNAME'
257 GO
258 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'簡歷格式' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'RESUMETYPE'
259 GO
260 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'戶籍所在地,編碼(關聯至TBCode_Area的CodeValue)' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'HuJiSuoZaiDi'
261 GO
262 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'戶籍所在派出所' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'HUJIPAICHUSUO'
263 GO
264 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'工做時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'WORKDATE'
265 GO
266 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'加入公司時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'JINRUDATE'
267 GO
268 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'車牌號' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'CARNUMBER'
269 GO
270 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'QQ號' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'QQ'
271 GO
272 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'微信公衆帳號對應的OpenID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'WEBCHATOPENID'
273 GO
274 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'CREATEDATE'
275 GO
276 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'建立者' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'CREATEUSER'
277 GO
278 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改時間' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'UPDATEDATE'
279 GO
280 EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改者' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'SYS_USERINFO', @level2type=N'COLUMN',@level2name=N'UPDATEUSER'
281 GO
View Code

 

二、新建控制器UserController

三、聲明容器

 1 #region 聲明容器
 2         /// <summary>
 3         /// 部門
 4         /// </summary>
 5         IDepartmentManage DepartmentManage { get; set; }
 6         /// <summary>
 7         /// 崗位管理
 8         /// </summary>
 9         IPostManage PostManage { get; set; }
10         /// <summary>
11         /// 用戶崗位
12         /// </summary>
13         IPostUserManage PostUserManage { get; set; }
14         /// <summary>
15         /// 用戶信息
16         /// </summary>
17         IUserInfoManage UserInfoManage { get; set; }
18         /// <summary>
19         /// 字典編碼
20         /// </summary>
21         ICodeManage CodeManage { get; set; }
22         /// <summary>
23         /// 角色
24         /// </summary>
25         IRoleManage RoleManage { get; set; }
26         #endregion
View Code

 四、加載首頁

 1 /// <summary>
 2         /// 加載首頁
 3         /// </summary>
 4         /// <returns></returns>
 5         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "View")]
 6         public ActionResult Index()
 7         {
 8             try
 9             {
10 
11                 #region 處理查詢參數
12                 string DepartId = Request.QueryString["DepartId"];
13                 ViewBag.Search = base.keywords;
14                 ViewData["DepartId"] = DepartId;
15                 #endregion
16 
17                 ViewBag.dpt = this.DepartmentManage.GetDepartmentByDetail();
18 
19                 return View(BindList(DepartId));
20             }
21             catch (Exception e)
22             {
23                 WriteLog(Common.Enums.enumOperator.Select, "員工管理加載主頁:", e);
24                 throw e.InnerException;
25             }
26 
27         }
View Code
 1 /// <summary>
 2         /// 分頁查詢用戶列表
 3         /// </summary>
 4         private Common.PageInfo BindList(string DepartId)
 5         {
 6             //基礎數據
 7             var query = this.UserManage.LoadAll(p => p.ID > 1);
 8 
 9             //部門(本部門用戶及全部下級部門用戶)
10             if (!string.IsNullOrEmpty(DepartId))
11             {
12                 var childDepart = this.DepartmentManage.LoadAll(p => p.PARENTID == DepartId).Select(p=>p.ID).ToList();
13                 query = query.Where(p => p.DPTID == DepartId || childDepart.Any(e => e == p.DPTID));
14             }
15             
16             //查詢關鍵字
17             if (!string.IsNullOrEmpty(keywords))
18             {
19                 keywords = keywords.ToLower();
20                 query = query.Where(p => p.NAME.Contains(keywords) || p.ACCOUNT.Contains(keywords) || p.PINYIN2.Contains(keywords) || p.PINYIN1.Contains(keywords));
21             }
22             //排序
23             query = query.OrderBy(p=>p.SHOWORDER1).OrderByDescending(p => p.CREATEDATE);
24             //分頁
25             var result = this.UserManage.Query(query, page, pagesize);
26 
27             var list = result.List.Select(p => new
28             {
29                 p.ID,
30                 p.NAME,
31                 p.ACCOUNT,
32                 DPTNAME = this.DepartmentManage.GetDepartmentName(p.DPTID),
33                 POSTNAME = GetPostName(p.SYS_POST_USER),
34                 ROLENAME = GetRoleName(p.SYS_USER_ROLE),
35                 p.CREATEDATE,
36                 ZW = this.CodeManage.Get(m => m.CODEVALUE == p.LEVELS && m.CODETYPE == "ZW").NAMETEXT,
37                 ISCANLOGIN = !p.ISCANLOGIN ? "<i class=\"fa fa-circle text-navy\"></i>" : "<i class=\"fa fa-circle text-danger\"></i>"
38 
39             }).ToList();
40 
41             return new Common.PageInfo(result.Index, result.PageSize, result.Count, Common.JsonConverter.JsonClass(list));
42         }
43         /// <summary>
44         /// 根據崗位集合獲取崗位名稱
45         /// </summary>
46         private string GetPostName(ICollection<Domain.SYS_POST_USER> collection)
47         {
48             string retval = string.Empty;
49             if (collection != null && collection.Count > 0)
50             {
51                 var postlist = String.Join(",", collection.Select(p => p.FK_POSTID).ToList()).Trim(',').Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries).Select(p => p).ToList();
52                 retval = String.Join(",", PostManage.LoadAll(p => postlist.Any(e => e == p.ID)).Select(p => p.POSTNAME).ToList());
53             }
54             return retval = retval.TrimEnd(',');
55         }
56         /// <summary>
57         /// 根據角色集合獲取角色名稱
58         /// </summary>
59         private string GetRoleName(ICollection<Domain.SYS_USER_ROLE> collection)
60         {
61             string retval = string.Empty;
62             if (collection != null && collection.Count > 0)
63             {
64                 var rolelist = String.Join(",", collection.Select(p => p.FK_ROLEID).ToList()).Trim(',').Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries).Select(p => int.Parse(p)).ToList();
65                 retval = String.Join(",", RoleManage.LoadAll(p => rolelist.Any(e => e == p.ID)).Select(p => p.ROLENAME).ToList());
66             }
67             return retval = retval.TrimEnd(',');
68         }
View Code

五、加載用戶詳情信息(基本)

 1 /// <summary>
 2         /// 加載用戶詳情信息(基本)
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "Detail")]
 5         public ActionResult Detail(int? id)
 6         {
 7             try
 8             {
 9                 var _entity = new Domain.SYS_USER();
10 
11                 var Postlist="";
12 
13                 if (id != null && id > 0)
14                 {
15                     _entity = UserManage.Get(p => p.ID == id);
16                     Postlist = String.Join(",", _entity.SYS_POST_USER.Select(p => p.FK_POSTID).ToList());
17                 }
18                 ViewBag.dpt = this.DepartmentManage.GetDepartmentByDetail();
19                 ViewBag.zw = this.CodeManage.LoadAll(p => p.CODETYPE == "ZW").ToList();
20                 ViewData["Postlist"] = Postlist;
21                 return View(_entity);
22             }
23             catch (Exception e)
24             {
25                 WriteLog(Common.Enums.enumOperator.Select, "加載用戶詳情發生錯誤:", e);
26                 throw e.InnerException;
27             }
28         }
View Code

六、保存人員基本信息

 1  /// <summary>
 2         /// 保存人員基本信息
 3         /// </summary>
 4         [ValidateInput(false)]
 5         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "Add,Edit")]
 6         public ActionResult Save(Domain.SYS_USER entity)
 7         {
 8             bool isEdit = false;
 9             var json = new JsonHelper() { Msg = "保存成功", Status = "n" };
10             try
11             {
12                 if (entity != null)
13                 {
14                     if (entity.ID <= 0) //添加
15                     {
16                         entity.CREATEDATE = DateTime.Now;
17                         entity.CREATEPER = this.CurrentUser.Name;
18                         entity.UPDATEDATE = DateTime.Now;
19                         entity.UPDATEUSER = this.CurrentUser.Name;
20                         entity.PASSWORD = new Common.CryptHelper.AESCrypt().Encrypt("111111");
21                         entity.PINYIN1 = Common.ConvertHzToPz.Convert(entity.NAME).ToLower();
22                         entity.PINYIN2 = Common.ConvertHzToPz.ConvertFirst(entity.NAME).ToLower();
23                     }
24                     else //修改
25                     {
26                         entity.UPDATEUSER = this.CurrentUser.Name;
27                         entity.UPDATEDATE = DateTime.Now;
28                         entity.PINYIN1 = Common.ConvertHzToPz.Convert(entity.NAME).ToLower();
29                         entity.PINYIN2 = Common.ConvertHzToPz.ConvertFirst(entity.NAME).ToLower();
30                         isEdit = true;
31                     }
32                     //檢測此用戶名是否重複
33                     if (!this.UserManage.IsExist(p => p.ACCOUNT.Equals(entity.ACCOUNT) && p.ID != entity.ID))
34                     {
35                         if (this.UserManage.SaveOrUpdate(entity, isEdit))
36                         {
37                            //員工崗位
38                             var postlist = Request.Form["postlist"];
39                             if(!string.IsNullOrEmpty(postlist))
40                             {
41                                 //刪除員工崗位
42                                 if(PostUserManage.IsExist(p=>p.FK_USERID==entity.ID))
43                                 {
44                                     PostUserManage.Delete(p => p.FK_USERID == entity.ID);
45                                 }
46                                 //添加新的員工崗位
47                                 List<Domain.SYS_POST_USER> PostUser = new List<Domain.SYS_POST_USER>();
48                                 foreach(var item in postlist.Trim(',').Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries).Select(p => p).ToList())
49                                 {
50                                     PostUser.Add(new Domain.SYS_POST_USER() { FK_POSTID = item, FK_USERID = entity.ID });
51                                 }
52                                 PostUserManage.SaveList(PostUser);
53                             }
54                         }
55                         json.Status = "y";
56                     }
57                     else
58                     {
59                         json.Msg = "登陸帳號已被使用,請修改後再提交!";
60                     }
61                 }
62                 else
63                 {
64                     json.Msg = "未找到要操做的用戶記錄";
65                 }
66                 if (isEdit)
67                 {
68                     WriteLog(Common.Enums.enumOperator.Edit, "修改用戶,結果:" + json.Msg, Common.Enums.enumLog4net.INFO);
69                 }
70                 else
71                 {
72                     WriteLog(Common.Enums.enumOperator.Add, "添加用戶,結果:" + json.Msg, Common.Enums.enumLog4net.INFO);
73                 }
74             }
75             catch (Exception e)
76             {
77                 json.Msg = "保存人員信息發生內部錯誤!";
78                 WriteLog(Common.Enums.enumOperator.None, "保存用戶錯誤:", e);
79             }
80             return Json(json);
81 
82         }
View Code

七、刪除用戶

/// 驗證規則:一、超級管理員不能刪除
///               二、當前登陸用戶不能刪除
///               三、正常狀態用戶不能刪除
///               四、上級部門用戶不能刪除
/// 刪除原則:一、刪除用戶檔案
///        二、刪除用戶角色關係
///        三、刪除用戶權限關係
///        四、刪除用戶崗位關係
///        五、刪除用戶部門關係
///        六、刪除用戶

 1 /// <summary>
 2         /// 方法註解:刪除用戶
 3         /// 驗證規則:一、超級管理員不能刪除
 4         ///           二、當前登陸用戶不能刪除
 5         ///           三、正常狀態用戶不能刪除
 6         ///           四、上級部門用戶不能刪除
 7         /// 刪除原則:一、刪除用戶檔案
 8         ///           二、刪除用戶角色關係
 9         ///           三、刪除用戶權限關係
10         ///           四、刪除用戶崗位關係
11         ///           五、刪除用戶部門關係
12         ///           六、刪除用戶
13         /// </summary>
14         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "Remove")]
15         public ActionResult Delete(string idList)
16         {
17             var json = new JsonHelper() { Status = "n", Msg = "刪除用戶成功" };
18             try
19             {
20                 //是否爲空
21                 if (string.IsNullOrEmpty(idList)) { json.Msg = "未找到要刪除的用戶"; return Json(json); }
22                 string[] id = idList.Trim(',').Split(',');
23                 for (int i = 0; i < id.Length; i++)
24                 {
25                     int userId = int.Parse(id[i]);                   
26                     if (this.UserManage.IsAdmin(userId))
27                     {
28                         json.Msg = "被刪除用戶存在超級管理員,不能刪除!";
29                         WriteLog(Common.Enums.enumOperator.Remove, "刪除用戶:" + json.Msg, Common.Enums.enumLog4net.ERROR);
30                         return Json(json);
31                     }
32                     if (this.CurrentUser.Id == userId)
33                     {
34                         json.Msg = "當前登陸用戶,不能刪除!";
35                         WriteLog(Common.Enums.enumOperator.Remove, "刪除用戶:" + json.Msg, Common.Enums.enumLog4net.ERROR);
36                         return Json(json);
37                     }
38                     if (this.UserManage.Get(p => p.ID == userId).ISCANLOGIN)
39                     {
40                         json.Msg = "用戶未鎖定,不能刪除!";
41                         WriteLog(Common.Enums.enumOperator.Remove, "刪除用戶:" + json.Msg, Common.Enums.enumLog4net.ERROR);
42                         return Json(json);
43                     }
44                     if (this.CurrentUser.DptInfo!=null)
45                     {
46                         string dptid = this.UserManage.Get(p => p.ID == userId).DPTID;
47                         if (this.DepartmentManage.Get(m => m.ID == dptid).BUSINESSLEVEL < this.CurrentUser.DptInfo.BUSINESSLEVEL)
48                         {
49                             json.Msg = "不能刪除上級部門用戶!";
50                             WriteLog(Common.Enums.enumOperator.Remove, "刪除用戶:" + json.Msg, Common.Enums.enumLog4net.ERROR);
51                             return Json(json);
52                         }
53                     }
54                     this.UserManage.Remove(userId);
55                     json.Status = "y";
56                     WriteLog(Common.Enums.enumOperator.Remove, "刪除用戶:" + json.Msg, Common.Enums.enumLog4net.WARN);
57                 }
58             }
59             catch (Exception e)
60             {
61                 json.Msg = "刪除用戶發生內部錯誤!";
62                 WriteLog(Common.Enums.enumOperator.Remove, "刪除用戶:", e);
63             }
64             return Json(json);
65         }
View Code

這是最基本的用戶的操做

七、下面咱們先作一下初始化密碼:

 1 /// <summary>
 2         /// 方法描述:根據傳入的用戶編號重置當前用戶密碼
 3         /// </summary>
 4         /// <param name="Id">用戶編號</param>
 5         /// <returns></returns>
 6         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "PwdReset")]
 7         public ActionResult ResetPwd(string idList)
 8         {
 9             var json = new JsonHelper() { Status = "n", Msg = "操做成功" };
10             try
11             {
12                 //校驗用戶編號是否爲空
13                 if (string.IsNullOrEmpty(idList))
14                 {
15                     json.Msg = "校驗失敗,用戶編號不能爲空";
16                     WriteLog(Common.Enums.enumOperator.Edit, "重置當前用戶密碼:" + json.Msg, Common.Enums.enumLog4net.ERROR);
17                     return Json(json);
18                 }
19                 var idlist1 = idList.Trim(',').Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries).Select(p => int.Parse(p)).ToList();
20                 if (idlist1 != null && idlist1.Count > 0)
21                 {
22                     foreach (var newid in idlist1)
23                     {
24                         var _user = UserManage.Get(p => p.ID == newid);
25                         _user.PASSWORD = new Common.CryptHelper.AESCrypt().Encrypt("111111");
26                         UserManage.Update(_user);
27                     }
28                 }
29                 json.Status = "y";
30                 WriteLog(Common.Enums.enumOperator.Edit, "重置當前用戶密碼:" + json.Msg, Common.Enums.enumLog4net.INFO);
31             }
32             catch (Exception e)
33             {
34                 json.Msg = "操做失敗";
35                 WriteLog(Common.Enums.enumOperator.Edit, "重置當前用戶密碼:", e);
36             }
37             return Json(json);
38         }
View Code

八、分配角色(角色控制器 RoleController)

8.1角色分配

 1  /// <summary>
 2         /// 用戶角色分配
 3         /// </summary>
 4         /// <param name="id">用戶ID</param>
 5         /// <returns></returns>
 6         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "AllocationRole")]
 7         public ActionResult RoleCall(int? id)
 8         {
 9             try
10             {
11                 if(id!=null && id>0)
12                 {
13                     //用戶ID
14                     ViewData["userId"] = id;
15                     //獲取用戶角色信息
16                     var userRoleList = this.UserRoleManage.LoadAll(p => p.FK_USERID == id).Select(p => p.FK_ROLEID).ToList();
17                     return View(Common.JsonConverter.JsonClass(this.RoleManage.LoadAll(p => this.CurrentUser.System_Id.Any(e => e == p.FK_BELONGSYSTEM)).OrderBy(p => p.FK_BELONGSYSTEM).OrderByDescending(p=>p.ID).ToList().Select(p => new { p.ID, p.ROLENAME, ISCUSTOMSTATUS = p.ISCUSTOM ? "<i class=\"fa fa-circle text-navy\"></i>" : "<i class=\"fa fa-circle text-danger\"></i>", SYSNAME = SystemManage.Get(m => m.ID == p.FK_BELONGSYSTEM).NAME,IsChoosed=userRoleList.Contains(p.ID) })));
18                 }
19                 else
20                 {
21                     return View();
22                 }
23                 
24             }
25             catch(Exception e)
26             {
27                 WriteLog(Common.Enums.enumOperator.Select, "獲取用戶分配的角色:", e);
28                 throw e.InnerException;
29             }
30         }
View Code

8.2設置用戶角色

 1 /// <summary>
 2         /// 設置用戶角色
 3         /// </summary>
 4         [UserAuthorizeAttribute(ModuleAlias = "Role", OperaAction = "Allocation")]
 5         public ActionResult UserRole()
 6         {
 7             var json = new JsonHelper()
 8             {
 9                 Msg = "設置用戶角色成功",
10                 Status = "n"
11             };
12             string userId = Request.Form["UserId"];
13             string roleId = Request.Form["checkbox_name"];
14             if (string.IsNullOrEmpty(userId))
15             {
16                 json.Msg = "未找到要分配角色用戶";
17                 return Json(json);
18             }
19             roleId = roleId.TrimEnd(',');
20 
21             try
22             {
23                 //設置用戶角色
24                 this.UserRoleManage.SetUserRole(int.Parse(userId), roleId);
25                 json.Status = "y";
26                 WriteLog(Common.Enums.enumOperator.Allocation, "設置用戶角色:" + json.Msg, Common.Enums.enumLog4net.INFO);
27             }
28             catch (Exception e)
29             {
30                 json.Msg = "設置失敗,錯誤:" + e.Message;
31                 WriteLog(Common.Enums.enumOperator.Allocation, "設置用戶角色:", e);
32             }
33             return Json(json);
34         }
View Code

九、分配權限,當用戶分配角色以後就擁有了 相應操做系統的角色的權限,這個分配權限的功能是對於特殊的用戶添加角色以外的權限,例如,網站編輯擁有對文章的操做權限,可是有個小編,我想讓他本身負責欄目的管理,這時候咱們就爲這個員工添加單獨的欄目的操做權限了。

這個功能咱們在作角色管理的時候已經作過了,你們看下權限管理控制器PermissionController  裏面的 PerAllocation方法和SaveAllocation ,咱們只須要參考角色 分配權限的方法 把tp參數傳遞爲user就OK了

十、人員檔案

10.1加載人員檔案

 1 /// <summary>
 2         /// 加載人員檔案
 3         /// </summary>
 4         /// <param name="id"></param>
 5         /// <returns></returns>
 6         [UserAuthorizeAttribute(ModuleAlias = "User", OperaAction = "UserInfo")]
 7         public ActionResult UserInfo(int? userid)
 8         {
 9             try
10             {
11                 //是否爲人事部
12                 var IsMatters = true;
13 
14                 var entity = new Domain.SYS_USERINFO();
15 
16                 var UserName = CurrentUser.Name;
17 
18                 if (userid != null && userid > 0)
19                 {
20                     entity = UserInfoManage.Get(p => p.USERID == userid) ?? new Domain.SYS_USERINFO() { USERID = int.Parse(userid.ToString()) };
21                     UserName = UserManage.Get(p => p.ID == userid).NAME;
22                     if((CurrentUser.DptInfo!=null && CurrentUser.DptInfo.NAME != "人事部") || !CurrentUser.IsAdmin)
23                     {
24                         IsMatters = false;
25                     }
26                 }
27                 else
28                 {
29                     entity = UserInfoManage.Get(p => p.USERID == CurrentUser.Id) ?? new Domain.SYS_USERINFO() { USERID = CurrentUser.Id };
30                 }
31 
32                 ViewData["UserName"] = UserName;
33 
34                 ViewBag.IsMatters = IsMatters;
35 
36                 Dictionary<string, string> dic = Common.Enums.ClsDic.DicCodeType;
37                 var dictype = this.CodeManage.GetDicType();
38                 //在崗狀態
39                 string zgzt = dic["在崗狀態"];
40                 ViewData["zgzt"] = dictype.Where(p => p.CODETYPE == zgzt).ToList();
41                 //婚姻情況
42                 string hyzk = dic["婚姻情況"];
43                 ViewData["hunyin"] = dictype.Where(p => p.CODETYPE == hyzk).ToList();
44                 //政治面貌
45                 string zzmm = dic["政治面貌"];
46                 ViewData["zzmm"] = dictype.Where(p => p.CODETYPE == zzmm).ToList();
47                 //民族
48                 string mz = dic["民族"];
49                 ViewData["mz"] = dictype.Where(p => p.CODETYPE == mz).ToList();
50                 //職稱級別
51                 string zcjb = dic["職稱"];
52                 ViewData["zcjb"] = dictype.Where(p => p.CODETYPE == zcjb).ToList();
53                 //學歷
54                 string xl = dic["學歷"];
55                 ViewData["xl"] = dictype.Where(p => p.CODETYPE == xl).ToList();
56 
57                 return View(entity);
58             }
59             catch (Exception e)
60             {
61                 WriteLog(Common.Enums.enumOperator.Select, "加載人員檔案:", e);
62                 throw e.InnerException;
63             }
64 
65         }
View Code

10.2保存人員檔案

 1 /// <summary>
 2         /// 保存人員檔案
 3         /// </summary>
 4         public ActionResult SetUserInfo(Domain.SYS_USERINFO entity)
 5         {
 6             bool isEdit = false;
 7             var json = new JsonHelper() { Msg = "保存人員檔案成功", Status = "n" };
 8             try
 9             {               
10                     if (entity != null)
11                     {
12                         #region 獲取html標籤值
13 
14                         //籍貫
15                         entity.HomeTown = Request.Form["jgprov"] + "," + Request.Form["jgcity"] + "," +
16                                           Request.Form["jgcountry"];
17                         //戶口所在地
18                         entity.HuJiSuoZaiDi = Request.Form["hkprov"] + "," + Request.Form["hkcity"] + "," +
19                                               Request.Form["hkcountry"];
20 
21                         #endregion
22 
23                         //添加
24                         if (entity.ID<=0)
25                         {
26                             entity.CREATEUSER = CurrentUser.Name;
27                             entity.CREATEDATE = DateTime.Now;
28                             entity.UPDATEUSER = CurrentUser.Name;
29                             entity.UPDATEDATE = DateTime.Now;
30                         }
31                         else
32                         {
33                             entity.UPDATEUSER = CurrentUser.Name;
34                             entity.UPDATEDATE = DateTime.Now;
35                             isEdit = true;
36                         }
37 
38 
39 
40                         //修改用戶檔案
41                         if (this.UserInfoManage.SaveOrUpdate(entity, isEdit))
42                         {
43                             json.Status = "y";
44 
45                         }
46                         else
47                         {
48                             json.Msg = "保存用戶檔案失敗";
49 
50                         }
51 
52                     }
53                     else
54                     {
55                         json.Msg = "未找到要編輯的用戶記錄";
56                     }
57                     if (isEdit)
58                     {
59                         WriteLog(Common.Enums.enumOperator.Edit, "保存人員檔案:" + json.Msg, Common.Enums.enumLog4net.INFO);
60                     }
61                     else
62                     {
63                         WriteLog(Common.Enums.enumOperator.Add, "保存人員檔案:" + json.Msg, Common.Enums.enumLog4net.INFO);
64                     }                
65             }
66             catch (Exception e)
67             {                
68                 json.Msg = e.InnerException.Message;
69                 WriteLog(Common.Enums.enumOperator.None, "保存人員檔案:", e);
70             }
71             return Json(json);
72         }
View Code

 

 

 

原創文章 轉載請尊重勞動成果 http://yuangang.cnblogs.com

相關文章
相關標籤/搜索