2005年11月07日

http://pear.php.net/package/Mail_IMAPv2
http://pear.php.net/package/Mail_IMAP
http://cn2.php.net/imap

发表于 2005-10-29 01:48
  第一句话是:优秀是一种习惯。
  这句话是古希腊哲学家亚里士多德说的。如果说优秀是一种习惯,那么懒惰也是一种习惯。人出生的时候,除了脾气会因为天性而有所不同,其他的东西基本都是后天形成的,是家庭影响和教育的结果。所以,我们的一言一行都是日积月累养成的习惯。我们有的人形成了很好的习惯,有的人形成了很坏的习惯。所以我们从现在起就要把优秀变成一种习惯,使我们的优秀行为习以为常,变成我们的第二天性。让我们习惯性地去创造性思考,习惯性地去认真做事情,习惯性地对别人友好,习惯性地欣赏大自然。
  (注解:要会"装",要持续的、不间断的"装",装久了就成了真的了,就成了习惯了,比如准时到会,每次都按时到会,你装装看,你装30年看看,装的时间长了就形成了习惯。:) 
  
  第二句话是:生命是一种过程.
  事情的结果尽管重要,但是做事情的过程更加重要,因为结果好了我们会更加快乐,但过程使我们的生命充实。   人的生命最后的结果一定是死亡,我们不能因此说我们的生命没有意义。世界上很少有永恒。大学生谈恋爱,每天都在信誓旦旦地说我会爱你一辈子,这实际上是不真实的。统计数据表明,大学生谈恋爱的100对里有90对最后会分手,最后结婚了的还有一半会离婚。你说爱情能永恒吗?所以最真实的说法是:"我今天,此时此刻正在真心地爱着你。"明天也许你会失恋,失恋后我们会体验到失恋的痛苦。这种体验也是丰富你生命的一个过程。  
  注解:生命本身其实是没有任何意义的,只是你自己赋予你的生命一种你希望实现的意义,因此享受生命的过程就是一种意义所在。  
 
  第三句话是:两点之间最短的距离并不一定是直线。
  在人与人的关系以及做事情的过程中,我们很难直截了当就把事情做好。我们有时需要等待,有时需要合作,有时需要技巧。我们做事情会碰到很多困难和障碍,有时候我们并不一定要硬挺、硬冲,我们可以选择有困难绕过去,有障碍绕过去,也许这样做事情更加顺利。大家想一想,我们和别人说话还得想想哪句话更好听呢。尤其在中国这个比较复杂的社会中,大家要学会想办法谅解别人,要让人觉得你这个人很成熟,很不错,你才能把事情做好。  
  注解:如果你在考数学试题,一定要答两点之间直线段最短,如果你在走路,从A到B,明明可以直接过去,但所以人都不走,你最好别走,因为有陷阱。在中国办事情,直线性思维在很多地方要碰壁,这是中国特色的中国处事智慧。  
 
  第四句话是:只有知道如何停止的人才知道如何加快速度.
  我在滑雪的时候,最大的体会就是停不下来。我刚开始学滑雪时没有请教练,看着别人滑雪,觉得很容易,不就是从山顶滑到山下吗?于是我穿上滑雪板,哧溜一下就滑下去了,结果我从山顶滑到山下,实际上是滚到山下,摔了很多个跟斗。我发现根本就不知道怎么停止、怎么保持平衡。最后我反复练习怎么在雪地上、斜坡上停下来。练了一个星期,我终于学会了在任何坡上停止、滑行、再停止。这个时候我就发现自己会滑雪了,就敢从山顶高速地往山坡下冲。因为我知道只要我想停,一转身就能停下来。只要你能停下来,你就不会撞上树、撞上石头、撞上人,你就不会被撞死。因此,只有知道如何停止的人,才知道如何高速前进。
  注解:用汽车来比喻,宝马可以上200公里,奇瑞却只能上120公里,为什么?发动机估计不相上下,差距在刹车系统,上了200公里刹不了车,呵呵,我的天!  
 
  第五句话是:放弃是一种智慧,缺陷是一种恩惠。
  当你拥有六个苹果的时候,千万不要把它们都吃掉,因为你把六个苹果全都吃掉,你也只吃到了六个苹果,只吃到了一种味道,那就是苹果的味道。如果你把六个苹果中的五个拿出来给别人吃,尽管表面上你丢了五个苹果,但实际上你却得到了其他五个人的友情和好感。以后你还能得到更多,当别人有了别的水果的时候,也一定会和你分享,你会从这个人手里得到一个橘子,那个人手里得到一个梨,最后你可能就得到了六种不同的水果,六种不同的味道,六种不同的颜色,六个人的友谊。人一定要学会用你拥有的东西去换取对你来说更加重要和丰富的东西。所以说,放弃是一种智慧。
  注解:每一次放弃都必须是一次升华,否则就不要放弃;每一次选择都必须是一次升华,否则不要选择。

  做人最大的乐趣在于通过奋斗去获得我们想要的东西,所以有缺点意味着我们可以进一步完美,有匮乏之处意味着我们可以进一步努力。美国有一部电视片,讲的是一位富翁给后代留下了用不尽的遗产,结果他的后代全都变成了吸毒的、自杀的、进监狱的,或者精神病患者。为什么会这样呢?因为这位富翁给自己后代留下的钱太多了,以致他们不需要劳动就可以继承一大笔财产。继承一大笔财富,就几乎什么都能买到。所以,当一个人什么都不缺的时候,他的生存空间就被剥夺掉了。如果我们每天早上醒过来,感到自己今天缺点儿什么,感到自己还需要更加完美,感到自己还有追求,那是一件多么值得高兴的事情啊!
