0x01.About
平时写代码大多数都是一些小模块,很少会一个人完整地写一个大型的网站。
我独自写过几个网站,都没发布,想想归结几个问题,要么界面太丑,要么逻辑细节漏洞太多,要么没有实际的使用价值。
完整地一个大型网站很复杂,要做好前端的效果,业务逻辑,cdn静态文件,服务器集群。
每一个我都尝试做过,之前在一篇《分布式服务器集群架构方案思考》中分析过,关于网站架构的模型,也做过几篇关于nginx服务器集群处理的文章。
这里做个小总结,分享下最近开发过程中一些零零碎碎的蛋疼东西。
0x02.前端说起
前端的第一感觉要代码简约,数据清晰。
1.命名简约,《Google开源项目风格指南》
大小写区分,变量函数区分,后来我写代码,就统一将变量写成小写+下划线,函数写成首字母大写,函数统一同一栏花括号。
2.关于闭包
简约就不得不说起闭包问题,闭包显然对于多人开发很好用,这也体现了js的灵活性。
个人习惯是写一个base的函数库,然后每个页面需求写不同的js库。
(function(){
//main js
function index(){
var that = this;
this.fun1 = function(){};
this.fun2 = function(){};
this.fun3 = function(){};
}
window.index = index;//这样的话,外界浏览器就能访问到闭包内部了。
})();
这是一种方式,还可以用个简单地方法直接写在一个函数内部。
function index(){
this.fun1 = function(){}
return this;
}
类似MVC思想,可以把js分成:base层,common层,page层。
base层:主要兼容一些浏览器特性,比较底层,类似mvc中的m层,封装不同浏览器特性公common层调用。
common层:主要集成化插件,实现功能供page调用,mvc中典型的c层,控制页面的主体。
page:其实我们平时用的插件都在用page层多,插件都是封装了base和common层。
3.关于异步与同步
这是我这几天碰到的问题,关于异步与同步转化问题。f1()与f2()
function f1(callback){
setTimeout(function () {
// f1的任务代码
callback();
}, 1000);
}
如果f1是一个很耗时的任务,可以考虑改写f1,把f2写成f1的回调函数。f1(f2)
4.下面是每次都会用到的代码片段
function SetCookie(name,value,expiredays){
var exdate=new Date()
exdate.setDate(exdate.getDate()+expiredays)
document.cookie=name+ "=" +escape(value)+
((expiredays==null) ? "" : ";expires="+exdate.toGMTString())
}
function GetCookie(c_name){
if (document.cookie.length>0){
c_start=document.cookie.indexOf(c_name + "=");
if (c_start!=-1){
c_start=c_start + c_name.length+1
c_end=document.cookie.indexOf(";",c_start)
if (c_end==-1) c_end=document.cookie.length
return unescape(document.cookie.substring(c_start,c_end));
}
}
return "";
}
0x03.关于后端代码
1.关于模型与架构方式,可以用MVC,MVP,MVVC等。
MVC作为快速,稳健开发是非常适合的,分层明显,结果清晰,层级与层级之间互为类,层级之间传输通过array形式。
视图(View):用户界面。
控制器(Controller):业务逻辑
模型(Model):数据保存
2.web中用户文件权限模型设计
这是我最近在开发时候碰到的问题,如何去处理不同用户之间的权限等级,后来就想到了Linux的权限管理,先脑补下Linux权限表:
- Linux字母权限中,
1,第一段:例子中字母“d”,表示文件所在目录
2,第二段:例子中字符串“rwx”,表示文件所有者对此文件的操作权限
3,第三段,例子中字符串“r-x”,表示文件所有者所在组对些文件的操作权限
4,第四段,例子中字符串“r-x”,表示除2、3两种外的任何人对此文件的操作权限
- Linux里面数字权限中,r(read)->4,w(write)->2,x(execute)->1
任何组合数都能从下面的表中得到结果:
回到问题中,我在数据库中储存了文件权限数字,我再应用时候要转化出来,转成字母形式,然后审查权限够不够。
首先,这里不同,第一段是,文件所有者对此文件的操作权限;第二段是,文件被分享者对此文件的操作权限;第三段是普通参观者对文件操作权限。
那么,我选权限,先分割766中,用户所在第几位。
接着将第几位,数字表与字母表转化,最后分析权限够不够。
伪代码如下:
$competence = 数字权限;
if(query->row_num()!=0){
$res = str_split($competence,1);
switch($type){
case 'admin':
return $res[0];
break;
case 'share':
return $res[1];
break;
case 'guest':
return $res[2];
break;
default:
return $res[2];
break;
}
}
接着确认用户权限够不够:
function CheckCompetence($expected, $input=000){
$res = "---";
preg_match("/r/i", $expected, $matches);
if($matches){//read
if($input==7 || $input==6 || $input==5 || $input==4) $res[0]="r";
else return false;
}
preg_match("/w/i", $expected, $matches);
if($matches){//write
if($input==7 || $input==6 || $input==3 || $input==2) $res[1]="w";
else return false;
}
preg_match("/x/i", $expected, $matches);
if($matches){//exec
if($input==7 || $input==5 || $input==3 || $input==1) $res[2]="x";
else return false;
}
return $res;
}
期望的权限expected为字母,输入权限为input,如果用户权限不足,返回false。
通信传输常用的base加密代码片段
class base{
//private $string = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-+*#@";
private $string = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
private $base = 62;
public function base62_encode($str) {
$out = '';
for($t=floor(log10($str)/log10( $this->base )); $t>=0; $t--) {
$a = floor($str / pow( $this->base, $t));
$out = $out.substr($this->string, $a, 1);
$str = $str - ($a * pow( $this->base, $t));
}
return $out;
}
public function base62_decode($str) {
$out = 0;
$len = strlen($str) - 1;
for($t=0; $t<=$len; $t++) {
$out = $out + strpos($this->string, substr($str, $t, 1)) * pow( $this->base, $len - $t);
}
return substr(sprintf("%f", $out), 0, -7);
}
}
本文出自 夏日小草,转载请注明出处: http://homeway.me/2015/05/12/think-about-web-develop/
by 小草
2015-05-12 1:29:20
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。