后端技术

python改变系统hosts

Posted in 后端技术 on 十一月 2nd, 2009 by admin – 评论关闭

因工作需要一直修改系统hosts,以切换内网,外网,其他测试服务器。
天天改比较麻烦写了这个小工具比较简单, 打包成EXE后比较大(不过自己用的东西就没啥讲究了)

贴上源代码

#-* coding:GBK *-
import os
import wx

def create(parent):
    return Frame1(parent)

# assign ID numbers
[wxID_FRAME1, wxID_FRAME1BUTTON1, wxID_FRAME1BUTTON2, wxID_FRAME1LISTBOX1,
] = [wx.NewId() for _init_ctrls in range(4)]

class Frame1(wx.Frame):
    def _init_ctrls(self, prnt):
        # BOA generated methods
        wx.Frame.__init__(self, id=wxID_FRAME1, name='', parent=prnt,
              pos=wx.Point(400, 400), size=wx.Size(500, 400),
              style=wx.DEFAULT_FRAME_STYLE, title='改系统hosts,需要把要修改的hosts文件放在hosts目录下面')

        self.SetClientSize(wx.Size(750, 300))

        self.listBox1 = wx.ListBox(choices=[], id=wxID_FRAME1LISTBOX1,
              name='listBox1', parent=self, pos=wx.Point(10, 10),
              size=wx.Size(200, 240), style=0)

        self.t1 = wx.TextCtrl(self, -1,"",size=(520, 280), pos=wx.Point(220, 10),style=wx.TE_MULTILINE|wx.TE_PROCESS_ENTER)

        '''列表目录中所有文件'''
        for i in os.listdir('./hosts/'):
            self.listBox1.Append(i)   

        self.listBox1.Bind(wx.EVT_LISTBOX, self.OnListBox1Listbox,
              id=wxID_FRAME1LISTBOX1)            

        self.button2 = wx.Button(id=wxID_FRAME1BUTTON2, label='改写系统hosts',
              name='button2', parent=self, pos=wx.Point(10, 260),
              size=wx.Size(200, 30), style=0)

        self.button2.Bind(wx.EVT_BUTTON, self.OnButton2Button,
              id=wxID_FRAME1BUTTON2)

    def __init__(self, parent):
        self._init_ctrls(parent)

    def OnListBox1Listbox(self, event):
        selName = './hosts/' + self.listBox1.GetStringSelection()
        #self.SetTitle(selName)       

        f = open(selName, "r+")
        try:
            all_the_text = f.read( )
        finally:
            f.close()
        self.t1.Clear()
        self.t1.write(all_the_text)        

    def OnButton2Button(self, event):
        x = os.getenv('WINDIR')+"\system32\drivers\etc\hosts"
        v = self.t1.GetValue();
        v = v.encode('gb2312')
        f = open(x, 'w')
        f.writelines(v)
        f.close( )        

#--------------- end of class Frame1 --------------------

# program entry point ...
if __name__ == '__main__':
    app = wx.PySimpleApp()
    wx.InitAllImageHandlers()
    frame = create(None)
    frame.Show()

    app.MainLoop()

使用PHPXref生成PHP开发文档

Posted in 后端技术, 开源 on 八月 15th, 2009 by admin – 评论关闭

PHPXref是一个开源项目使用perl编写.
phpdoc生成开发文档时要配置一堆东西. 而且又很难用.
最近发现这个不错

下载地址:
http://sourceforge.net/projects/phpxref/files/phpxref/0.7/phpxref-0.7-win32.zip/download

这个不需要安装prel 环境
配置 phpxref.cfg

一般修改4个地方:
SOURCE=C:\phpxref\source #源代码
OUTPUT=C:\phpxref\output #输出
PROJECT=Unnamed Project #项目名称
CHARSET=utf-8 #中文的话修改一下编码

其他的还没有我没有用到, 大家可以试试

最后执行一下 phpxref.exe

javascript与php类型转换

Posted in 前端技术, 后端技术 on 十一月 27th, 2008 by admin – 评论关闭

1. 字符串转换为整型
//php
intval(); //php
floatval();//php浮点
strval();

//javascript
toString(); //转化为整型
parseInt(); //js 转化为整型
parseFloat(); //转化为浮点
Number(); //js, 这个会自动转

php限制网站访问IP(段)

Posted in 后端技术 on 十一月 20th, 2008 by admin – 评论关闭

