Archive for 十月, 2008

mysql字段类型说明与用途(转)

Posted in 数据库相关 on 十月 16th, 2008 by admin – Be the first to comment
数据类型 描述 字节 推荐使用
SMALLINT 整数,从-32000到 +32000范围 2 存储相对比较小的整数。
比如: 年纪,数量
INT 整数,从-2000000000 到 +2000000000 范围 4 存储中等整数
例如: 距离
BIGINT 不能用SMALLINT 或 INT描述的超大整数。 8 存储超大的整数
例如: 科学/数学数据
FLOAT 单精度浮点型数据 4 存储小数数据
例如:测量,温度
DOUBLE 双精度浮点型数据 8 需要双精度存储的小数数据
例如:科学数据
DECIMAL 用户自定义精度的浮点型数据 变量;取决于精度与长度 以特别高的精度存储小数数据。
例如:货币数额,科学数据
CHAR 固定长度的字符串 特定字符串长度(高达255字符) 存储通常包含预定义字符串的变量
例如: 定期航线,国家或邮编
VARCHAR 具有最大限制的可变长度的字符串 变量; 1 + 实际字符串长度 (高达 255 字符) 存储不同长度的字符串值(高达一个特定的最大限度).
例如:名字,密码,短文标签
TEXT 没有最大长度限制的可变长度的字符串 Variable; 2 +聽 actual string length 存储大型文本数据
例如: 新闻故事,产品描述
BLOB 二进制字符串 变量;2 + 实际字符串长度 存储二进制数据
例如:图片,附件,二进制文档
DATE 以 yyyy-mm-dd格式的日期 3 存储日期
例如:生日,产品满期
TIME 以 hh:mm:ss格式的时间 3 存储时间或时间间隔
例如:报警声,两时间之间的间隔,任务开始/结束时间
DATETIME 以yyyy-mm-ddhh:mm:ss格式结合日期和时间 8 存储包含日期和时间的数据
例如:提醒的人,事件
TIMESTAMP 以yyyy-mm-ddhh:mm:ss格式结合日期和时间 4 记录即时时间
例如:事件提醒器,“最后进入”的时间标记
YEAR 以 yyyy格式的年份 1 存储年份
例如:毕业年,出生年
ENUM 一组数据,用户可从中选择其中一个 1或 2个字节 存储字符属性,只能从中选择之一
例如:布尔量选择,如性别
SET 一组数据,用户可从中选择其中0,1或更多。 从1到8字节;取决于设置的大小 存储字符属性,可从中选择多个字符的联合。
例如:多选项选择,比如业余爱好和兴趣。

javascript异常处理实例

Posted in 前端技术 on 十月 14th, 2008 by admin – Be the first to comment

以前一直不知道如何使用异常处理。今天在处理一个项目时用到,于是看了一下手册,写了一个简单示例.

<div id=”a”>abc</div>
<script>
  try {
   var x = document.getElementById(“ab”); 
   alert(x.innerHTML) //这句会出错,因为没有找到 ab这个ID
  }
  catch(e) {
   alert(“出错:”+e.description); //显示出错的原因
  }
</script>

其实很简单,汗!

让ul与li水平居中,常用于页面居中导航

Posted in 前端技术 on 十月 14th, 2008 by admin – Be the first to comment

<html xmlns=”http://www.w3.org/1999/xhtml“>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″ />
<title>无标题文档-SH!</title>
<style>
ul,li{
margin:0;
padding:0;
list-style:none;
}
#area{
width:100%;
height:80px;
background-color:#eee;
text-align:center;
overflow:hidden;
}
#area ul{
float:left;
position:relative;
left:50%;
}
#area ul li{
float:left;
margin:10px;
padding:0 10px;
position:relative;
right:50%;
line-height:60px;
border:solid 1px #000;
}
</style>
</head>
<body>
<h1>跨浏览器实现float:center</h1>
<div id=”area”>
<ul >
<li>列表一,我是浮动的</li>
<li>列表二</li>
<li>列表三</li>
<li>这里可能是N</li>
</ul>
</div>
</body>
</html>

php加密cookie[原创]

Posted in 后端技术 on 十月 13th, 2008 by admin – Be the first to comment

我们知道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);
*/

?>

第一次使用WP

Posted in 前端技术 on 十月 12th, 2008 by admin – Be the first to comment

发一贴试一下.