首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

PEAR:常用模块(4)

PEAR:常用模块(4)

7.Mail/RFC822检查一个输入的email是否合法,不是一件很轻松的事情,你也许尝试使用一些规则表达式来检查,但是并非那么方便有效。现在,如果要检查一系列的邮件地址是否符合RFC822标准,并把它们拆分成单独的email地址,你可以试试这个模块,非常简单实用。
使用方法:         Mail_RFC822($address = null, $default_domain =null, $nest_groups = null, $validate = null)
类构造函数,$address是你要验证的一系列的地址,$default_domain,指定缺省的域名或者主机名,$nest_groups是否在输出结果中进行分组,以便显示$validate是否需要验证每个原子parseAddressList($address = null,$default_domain = null, $nest_groups = null, $validate =null)分析验证所给定的地址列表,如果地址有效,返回拆分后的单独的地址列表,如果发生错误,则返回错误信息。
<?php    require_once "Mail/RFC822.php";    $rf822 = new Mail_RFC822;    $result=$rf822->paseAddressList('who;whoim@hotmail.com;test@test.ch');    if ( $rf822->error ){        echo "Errorresult";    }else {        reset($result);        for ($i=0; $i< count($result);$i++){            echo "emailresult[$i]\n";        }    }?>8.Mail/Sendmailsendmail是unix/linux上面最常用的MTA,这个模块可以让你直接使用sendmail来发送信件
使用方法:         Mail_sendmail($params)
类构造函数,$params是一个关联数组,你可以设定sendmail的参数,目前只有'sendmail_path'是有效的,用来设置sendmail的路径send($recipients, $headers, $body)发送信件,$recipients是你的收件人的email地址,可以是单个,也可以是用;隔开的地址列表,只要符合RFC82标准就可以。$headers是你发送信件的信头,这是一个关联数租,数组的关键字是信头的名字(如Subject),数组值则是信头的值(比如:Hello!)。处理后的信头将会是:Subject:Hello!$body是信件的信体,包括所有的MIME编码后的部分。如果成功,返回真,否则返回一个PEAR_Error对象
<?php    require_once "Mail/sendmail.php";    $sendmail = new Mail_sendmail(array('sendmail_path=>'/usr/local/bin/sendmail'));    $header   = array('Subject'=>'Hello','BCC'=>'test2@hotmail.com');    $body     = 'This is a test message from nightsailer.com';    $result = $sendmail->send('test@nightsailer.com', $header, $body);    if ( PEAR::isError($result) ){        echo "<h1> 发送失败 </h1><br>原因:".$result->getMessage()."<br>";    }else {        echo "<h1>恭喜!发送成功!</h1><br>";    }?>9.Mail/smtp对于现在有些站点不允许使用sendmail,那么如果你的php程序希望使用发信功能,就需要能够通过使用外部的smtp服务器来完成相应的功能了。
使用方法:使用上这个模块和Mail::sendmail基本上是一样的。需要注意的是:这个模块需要使用Net::SMTP模块:Mail_smtp($params)        
$params的有效参数是:        
'host' smtp的服务器地址,缺省是 localhost        
'port' smtp服务端口,缺省是25        
'auth' smtp是否需要授权验证,缺省是false        
'usename' smtp授权的用户名        
'password' smtp授权的密码      
send($recipients, $headers, $body)        
发送      
<?php    require_once "Mail/sendmail.php";    $params=array('host'=>'smtp.nightsailer.com','auth'=true,              'username'=>'night','password'=>'123456');    $sendmail = new Mail_sendmail($params);    $header   = array('Subject'=>'Hello','BCC'=>'test2@hotmail.com');    $body     = 'This is a test message from nightsailer.com';    $result = $sendmail->send('test@nightsailer.com', $header, $body);    if ( PEAR::isError($result) ){        echo "<h1> 发送失败 </h1><br>原因:".$result->getMessage()."<br>";    }else {        echo "<h1>恭喜!发送成功!</h1><br>";    }?>10.Schedule/At这个模块提供了unix上面的at程序的接口
add($cmd, $timespec, $queue = false, $mail = false )追加一个at命令
这个方法将为at程序生成一个定制的作业:        
$cmd 是你要运行的程序或脚本        
$timespec 是作业开始执行的时间,格式与at要求的相同        
$queue 可选参数,指明作业的队列名        
$mail 可选参数,指明是否在作业结束后要发送email汇报运行结果      
show($queue = false)        
显示在at队列中的命令,返回一个关联数组,数组的key是作业的编号,相应的键值也是一个关联数组,内容是array(runtime,queue)$queue是一个可选参数,你可以用它限定只返回队列中队列名匹配$queue的作业列表      
remove($job = false)        
从at队列中删除指定的at作业$job是要删除的作业编号,如果,成功,返回true,否则返回false      
<?php    require_once "Schedule/At.php";    $at = new Schedule_At();    //生成并追加一个作业    $result = $at->add ('find / -type file -name core -exec rm -f {} \;','00:00');    if ( PEAR::is_Error($result) ) {        echo "无法追加作业!\n";        echo "原因:$result->getMessage() \n";        exit;    }    //显示当前at队列    $queue = $at->show();    if ( PEAR::isError($queue) ) {        echo "发生错误!\n";        echo "原因:" . queue->getMessage(). "\n";        exit;    }    reset( $queue );    while ( list($job, $cmd) = each $queue ){        echo "[$job]" . $cmd['runtime'] . "-" .$cmd['queue'];        echo "\n"    }?>以上是一些PEAR模块的使用,更为详细的说明需要你自己去察看这些模块的源文件,或者你可以使用phpdoc自动生成这些模块的api文档。关于phpdoc,我们将在下篇详细讨论。
返回列表