可以限制单独IP与IP段

ip.txt (存放限制的IP及IP段)
58.14.0.0-58.25.255.255
127.0.0.1-127.0.0.1

前后IP相同表示只指定1个IP

/*
 * 马克(sim_cn@qq.com)
 * www.simcn.com
 */
$meip = ip2long($_SERVER['REMOTE_ADDR']);
$filename="../ip.txt";     	//定义操作文件
$ip_lib=file($filename);  	//读取文件数据到数组中 

for($i=0;$i= $sip && $meip <= $eip){
		echo "你的IP被限制了,有问题请联系管理员";
		exit();
		break;
	}
}

本文用用到函数解释

ip2long 把ip地址转换为 整型数字有+,-

优化一下代码
可以限制单独IP与IP段

ip.txt (存放限制的IP及IP段)
58.14.0.0-58.25.255.255
127.0.0.1-127.0.0.1

前后IP相同表示只指定1个IP

/*
 * 马克(sim_cn@qq.com)
 * www.simcn.com
 */
$meip = ip2long($_SERVER['REMOTE_ADDR']);
$filename="../ip.txt";     	//定义操作文件
$ip_lib=file($filename);  	//读取文件数据到数组中 

$n = count($ip_lib); //不在for循环中做函数会更快一点.
for($i=0;$i<$n;$i++){
	list($sip,$eip) = explode('-',$ip_lib[$i]);
	$sip = ip2long(trim($sip));
	$eip = ip2long(trim($eip));
	if($meip >= $sip && $meip <= $eip){
		echo "你的IP被限制了,有问题请联系管理员";
		exit();
	}
}

日期(date)函数的常量(PHP5)

Posted in 后端技术 on 十一月 3rd, 2008 by admin – 评论关闭

php5.1.1以后,date函数新增了以下常量。

自 PHP 5.1.1 起定义有以下常量来提供标准日期表达方法,可以用于日期格式函数(例如 date())。

DATE_ATOM(string)
原子钟格式(如:2005-08-15T15:52:01+00:00)

DATE_COOKIE(string)
HTTP Cookies 格式(如:Mon, 15 Aug 2005 15:52:01 UTC)

DATE_ISO8601(string)
ISO-8601(如:2005-08-15T15:52:01+0000)

DATE_RFC822(string)
RFC 822(如:Mon, 15 Aug 2005 15:52:01 UTC)

DATE_RFC850(string)
RFC 850(如:Monday, 15-Aug-05 15:52:01 UTC)

DATE_RFC1036(string)
RFC 1036(如:Monday, 15-Aug-05 15:52:01 UTC)

DATE_RFC1123(string)
RFC 1123(如:Mon, 15 Aug 2005 15:52:01 UTC)

DATE_RFC2822(string)
RFC 2822(如:Mon, 15 Aug 2005 15:52:01 +0000)

DATE_RSS(string)
RSS(如:Mon, 15 Aug 2005 15:52:01 UTC)

DATE_W3C(string)
World Wide Web Consortium(如:2005-08-15T15:52:01+00:00)

比如,要输出一个RSS需要的日期格式,就可以用下面的代码简单实现:

echo date(DATE_RSS);

优化PHP代码的40条建议

Posted in 后端技术 on 十月 23rd, 2008 by admin – 评论关闭

简介

英文版权归Reinhold Weber所有,中译文作者yangyang(aka davidkoree)。双语版可用于非商业传播,但须注明英文版作者、版权信息,以及中译文作者。翻译水平有限,请广大PHPer指正。

1.如果一个方法可静态化,就对它做静态声明。速率可提升至4倍。

2.echo 比 print 快。

3.使用echo的多重参数(译注:指用逗号而不是句点)代替字符串连接。

4.在执行for循环之前确定最大循环数,不要每循环一次都计算最大值。

5.注销那些不用的变量尤其是大数组,以便释放内存。

6.尽量避免使用__get,__set,__autoload。

7.require_once()代价昂贵。

8.在包含文件时使用完整路径,解析操作系统路径所需的时间会更少。

9.如果你想知道脚本开始执行(译注:即服务器端收到客户端请求)的时刻,使用$_SERVER[‘REQUEST_TIME’]要好于time()。

10.函数代替正则表达式完成相同功能。

11.str_replace函数比preg_replace函数快,但strtr函数的效率是str_replace函数的四倍。

12.如果一个字符串替换函数,可接受数组或字符作为参数,并且参数长度不太长,那么可以考虑额外写一段替换代码,使得每次传递参数是一个字符,而不是只写一行代码接受数组作为查询和替换的参数。

13.使用选择分支语句(译注:即switch case)好于使用多个if,else if语句。

14.用@屏蔽错误消息的做法非常低效。

15.打开apache的mod_deflate模块。

16.数据库连接当使用完毕时应关掉。

17.$row[‘id’]的效率是$row[id]的7倍。

18.错误消息代价昂贵。

19.尽量不要在for循环中使用函数,比如for ($x=0; $x < count($array); $x)每循环一次都会调用count()函数。

20.在方法中递增局部变量,速度是最快的。几乎与在函数中调用局部变量的速度相当。

21.递增一个全局变量要比递增一个局部变量慢2倍。

22.递增一个对象属性(如:$this->prop++)要比递增一个局部变量慢3倍。

23.递增一个未预定义的局部变量要比递增一个预定义的局部变量慢9至10倍。

24.仅定义一个局部变量而没在函数中调用它,同样会减慢速度(其程度相当于递增一个局部变量)。PHP大概会检查看是否存在全局变量。

25.方法调用看来与类中定义的方法的数量无关,因为我(在测试方法之前和之后都)添加了10个方法,但性能上没有变化。

26.派生类中的方法运行起来要快于在基类中定义的同样的方法。

27.调用带有一个参数的空函数,其花费的时间相当于执行7至8次的局部变量递增操作。类似的方法调用所花费的时间接近于15次的局部变量递增操作。

28.用单引号代替双引号来包含字符串,这样做会更快一些。因为PHP会在双引号包围的字符串中搜寻变量,单引号则不会。当然,只有当你不需要在字符串中包含变量时才可以这么做。

29.输出多个字符串时,用逗号代替句点来分隔字符串,速度更快。注意:只有echo能这么做,它是一种可以把多个字符串当作参数的“函数”(译注:PHP手册中说echo是语言结构,不是真正的函数,故把函数加上了双引号)。

30.Apache解析一个PHP脚本的时间要比解析一个静态HTML页面慢2至10倍。尽量多用静态HTML页面,少用脚本。

31.除非脚本可以缓存,否则每次调用时都会重新编译一次。引入一套PHP缓存机制通常可以提升25%至100%的性能,以免除编译开销。

32.尽量做缓存,可使用memcached。memcached是一款高性能的内存对象缓存系统,可用来加速动态Web应用程序,减轻数据库负载。对运算码 (OP code)的缓存很有用,使得脚本不必为每个请求做重新编译。

33.当操作字符串并需要检验其长度是否满足某种要求时,你想当然地会使用strlen()函数。此函数执行起来相当快,因为它不做任何计算,只返回在zval 结构(C的内置数据结构,用于存储PHP变量)中存储的已知字符串长度。但是,由于strlen()是函数,多多少少会有些慢,因为函数调用会经过诸多步骤,如字母小写化(译注:指函数名小写化,PHP不区分函数名大小写)、哈希查找,会跟随被调用的函数一起执行。在某些情况下,你可以使用isset() 技巧加速执行你的代码。

(举例如下)
if (strlen($foo) < 5) { echo “Foo is too short”$$ }
(与下面的技巧做比较)
if (!isset($foo{5})) { echo “Foo is too short”$$ }

调用isset()恰巧比strlen()快,因为与后者不同的是,isset()作为一种语言结构,意味着它的执行不需要函数查找和字母小写化。也就是说,实际上在检验字符串长度的顶层代码中你没有花太多开销。

34.当执行变量$i的递增或递减时,$i++会比++$i慢一些。这种差异是PHP特有的,并不适用于其他语言,所以请不要修改你的C或Java代码并指望它们能立即变快,没用的。++$i更快是因为它只需要3条指令(opcodes),$i++则需要4条指令。后置递增实际上会产生一个临时变量,这个临时变量随后被递增。而前置递增直接在原值上递增。这是最优化处理的一种,正如Zend的PHP优化器所作的那样。牢记这个优化处理不失为一个好主意,因为并不是所有的指令优化器都会做同样的优化处理,并且存在大量没有装配指令优化器的互联网服务提供商(ISPs)和服务器。

35.并不是事必面向对象(OOP),面向对象往往开销很大,每个方法和对象调用都会消耗很多内存。

36.并非要用类实现所有的数据结构,数组也很有用。

37.不要把方法细分得过多,仔细想想你真正打算重用的是哪些代码?

38.当你需要时,你总能把代码分解成方法。

39.尽量采用大量的PHP内置函数。

40.如果在代码中存在大量耗时的函数,你可以考虑用C扩展的方式实现它们。

41.评估检验(profile)你的代码。检验器会告诉你,代码的哪些部分消耗了多少时间。Xdebug调试器包含了检验程序,评估检验总体上可以显示出代码的瓶颈。

42.mod_zip可作为Apache模块,用来即时压缩你的数据,并可让数据传输量降低80%。

43.另一篇优化PHP的精彩文章,由John Lim撰写。

自己写个mysql的操作类

Posted in 后端技术, 数据库相关 on 十月 22nd, 2008 by admin – 评论关闭
links = mysql_connect($host, $user, $pass)){
			return false;
		}
		mysql_select_db($dbname);
		$this->connected = true;
	}

	//关闭
	function close(){
		$this->connected = false;
		$this->link = null;
		return true;
	}

	//快速查询
	//返回影响的记录条数
	function _query($sql){
		if(empty($sql) or !$this->connected){ return false; }
		return mysql_query($sql);
	}

	//返回二维数组(行, 列)
	function execute($sql){
		if(empty($sql) or !$this->connected){ return false;}
		$result = $this->_query($sql);
		while ($row = mysql_fetch_array($result, MYSQL_ASSOC)){
			$out[]=$row;
		}
		mysql_free_result($result);
		return $out;
	}

	//返选输出范围
	function selectlimit($sql,$numrows=-1,$offset=-1){
		if(empty($sql) or !$this->connected){ return false;}
		$sql = $sql." LIMIT $numrows,$offset";
		$result = $this->_query($sql);
		while ($row = mysql_fetch_array($result, MYSQL_ASSOC)){
			$out[]=$row;
		}
		mysql_free_result($result);
		return $out;
	}

	//取单个字段记录
	function getone($sql){
		if(empty($sql) or !$this->connected){ return false;}
		$result = $this->_query($sql);
		$row = mysql_fetch_array($result);
		mysql_free_result($result);
		return $row[0];
	}

	//取单个表记录
	function getrow($sql){
		if(empty($sql) or !$this->connected){ exit('db connected error');return false;}
		$result = $this->_query($sql);
		$row = mysql_fetch_array($result, MYSQL_ASSOC);
		mysql_free_result($result);
		return $row;
	}

	//删除记录
	function del($sql){
		return $this->_query($sql);
	}

	//增加记录
	function into($sql){
		$this->_query($sql);
		return mysql_insert_id();
	}
}


echo "
";
$conn = new db;
$conn->connect();

$sql = 'SELECT * FROM mt_tag';
$sql1 = "INSERT INTO mt_tag (tagname) VALUES ('abc')";
$sql2 = "DELETE FROM `mt_tag` WHERE (`id`='123')  ";

$arr = ($conn->selectlimit($sql,0,5));

