一、屌絲也有春天 "親愛的,在不?" "妹子,你電腦又感覺慢了麽?您以後裝軟體的時候註意點行不,能不能不要裝上7-8個瀏覽器,3-4個殺毒軟體,啥配置的機子你都感覺卡。以後別到處瞎找動作類電影看,網上一般都掛馬騙你們這些小白的,實在想看找我要種子不就行了。" "沒有啦,人家電腦好著呢,您不是做軟體的 ...
一、屌絲也有春天
"親愛的,在不?"
"妹子,你電腦又感覺慢了麽?您以後裝軟體的時候註意點行不,能不能不要裝上7-8個瀏覽器,3-4個殺毒軟體,啥配置的機子你都感覺卡。以後別到處瞎找動作類電影看,網上一般都掛馬騙你們這些小白的,實在想看找我要種子不就行了。"
"沒有啦,人家電腦好著呢,您不是做軟體的麽,公司有個小項目讓我找供應商,我第一個就想到了你,對你好吧,需求你接下,看看能不能做。下周就要用,費用的話萬兒八千不是問題。"
先看看需求吧,沒準人家出個幾千塊讓我整個ERP系統出來。。。不著邊際的小客戶我見多了,想出900塊錢做個網站的人都有。
內容相當少,就是給他們公司的網站後臺加一個後臺新聞發佈的功能。這就萬把塊?也太爽了吧?
"大妹子,你們的需求是在原有網站的基礎上加一個後臺新聞發佈的功能麽?"
"大叔,需求上不都寫的明明白白的麽?你還來問我,想搭訕找個其它理由可以不?就這一個功能,不過以前後臺管理沒有進行許可權管理的,這次要順便做進去"
"做個新聞發佈的功能順便把許可權管理做進去!!太TM扯蛋了吧,這跟買套婚紗讓店主順便送個老婆有什麼區別。。我先考慮下吧。。。"
"好吧,等你的信,下班前給我答覆。"
"大雄,過來瞧瞧,我小學同學的大姨媽家的二舅舅的三嬸子的四兒子的五姑娘的小女兒要找個人家嫁了,這裡有照片,你過來瞅瞅,看有合適的人介紹沒?"
"擦,這不小澤老師麽?你丫忽悠我。"
"大爺的,你啥時候見小澤老師穿這麼厚實過。"
"是哦,聯繫方式有麽,我這不剛失戀,肥水別流外人田了。"
"我這有個小單子,你看看需求,你那邊有差不多的代碼改改用麽?"
"沒問題,我上星期剛整了通用許可權管理系統,你拿去用,說明書也有,標準的ISO"
二、流水線式生產
大雄還真有心,給了我套框架,還配了說明書,按照流程走標準的流水線生產呀。
許可權的事先不用操心了,那就先開始弄資料庫了。
1、後臺表創建
這裡要記得給表和欄位添加說明,這樣在使用代碼生成器的時候就可以帶出註釋。提高代碼可讀性
2、代碼生成
2.1連接代碼生成器
2.2代碼生成
分層生成後臺代碼,複製到項目文件夾下
"大雄,代碼生成完了,接下來我要怎麼做呀?"
"配置許可權呀,說明裡不寫著麽!"
還是看說明吧,指望他幫我做東西是不現實的
3、配置模塊
"大雄,這裡配置模塊有什麼用呀?"
"看下源代碼你不就明白了。。。你到底是不是程式猿呀?"
對呀,是該看一下源代碼了
//手風琴導航菜單 var AccordionMenuJson = ""; function GetAccordionMenu() { var index = 0; var html = ""; getAjax("Frame.ashx", "action=LoadFirstMenu", function (data) { AccordionMenuJson = eval("(" + data + ")"); $.each(AccordionMenuJson, function (i) { if (AccordionMenuJson[i].ParentId == '9f8ce93a-fc2d-4914-a59c-a6b49494108f') { if (index == 0) { html += "<li><a style=\"border-top: 0px solid #ccc;\"><img src=\"/Themes/Images/32/" + AccordionMenuJson[i].Img + "\">" + AccordionMenuJson[i].FullName + "</a>"; } else { html += "<li><a><img src=\"/Themes/Images/32/" + AccordionMenuJson[i].Img + "\">" + AccordionMenuJson[i].FullName + "</a>"; } html += GetSubmenu(AccordionMenuJson[i].MenuId); html += "</li>"; index++; } }); }) $(".accordion").append(html); }
switch (active) { case "login"://登錄 #region 登錄 try { string IPAddress = RequestHelper.GetIPAddress(); objScan.IP = IPAddress; objScan.DataPath = context.Server.MapPath("/Themes/IPScaner/QQWry.Dat"); string IPAddressName = objScan.IPLocation(); if (code.ToLower() != context.Session["dt_session_code"].ToString().ToLower()) { Msg = "1";//驗證碼輸入不正確 } else { //系統管理 if (Account == ConfigHelper.GetValue("CurrentUserName") && Md5Helper.MD5(Pwd, 32) == ConfigHelper.GetValue("CurrentPassword")) { SessionUser user = new SessionUser(); user.UserId = "System"; user.Account = "System"; user.UserName = "超級管理員"; user.Gender = "男"; user.Password = bpms_user.Password; user.Code = "System"; user.DepartmentId = "超級管理員"; user.DepartmentName = "超級管理員"; RequestSession.AddSessionUser(user); Msg = "3";//驗證成功 bpms_syslogibll.AddSysLoginLog(bpms_user.Account, "登錄成功", IPAddress, IPAddressName); } else { #region 驗證 bpms_ipblacklistibll.TheIpIsRange(IPAddress); string outmsg; bpms_user = bpms_useribll.UserLogin(Account.Trim(), Pwd.Trim(), out outmsg); if (outmsg != "-1") { if (outmsg == "succeed") { if (bpms_user.Enabled == 1) { if (Islogin(context, Account.Trim())) { string DepartmentName = ""; bpms_organization = bpms_organizationibll.GetEntity(bpms_user.DepartmentId); if (bpms_organization != null) { DepartmentName = bpms_organization.FullName; } SessionUser user = new SessionUser(); user.UserId = bpms_user.UserId; user.Account = bpms_user.Account; user.UserName = bpms_user.RealName; user.Gender = bpms_user.Gender; user.Password = bpms_user.Password; user.Code = bpms_user.Code; user.Secretkey = bpms_user.Secretkey; user.DepartmentId = bpms_user.DepartmentId; user.DepartmentName = DepartmentName; user.RoleId = bpms_user.RoleId; RequestSession.AddSessionUser(user); Msg = "3";//驗證成功 bpms_syslogibll.AddSysLoginLog(bpms_user.Account, "登錄成功", IPAddress, IPAddressName); } else { context.Response.Write("6");//該用戶已經登錄,不允許重覆登錄 context.Response.End(); } } else { Msg = "2";//賬戶鎖定 bpms_syslogibll.AddSysLoginLog(bpms_user.Account, "賬戶鎖定", IPAddress, IPAddressName); } } else { Msg = "4";//賬戶或者密碼有錯誤 bpms_syslogibll.AddSysLoginLog(bpms_user.Account, "登錄失敗", IPAddress, IPAddressName); } } else { Msg = DbErrorMsg.ReturnMsg;//服務連接不上 } #endregion } } } catch (Exception ex) { Msg = ex.Message; } context.Response.Write(Msg); context.Response.End(); #endregion break; case "Outlogin"://安全退出 UserId = RequestSession.GetSessionUser().UserId; CacheHelper.RemoveAllCache("Module" + UserId); CacheHelper.RemoveAllCache("Button" + UserId); CacheHelper.RemoveAllCache("Data" + UserId); context.Session.Abandon(); //取消當前會話 context.Session.Clear(); //清除當前瀏覽器所以Session context.Response.Write("1"); context.Response.End(); break; case "LoadFirstMenu": UserId = RequestSession.GetSessionUser().UserId; IList list = (IList)StorePermission.Instance.GetModulePermission(UserId); context.Response.Write(JsonHelper.DropToJson<BPMS_ModulePermission>(list, "JSON")); context.Response.End(); break; case "SetSystemId"://模塊ID、訪問模塊 UserId = RequestSession.GetSessionUser().UserId; string SystemId = context.Request["SystemId"]; //模塊ID List<BPMS_ModulePermission> Modulelist = IListHelper.IListToList<BPMS_ModulePermission>((IList)StorePermission.Instance.GetModulePermission(UserId)).FindAll(t => t.MenuId == SystemId); foreach (BPMS_ModulePermission entity in Modulelist) { BPMS_SysLogDAL.Instance.AddVisitLog(UserId, RequestSession.GetSessionUser().UserName, entity.FullName, "URL:" + entity.NavigateUrl); break; } //寫入Session context.Session["SystemId"] = SystemId; context.Response.Write(SystemId); context.Response.End(); break; case "LeaveModule"://離開模塊 break; default: break; } }
從源代碼中可以看出來,在模塊管理中記錄了這個菜單模塊的URL地址,顯示圖標等信息,登陸系統的時候在前臺就能顯示出這個菜單項。
然後原有許可權框架根據模塊的ID也能對這個模塊進行許可權管理。
做的真的很不多,源碼還是要好好看的。
接下來就是公用按鈕的分配了
分配過後點擊保存再刷新一次界面
非常好,勾選的那幾個按鈕按順序都顯示出來了。但是按下去好像不起作用。。。
"大雄,我分配了公共按鈕以後點擊按鈕為什麼不起作用呢?"
"你在代碼裡面實現了按鈕對應的方法函數沒有?"
"我既然要一個個去寫函數,還在這裡來分配什麼按鈕,不如直接自己寫好了,太麻煩了"
"那你自己寫的按鈕,進行許可權判斷的時候每個按鈕里都要去判斷一下麽?"
"哦,我明白啦,你這裡的按鈕其實也跟菜單模塊許可權類似,這裡並不是為了省多少代碼。而是為了更細更方便的控制許可權,許可權系統能根據模塊和按鈕的ID來控制每一個按鈕的操作許可權。比如:新增、刪除、修改什麼的。"
"不錯不錯,一點就通"
//新增 function add() { var url = "/ExampleModule/News/NewsForm.aspx"; top.openDialog(url, 'NewsForm', '新聞信息 - 添加', 800, 500, 50, 50); } //編輯 function edit() { var key = GetPqGridRowValue("#grid_paging", 0); if (IsEditdata(key)) { var url = "/ExampleModule/News/NewsForm.aspx?key=" + key; top.openDialog(url, 'NewsForm', '新聞信息 - 編輯', 800, 500, 50, 50); } } //刪除 function Delete() { var key = GetPqGridRowValue("#grid_paging", 0); if (IsDelData(key)) { var delparm = 'action=Delete&key=' + key; delConfig('NewsList.aspx', delparm); } } //刷新 function windowload() { $("#grid_paging").pqGrid("refreshDataAndView"); GetRowIndex = -1; }
這裡寫了一個每個按鈕的操作函數,不管是js還是後臺代碼都可以被許可權系統牢牢控制,非常好用呀,再次運行
OK,完全實現了功能。
掐表一算,整個過程才20分鐘不到,而且我是第一次使用這個框架。流水線式生產就是好呀。
"大雄,我用了不到20分鐘就全搞定了呀。明天請你吃飯噢。"
"20分鐘?你也太慢了。。。先看看這篇博客瞭解下這個框架的詳細結構《打造一套UI與後臺並重.net通用許可權管理系統》,10分鐘你就能搞定"
http://www.learun.cn 力軟官網
http://learun.cn:8090 線上demo