发表于 2005-10-29 01:39
  [前言:]在我们编写WEB程序时,经常会判断一个字符串的有效性,如;一个串是否是数字、是否是有效的Email地址等等。如果不使用正则表达式,那么判断的程序会很长,并且容易出错,如果使用正则表达式,这些判断就是一件很轻松的工作了。本文全面介绍正则表达式的慨念、格式。并以在PHP、ASP中的应用实例增加读者的感性认识。正则表达式的应用很广,需要大家在学习和实践中不断的总结。

  正则表达式简介 

  简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。在网络编程中应用广泛,如PHP脚本语言或是JavaScript、 VBScript这样的客户端脚本语言都提供了对正则表达式的支持。由此可见,正则表达式已经超出了某种语言或某个系统的局限,成为人们广为接受的概念和功能。 

  正则表达式可以让用户通过使用一系列的特殊字符构建匹配模式,然后把匹配模式与数据文件、程序输入以及WEB页面的表单输入等目标对象进行比较,根据比较对象中是否包含匹配模式,执行相应的程序。 

  举例来说,正则表达式的一个最为普遍的应用就是用于验证用户在线输入的邮件地址的格式是否正确,如果通过正则表达式验证用户邮件地址的格式正确,用户所填写的表单信息将会被正常处理;反之,如果用户输入的邮件地址与正则表达的模式不匹配,将会弹出提示信息,要求用户重新输入正确的邮件地址。由此可见正则表达式在WEB应用的逻辑判断中具有举足轻重的作用。在后面我们会举例详细介绍。 

  正则表达式形式一般如:/love/,其中位于 "/"定界符之间的部分就是将要在目标对象中进行匹配的模式。用户只要把希望查找匹配对象的模式内容放入"/"定界符之间即可。为了能够使用户更加灵活的定制模式内容,正则表达式提供了专门的"元字符"。所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符)在目标对象中的出现模式。较为常用的元字符包括: "+,"*,?以及{}",或者"\s,\S,\d,\w和\W"等等。为了能够方便用户更加灵活的设定匹配模式,正则表达式允许使用者在匹配模式中利用[]界定匹配于某一个范围的字符而不局限于具体的字符。 

  除了我们以上的元字符之外,正则表达式中还具有另外一种较为独特的专用字符,即定位符。定位符用于规定匹配模式在目标对象中的出现位置。较为常用的定位符包括: "^", "$", "\b" 以及 "\B"。 

  如果我们希望在正则表达式中实现类似编程逻辑中的"或"运算,在多个不同的模式中任选一个进行匹配的话,可以使用管道符 "|"。例如: 

  正则表达式中还有一个较为常用的运算符,即否定符 "[^]"。与我们前文所提到的定位符 "^" 不同,否定符 "[^]"规定目标对象中不能存在模式中所规定的字符串。一般来说,当"^"出现在 "[]"内时就被视做否定运算符;而当"^"位于"[]"之外,或没有"[]"时,则应当被视做定位符。  

  最后,当用户需要在正则表达式的模式中加入元字符,并查找其匹配对象时,可以使用转义符"\"。例如:/Th\*/,该正则表达式将会与目标对象中的"Th*"而非"The"等相匹配。 

  正则表达式的语法规则和标记

  现在我们正式进入则表达式的学习,我会根据实例结合讲解正则表达式的用法,看完后你就会觉得写UBB代码如此简单了,只要你一步一步的跟着我学 看完本文章后你就成为UBB高手了。激动人心的就是你能写出自已的UBB标签来了,再也不用到别人那里去拷贝现成的代码和模板了。 还好VBScritp5.0 给我们提供了"正则表达式"对象,只要你的服务器安装了IE5.x,就可以运行了.

  字符描述:

     ^符号匹配字符串的开头。例如:

    ^abc 与"abc xyz"匹配,而不与"xyz abc"匹配

  $符号匹配字符串的结尾。例如:

    abc$ 与"xyz abc"匹配,而不与"abc xyz"匹配。

    注意:如果同时使用^符号和$符号,将进行精确匹配。例如:

       ^abc$ 只与"abc"匹配   

  *符号匹配0个或多个前面的字符。例如:

    ab* 可以匹配"ab"、"abb"、"abbb"等

  +符号匹配至少一个前面的字符。例如:

    ab+ 可以匹配"abb"、"abbb"等,但不匹配"ab"。 

  ?符号匹配0个或1个前面的字符。例如:

    ab?c? 可以且只能匹配"abc"、"abbc"、"abcc"和"abbcc"

  .符号匹配除换行符以外的任何字符。例如:

    (.)+ 匹配除换行符以外的所有字符串

  x|y匹配"x"或"y"。例如:

    abc|xyz 可匹配 "abc"或 "xyz",而"ab(c|x)yz"匹配 "abcyz"和"abxyz"

  {n}匹配恰好n次(n为非负整数)前面的字符。例如:

    a{2} 可以匹配"aa",但不匹配"a"

  {n,}匹配至少n次(n为非负整数)前面的字符。例如:

    a{3,} 匹配"aaa"、"aaaa"等,但不匹配"a"和"aa"。

    注意:a{1,}等价于a+

       a{0,}等价于a*

  {m,n}匹配至少m个,至多n个前面的字符。例如:

    a{1,3} 只匹配"a"、"aa"和"aaa"。

    注意:a{0,1}等价于a?

  [xyz]表示一个字符集,匹配括号中字符的其中之一。例如:

    [abc] 匹配"a"、"b"和"c"

  [^xyz]表示一个否定的字符集。匹配不在此括号中的任何字符。例如:

    [^abc] 可以匹配除"a"、"b"和"c"之外的任何字符

  [a-z]表示某个范围内的字符,匹配指定区间内的任何字符。例如:

    [a-z] 匹配从"a"到"z"之间的任何一个小写字母字符

  [^m-n]表示某个范围之外的字符,匹配不在指定范围内的字符。例如:

    [m-n] 匹配除从"m"到"n"之间的任何字符

  \符号是转义操作符。例如:

    \n 换行符

    \f 分页符

    \r 回车

    \t 制表符

    \v 垂直制表符 

    \\ 匹配"\"

    \/ 匹配"/"

    \s 任何白字符,包括空格、制表符、分页符等。等价于"[ \f\n\r\t\v]"

    \S 任何非空白的字符。等价于"^\f\n\r\t\v]"

    \w 任何单词字符,包括字母和下划线。等价于"[A-Za-z0-9_]"

    \W 任何非单词字符。等价于"[^A-Za-z0-9_]"

    \b匹配单词的结尾。例如:

      ve\b 匹配单词"love"等,但不匹配"very"、"even"等

    \B匹配单词的开头。例如:

      ve\B 匹配单词"very"等,但不匹配"love"等

    \d匹配一个数字字符,等价于[0-9]。例如:

      abc\dxyz 匹配"abc2xyz"、"abc4xyz"等,
      但不匹配"abcaxyz"、"abc-xyz"等

    \D匹配一个非数字字符,等价于[^0-9]。例如:

      abc\Dxyz 匹配"abcaxyz"、"abc-xyz"等,
      但不匹配"abc2xyz"、"abc4xyz"等

    \NUM匹配NUM个(其中NUM为一个正整数),引用回到记住的匹配。例如:

      (.)\1 匹配两个连续相同的字符。 

    \oNUM匹配n(其中n为一个小于256的八进制换码值)。例如:

      \o011 匹配制表符

    \xNUM匹配NUM(其中NUM为一个小于256的十六进制换码值)。例如:

      \x41 匹配字符"A"

 
  应用实例 

  在对正则表达式有了较为全面的了解之后,就可以在Perl,PHP,以及ASP等程式中使用正则表达式了。

  下面以PHP语言为例,使用验证用户在线输入的邮件地址以及网址的格式是否正确。PHP 提供了eregi()或ereg()资料处理函数实现字串比对剖析的模式匹配操作ereg()函数的使用格式如下: 

      ereg (pattern, string) 

  其中,pattern代表正则表达式的模式;而string则是执行查找替换操作的目标对象,如Email地址值。本函式以 pattern 的规则来剖析比对字串 string,找到则传回值为 true。函式ereg()与eregi()的区别就是前者区分大小写,后者与大小写无关。使用PHP编写的程序代码如下: 

     <?php 
   if (ereg("^([a-z0-9_-])+@([a-zZ0-9_-])+(\.[a-z0-9_-])+[a-z]{2,3}$",$email)) 
   { echo "您的 E-Mail 通过初步检查!";} 
   else 
   { echo "不是合法的E-Mail 地址,请重新输入!";} 
   ?> 
 

  这个例子是可对使用者输入的 E-Mail 作简单的检查,检查使用者的 E-Mail 字串是否有 @ 字元,在 @ 字元前有小写英文字母、数字或下"_",在 @ 之后有数节字串,最后的小数点后只能有二个或三个小写英文字母。如webmaster@mail.sever.net,  hello_2001@88new.cn就可以通过检查,而New99@253.com(出现大写字母)和new99@253.comn(最后的小数点后只能超过3个英文字母)就不能通过检查。 

  我们通过调用自定义正规则判别函式也可以进行检查操作,如下面的网址检验函式: 

