大濕教我寫程序(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分鍾你就能搞定"

附大濕教我寫程序系列博文:

打造一套UI與后台並重.net通用權限管理系統

大濕教我寫程序(1)之菜單導航篇

大濕教我寫程序(2)之走向AV之路

大濕教我寫程序(3)之自動補全(屌絲沒有春天)篇

 

http://www.learun.cn  力軟官網

http://www.learun.cn:8080  在線demo

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM