浅谈web开发

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

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
任何组合数都能从下面的表中得到结果:

3

回到问题中,我在数据库中储存了文件权限数字,我再应用时候要转化出来,转成字母形式,然后审查权限够不够。

首先,这里不同,第一段是,文件所有者对此文件的操作权限;第二段是,文件被分享者对此文件的操作权限;第三段是普通参观者对文件操作权限。

那么,我选权限,先分割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);
	} 
}

 

 

【原文:浅谈web开发 MottoIN小编整理发布】

原创文章,作者:Moto,如若转载,请注明出处:http://www.mottoin.com/article/network/84856.html

发表评论

登录后才能评论

联系我们

021-62666911

在线咨询:点击这里给我发消息

邮件:root@mottoin.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code