摘要:知識在于分享,也是希望和大家交流下,如何把后臺管理系統寫得能更具工程化,模塊化,更有效率。后臺管理系統多為端,所以和的技術運用不多,會根據產品需求進行優雅降級和漸進增強。
前兩天看segmentfault的時候,突然間,想寫篇文章總結一下那些年自己寫過的后臺管理系統。作為我前端的入門項目,我對后臺管理系統的感情還是挺深的。本著以下幾點原因,寫了此文。
對后臺管理系統做一個綜合全面的總結(嗯,這會是我以后項目總結的開端)。
也算是給新入門的一個基本概念和學習范圍吧(~大神請自動忽略~)。
知識在于分享,也是希望和大家交流下,如何把后臺管理系統寫得能更具工程化,模塊化,更有效率。
后臺管理系統多為PC端,所以css3和HTML5的技術運用不多,會根據產品需求進行優雅降級和漸進增強。下面先上一張圖,羅列下后臺管理系統涉及到的方方面面,歡迎大家補充。
語言
html+js+css+php mysql c++
后臺管理系統常用框架:bootstrap
常用類庫:jquery,jquery UI(里面有很多好用的函數和小組件)
整體實現:
前端頁面HTML+css+js ,用php做cgi層調后臺接口,數據渲染。
頁面結構:
頭部,側邊欄導航條,面包屑等公共部分抽離成頁面片,表格,表單,列表等抽離成小組件。所以后臺管理系統的頁面就有各個小積木拼接而成。
最常見的操作:
增刪改查:后臺管理系統的標配。主要是操作DOM,調接口,只是操作成功后,如果想有更好的用戶體驗,不要刷新頁面,用js動態改DOM即可,其余感覺沒啥好說的。
批量操作:批量操作本身并沒有技術難點,但是在用戶體驗上,個人認為,有很多講究。例如:全選,單選,多選,不選時的處理;單個或多個校驗不合法時的提示和處理;部分成功,部分失敗時的提示和處理;全部成功的處理;
查詢:這是后臺管理系統的標配。常見2種處理方法,1.get方法,參數全部拼到URL上,個人推薦這種,可以存為書簽;2.post方法,URL始終不會改變,大家都知道post方法較安全,但是這種無法保存為書簽,f5刷新頁面時無法保存查詢條件。(若是各位看官有別的實現方法,歡迎賜教)
導出:一般是導出Excel表格。用PHPExcel類庫。
需要加上頭信息:
header("Content-Type: application/vnd.ms-excel"); header(sprintf("Content-Disposition: attachment;filename="%s.xls"",$filename)); header("Cache-Control: max-age=0");
導入:一般也是導入Excel表格。用php的$_FILES可獲得上傳的文件。
if (isset($_FILES["file"]) && 0 == $_FILES["file"]["error"]) { $fileType = array("application/vnd.ms-excel", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", "application/kset","application/octet-stream"); //文件格式 if (in_array($_FILES["file"]["type"], $fileType) && $_FILES["file"]["size"] <= 2 * 1000 * 1000) { $file = $_FILES["file"]["tmp_name"]; require_once BASEPATH . "/libraries/phpexcel/PHPExcel.php"; $excelReader = new PHPExcel_Reader_Excel2007(); if (!$excelReader->canRead($file)) { $excelReader = new PHPExcel_Reader_Excel5(); } $sheet = $excelReader->load($file)->getSheet(0); //sheet1操作 $excelCont = array( "highestCol" => $sheet->getHighestColumn(), //列 "highestRow" => $sheet->getHighestRow(), //行 "highestColumnIndex" => PHPExcel_Cell::columnIndexFromString($sheet->getHighestColumn()) // 幾列 ); } }
權限控制處理:
白名單,黑名單:以php的CI框架為例,思路是:在項目的配置文件config中寫入名單數組,在core下建一個繼承CI_Controller的MY_Controller文件,然后在文件中封裝權限控制方法,這樣整個項目下的文件只要繼承了MY_Controller 就都可以調用這個權限控制的方法。
日志:雖然后臺肯定會打錯誤日志,但前端也要根據業務適當打日志。打日志是為了出錯時,更好的定位問題,所以多半在出錯時,把接口入參和出參打出來。具體怎么打,要根據業務情況。
例如:下面這種根本不調接口的情況,后臺根本不會有日志,但用戶會有上傳失敗的情況,所以前端日志對定位問題有很大幫助,cilog是封裝好的一個寫日志的函數。
elseif (!in_array($_FILES["file"]["type"],$fileType)) { cilog("error", "上傳文件MIME:".$_FILES["file"]["type"]); echo ""; } elseif ($_FILES["file"]["size"] > 2 * 1000 * 1000) { cilog("error", "上傳文件大小:".$_FILES["file"]["size"]); echo ""; } else { cilog("error", "上傳失敗:上傳文件MIME:".$_FILES["file"]["type"]."上傳文件大小:".$_FILES["file"]["size"]); echo ""; }
xss過濾:
安全問題主要是xss和sql注入。sql注入后臺會做,前端主要是做xss過濾。常用的解決方案就是:對特殊字符進行轉義。但這樣會造成頁面展示上也會轉義。所以目前的解決方案是,將半角的<>字符轉義成全角的<>。
$strNavName=str_replace("<", "<", $str); $strNavName=str_replace(">", ">", $strNavName);
登陸:加密(https),一般登錄頁會使用https協議,使用md5多次加密。
退出:清cookie,清sessionkey。
document.cookie = name + "=;expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain=" + domain;
異常處理:雖然后臺管理系統對異常的容忍度遠遠小于用戶側的項目,但作為一個有追求的前端,對異常分支還是要認真對待。
對于操作成功或失敗,都會給出對應的提示。封裝一個公共的函數,根據錯誤碼,給出用戶能夠理解的錯誤提示。
使用try catch,保證邊緣數據異常時不影響主體功能。例如:一個商品列表的頁面,商品的信息是主體,商品的評論數據是非主體,評論和商品不是同一個接口,評論接口有時會掛掉,所以就對評論接口使用try catch,保證評論異常時,商品數據是可以正常顯示的。
try { //可能會出錯的具體業務代碼 } catch(Exception $e) { //打日志,做容災處理 cilog("error", "get_mgmt_comment_list error: ".$e->getMessage()); }
【注】:這些異常處理只是前端對異常的處理,后臺也會有自己的異常報警處理。
常用插件(后臺管理系統的標配 ):
日歷:datetimepicker (個人比較傾向這個),layDate
彈窗:bootstrap的modal。如果自己寫,最好是一個網站的風格保持一致,封裝一個統一的函數或組件。
拖拽排序:jquery UI有現成的api,拖拽draggable,排序sortable,非常好用。
分頁:PHP CI框架有現成的分頁類Pagination,可以配合bootstrap的分頁樣式使用。
一些優秀的模板:(網上一搜一大堆)
http://www.jq22.com/demo/Bootstrap-150103222921/dashboard-1.html
http://themes.laborator.co/
http://themes.laborator.co/#theme=neon
字體圖標庫:
FontAwesome:http://fontawesome.io/
阿里巴巴矢量圖標庫:http://www.iconfont.cn/
據說后臺管理系統和Vue更配呢,改天得試下~~
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/79807.html
摘要:知識在于分享,也是希望和大家交流下,如何把后臺管理系統寫得能更具工程化,模塊化,更有效率。后臺管理系統多為端,所以和的技術運用不多,會根據產品需求進行優雅降級和漸進增強。 前兩天看segmentfault的時候,突然間,想寫篇文章總結一下那些年自己寫過的后臺管理系統。作為我前端的入門項目,我對后臺管理系統的感情還是挺深的。本著以下幾點原因,寫了此文。 對后臺管理系統做一個綜合全面的總...
摘要:此篇文章并未如何教你怎么面試的時候吹逼,而是給一點點建議,如何更聰明地達到目的。據不完全統計,基本都是做管理后臺改。不要太沉溺和糾結于技術,把重心移到業務能力上,踏踏實實做事。 前言 ??對于很多剛畢業或者大四的同學,都會有個困惑,我如何學PHP,為什么知識會那么雜,然后實習中公司大概需要哪些要求。此篇文章并未如何教你怎么面試的時候吹逼,而是給一點點建議,如何更聰明地達到目的。 實習可...
showImg(https://segmentfault.com/img/bVbw3tK?w=1240&h=827); 前端工程師這個崗位,真的是反人性的 我們來思考一個問題: 一個6年左右經驗的前端工程師: 前面兩年在用jQuery 期間一直在用React-native(一步一步踩坑過來的那種) 最近兩年還在寫微信小程序 下面一個2年經驗的前端工程師: 并不會跨平臺技術,他的兩年工作都是Reac...
摘要:而道器相融,在我看來,那煉丹就需要一個好的丹爐了,也就是一個優秀的機器學習平臺。因此,一個機器學習平臺要取得成功,最好具備如下五個特點精辟的核心抽象一個機器學習平臺,必須有其靈魂,也就是它的核心抽象。 *本文首發于 AI前線 ,歡迎轉載,并請注明出處。 摘要 2017年6月,騰訊正式開源面向機器學習的第三代高性能計算平臺 Angel,在GitHub上備受關注;2017年10月19日,騰...
閱讀 2910·2021-11-25 09:43
閱讀 2334·2021-11-24 09:39
閱讀 2719·2021-09-23 11:51
閱讀 1410·2021-09-07 10:11
閱讀 1456·2019-08-27 10:52
閱讀 1942·2019-08-26 12:13
閱讀 3361·2019-08-26 11:57
閱讀 1401·2019-08-26 11:31