function VerifyWebSiteAddr ($strWebSiteAddr){ 
return (eregi ("^([_0-9a-z-]+.)+([0-9a-z-]+.)+[a-z]{2,3}$", $strWebSiteAddr)); 

  我们知道,PHP程式的运行必须有服务器支持,如果您在自己的主页上想实现以上功能, 嵌入式脚本语言Javascript或许是好的选择。 JavaScript中带有一个功能强大的RegExp()对象,可以用来进行正则表达式的匹配操作。其中的test()方法可以检验目标对象中是否包含匹配模式,并相应的返回true或false。只须在HTML文档的<head>区域添加一段Javascript代码。 

< language="Javascript1.2"> 
  function verifyAddress(obj){ 
   var email = obj.email.value; 
   var pattern = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/; 
   flag = pattern.test(email); 
   if(flag){ 
    alert("您的 E-Mail 通过初步检查!"); 
    return true;} 
   else{ 
    alert("不是合法的E-Mail 地址,请重新输入!"); 
    return false;} 
  } 
 </script> 
 

  然后在网页中输入信息的表单域<form>标签区域内中加入一行如下代码: 

   <onSubmit="return verifyAddress(this);"> 

  当按下提交按钮后,首先运行verifyAddress()函式,进行匹配识别,如果满足条件则发送表单信息到目标页面,否则返回错误信息。

  本人对于新技术的接触总是慢半拍,从以前的电子邮件和QQ,别人都开始用的时候我还不怎么了解,而现在也听说RSS很火,可惜我也没用过。今天一个偶然的机会,我搜索了一下RSS并下载了新浪点点通阅读器,一下被RSS新颖、使用的功能给吸引了。

  因为我宿舍不能上网,只好单机玩。今晚我在玩我前几天下载的O-blog 2.5时,看到这个程序就有RSS功能嘛,于是我就装了新浪点点通阅读器,将O-blog假如频道,感觉不错!可是当我每次打开一篇文章时,都是打开的首页,原来是文章的链接错误,于是我看了一下xml代码(其实我也没学过xml),果然其中有个<link>http://localhost/……link> 这个地址是错误的,下面我就打开rss文件开始研究了,其实也不难嘛,我就下手改掉了错误。因为我很少写程序,所以代码写的很不规范,下面附上我的代码,请高手们指点、规范、完善以下。

1、首先在class\rss.php中加入GetExtra函数,获取静态文件扩展名,加在GetExtra()函数后即可。
//add some codes
function GetExtra()
{
 global $mysql_prefix;
 $sql = "SELECT `extraname` FROM `".$mysql_prefix."config`";
 $result = mysql_query($sql);
 $re = mysql_fetch_array($result);
 return $re[0];
}//
最后一行加入
//add some codes
$extraname  = GetExtra();

2、以程序目录下rss2.php为例修改,在$a[5] = $blog[$i]['content']一行后面加入部分代码。
//add some codes
if ($blog[$i]['filename'] == "")
    $filename = $a[1].".".$extraname;
else 
    $filename = $blog[$i]['filename'].".".$extraname;

$date_array = getdate ($blog[$i]['date']);
$filepath = "/archives/".$date_array['year']."/".$date_array['mon']."/".$date_array['mday']."/".$filename;

  现在保存文件,到新浪点点通验证,success!

发表于 2005-10-30

1、首先在class\rss.php中加入GetExtra函数,获取静态文件扩展名,加在GetExtra()函数后即可。
//add some codes
function GetExtra()
{
 global $mysql_prefix;
 $sql = "SELECT `extraname` FROM `".$mysql_prefix."config`";
 $result = mysql_query($sql);
 $re = mysql_fetch_array($result);
 return $re[0];
}//
最后一行加入
//add some codes
$extraname  = GetExtra();

2、以程序目录下rss2.php为例修改,在$a[5] = $blog[$i]['content']一行后面加入部分代码。
//add some codes
if ($blog[$i]['filename'] == "")
    $filename = $a[1].".".$extraname;
else 
    $filename = $blog[$i]['filename'].".".$extraname;

$date_array = getdate ($blog[$i]['date']);
$filepath = "/archives/".$date_array['year']."/".$date_array['mon']."/".$date_array['mday']."/".$filename;

  现在保存文件,到新浪点点通验证,success!

发表于 2005-10-30 link> 这个地址是错误的,下面我就打开rss文件开始研究了,其实也不难嘛,我就下手改掉了错误。因为我很少写程序,所以代码写的很不规范,下面附上我的代码,请高手们指点、规范、完善以下。

1、首先在class\rss.php中加入GetExtra函数,获取静态文件扩展名,加在GetExtra()函数后即可。
//add some codes
function GetExtra()
{
 global $mysql_prefix;
 $sql = "SELECT `extraname` FROM `".$mysql_prefix."config`";
 $result = mysql_query($sql);
 $re = mysql_fetch_array($result);
 return $re[0];
}//
最后一行加入
//add some codes
$extraname  = GetExtra();

2、以程序目录下rss2.php为例修改,在$a[5] = $blog[$i]['content']一行后面加入部分代码。
//add some codes
if ($blog[$i]['filename'] == "")
    $filename = $a[1].".".$extraname;
else 
    $filename = $blog[$i]['filename'].".".$extraname;

$date_array = getdate ($blog[$i]['date']);
$filepath = "/archives/".$date_array['year']."/".$date_array['mon']."/".$date_array['mday']."/".$filename;

  现在保存文件,到新浪点点通验证,success!

发表于 2005-10-30

写字楼里写字间,写字间里程序员;
程序人员写程序,又拿程序换酒钱。
酒醒只在网上坐,酒醉还来网下眠;
酒醉酒醒日复日,网上网下年复年。
但愿老死电脑间,不愿鞠躬老板前;
奔驰宝马贵者趣,公交自行程序员。
别人笑我忒疯癫,我笑自己命太贱;
不见满街漂亮妹,哪个归得程序员。

发表于 2005-10-29 22:31