foreach($arr as $v){
	foreach ($v as $k=>$v1){
		echo $k."->>".$v1."";
	}
	echo "

"; } var_dump($conn->_query($sql2)); print_r($conn->getrow($sql)); print_r($conn->getone($sql)); $conn->close();
?>

php加密cookie[原创]

Posted in 后端技术 on 十月 13th, 2008 by admin – 评论关闭

我们知道php的cookie是明文方式记录在本机上,有些数据要需要有点保密需求,所以写了这个class。

其中加密算法修改于 网站上流传的 xxtea算法.

代码如下

1.class.xxtea.php

andot@ujn.edu.cn>
* Version:      1.5
* LastModified: Dec 5, 2006
* This library is free. You can redistribute it and/or modify it.
* max修改于2008.08.08 maxtank@qq.com
*/

class xxtea{

private $key1 = 'AmPu$this1';
private function long2str($v, $w) {
   $len = count($v);
   $n = ($len - 1) << 2;
   if ($w) {
    $m = $v[$len - 1];
    if (($m < $n - 3) || ($m > $n)) return false;
    $n = $m;
   }
   $s = array();
   for ($i = 0; $i < $len; $i++) {
    $s[$i] = pack("V", $v[$i]);
   }
   if ($w) {
    return substr(join('', $s), 0, $n);
   }
   else {
    return join('', $s);
   }
}

private function str2long($s, $w) {
   $v = unpack("V*", $s. str_repeat("\0", (4 - strlen($s) % 4) & 3));
   $v = array_values($v);
   if ($w) {
    $v[count($v)] = strlen($s);
   }
   return $v;
}

private function int32($n) {
   while ($n >= 2147483648) $n -= 4294967296;
   while ($n <= -2147483649) $n += 4294967296;
   return (int)$n;
}

protected function xxtea_encrypt($str, $key) {
   if ($str == "") {
    return "";
   }
   $v = $this->str2long($str, true);
   $k = $this->str2long($key, false);
   if (count($k) < 4) {
    for ($i = count($k); $i < 4; $i++) {
     $k[$i] = 0;
    }
   }
   $n = count($v) - 1;

   $z = $v[$n];
   $y = $v[0];
   $delta = 0x9E3779B9;
   $q = floor(6 + 52 / ($n + 1));
   $sum = 0;
   while (0 < $q--) {
    $sum = $this->int32($sum + $delta);
    $e = $sum >> 2 & 3;
    for ($p = 0; $p < $n; $p++) {
     $y = $v[$p + 1];
     $mx = $this->int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ $this->int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
     $z = $v[$p] = $this->int32($v[$p] + $mx);
    }
    $y = $v[0];
    $mx = $this->int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ $this->int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
    $z = $v[$n] = $this->int32($v[$n] + $mx);
   }
   return $this->long2str($v, false);
}

protected function xxtea_decrypt($str, $key) {
   if ($str == "") {
    return "";
   }
   $v = $this->str2long($str, false);
   $k = $this->str2long($key, false);
   if (count($k) < 4) {
    for ($i = count($k); $i < 4; $i++) {
     $k[$i] = 0;
    }
   }
   $n = count($v) - 1;

   $z = $v[$n];
   $y = $v[0];
   $delta = 0x9E3779B9;
   $q = floor(6 + 52 / ($n + 1));
   $sum = $this->int32($q * $delta);
   while ($sum != 0) {
    $e = $sum >> 2 & 3;
    for ($p = $n; $p > 0; $p--) {
     $z = $v[$p - 1];
     $mx = $this->int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ $this->int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
     $y = $v[$p] = $this->int32($v[$p] - $mx);
    }
    $z = $v[$n];
    $mx =$this->int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4)) ^ $this->int32(($sum ^ $y) + ($k[$p & 3 ^ $e] ^ $z));
    $y = $v[0] = $this->int32($v[0] - $mx);
    $sum = $this->int32($sum - $delta);
   }
   return $this->long2str($v, true);
}

//转化为16进制
protected function stringToHex ($s) {
   $r = "0x";
   $hexes = array ("0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f");
   for ($i=0; $i> 4)] . $hexes [(ord($s{$i}) & 0xf)]);}
   return $r;
}

//16进抽转化为代码
protected function hexToString ($h) {
   $r = "";
   for ($i= (substr($h, 0, 2)=="0x")?2:0; $istringToHex($this->xxtea_encrypt($str,$this->key1));
}

//解密
public function decrypt($str){
   return $this->xxtea_decrypt($this->hexToString($str),$this->key1);
}

}
?>

2. class.safe.cookie.php

itime = 60*60*24*30; //30天过期
}
//设置安全cookie(名称,值)
public function set_cookie($cn,$cv){
   $cv = parent::encrypt($cv); //调用父类的方法
   setcookie($cn, $cv, time() + $this->itime);
}
//读取cookie(名称)
public function get_cookie($cn){
   return parent::decrypt($_COOKIE[$cn]);
}
//删除cookie(名称)
public function del_cookie($cn){
   setcookie($cn,"",time()-3600);
}
//删除所有cookie(名称)
public function del_all_cookie(){
   foreach ($_COOKIE as $name => $value) {
     setcookie($name,"",time()-3600);
   }
}
}

/*
$n = new SafeCookie();
print_r($_COOKIE);
$n->set_cookie("abc","中国人啊56611");
$n->set_cookie("ab11c","中国");
$n->del_cookie("ab11c");
$n->del_all_cookie();
print_r($_COOKIE);
*/

?>