无为清净楼资源网 Design By www.qnjia.com
smtp.class.php
复制代码 代码如下:
<?php  

define('SMTP_STATUS_NOT_CONNECTED', 1, TRUE); 
define('SMTP_STATUS_CONNECTED', 2, TRUE); 

class smtp 


var $connection; 
var $recipients; 
var $headers; 
var $timeout; 
var $errors; 
var $status; 
var $body; 
var $from; 
var $host; 
var $port; 
var $helo; 
var $auth; 
var $user; 
var $pass; 
var $debug; 

/** 
* 参数为一个数组 
* host SMTP 服务器的主机 默认:localhost 
* port SMTP 服务器的端口 默认:25 
* helo 发送HELO命令的名称 默认:localhost 
* user SMTP 服务器的用户名 默认:空值 
* pass SMTP 服务器的登陆密码 默认:空值 
* timeout 连接超时的时间 默认:5 
* @return bool 
*/ 

function smtp($params = array()) 


if(!defined('CRLF')) define('CRLF', “\r\n”, TRUE); 

$this->timeout = 5; 
$this->status = SMTP_STATUS_NOT_CONNECTED; 
$this->host = ‘localhost'; 
$this->port = 25; 
$this->auth = FALSE; 
$this->user = ”; 
$this->pass = ”; 
$this->errors = array(); 
$this->debug = false; 
foreach($params as $key => $value) 

$this->$key = $value; 


$this->helo = $this->host; 

// 如果没有设置用户名则不验证 
$this->auth = (” == $this->user) ? FALSE : TRUE; 


function connect($params = array()) 


if(!isset($this->status)) 

$obj = new smtp($params); 

if($obj->connect()) 

$obj->status = SMTP_STATUS_CONNECTED; 


return $obj; 


else 


$this->connection = fsockopen($this->host, $this->port, $errno, $errstr, $this->timeout); 
socket_set_timeout($this->connection, 0, 250000); 

$greeting = $this->get_data(); 

if(is_resource($this->connection)) 

$this->status = 2; 
return $this->auth ? $this->ehlo() : $this->helo(); 

else 

$this->errors[] = ‘Failed to connect to server: ‘.$errstr; 
return FALSE; 




/** 
* 参数为数组 
* recipients 接收人的数组 
* from 发件人的地址,也将作为回复地址 
* headers 头部信息的数组 
* body 邮件的主体 
*/ 

function send($params = array()) 


foreach($params as $key => $value) 

$this->set($key, $value); 


if($this->is_connected()) 

// 服务器是否需要验证 
if($this->auth) 

if(!$this->auth()) return FALSE; 


$this->mail($this->from); 

if(is_array($this->recipients)) 

foreach($this->recipients as $value) 

$this->rcpt($value); 


else 

$this->rcpt($this->recipients); 


if(!$this->data()) return FALSE; 

$headers = str_replace(CRLF.'.', CRLF.'..', trim(implode(CRLF, $this->headers))); 
$body = str_replace(CRLF.'.', CRLF.'..', $this->body); 
$body = $body[0] == ‘.' ? ‘.'.$body : $body; 

$this->send_data($headers); 
$this->send_data(”); 
$this->send_data($body); 
$this->send_data('.'); 

return (substr(trim($this->get_data()), 0, 3) === ‘250′); 

else 

$this->errors[] = ‘Not connected!'; 
return FALSE; 



function helo() 

if(is_resource($this->connection) 
AND $this->send_data('HELO ‘.$this->helo) 
AND substr(trim($error = $this->get_data()), 0, 3) === ‘250′ ) 

return TRUE; 


else 

$this->errors[] = ‘HELO command failed, output: ‘ . trim(substr(trim($error),3)); 
return FALSE; 



function ehlo() 

if(is_resource($this->connection) 
AND $this->send_data('EHLO ‘.$this->helo) 
AND substr(trim($error = $this->get_data()), 0, 3) === ‘250′ ) 

return TRUE; 

else 

$this->errors[] = ‘EHLO command failed, output: ‘ . trim(substr(trim($error),3)); 
return FALSE; 



function auth() 

if(is_resource($this->connection) 
AND $this->send_data('AUTH LOGIN') 
AND substr(trim($error = $this->get_data()), 0, 3) === ‘334′ 
AND $this->send_data(base64_encode($this->user)) // Send username 
AND substr(trim($error = $this->get_data()),0,3) === ‘334′ 
AND $this->send_data(base64_encode($this->pass)) // Send password 
AND substr(trim($error = $this->get_data()),0,3) === ‘235′ ) 

return TRUE; 

else 

$this->errors[] = ‘AUTH command failed: ‘ . trim(substr(trim($error),3)); 
return FALSE; 



function mail($from) 


if($this->is_connected() 
AND $this->send_data('MAIL FROM:<'.$from.'>') 
AND substr(trim($this->get_data()), 0, 2) === ‘250′ ) 

return TRUE; 

else 

return FALSE; 



function rcpt($to) 

if($this->is_connected() 
AND $this->send_data('RCPT TO:<'.$to.'>') 
AND substr(trim($error = $this->get_data()), 0, 2) === ‘25′ ) 

return TRUE; 

else 

$this->errors[] = trim(substr(trim($error), 3)); 
return FALSE; 



function data() 


if($this->is_connected() 
AND $this->send_data('DATA') 
AND substr(trim($error = $this->get_data()), 0, 3) === ‘354′ ) 

return TRUE; 

else 

$this->errors[] = trim(substr(trim($error), 3)); 
return FALSE; 



function is_connected() 

return (is_resource($this->connection) AND ($this->status === SMTP_STATUS_CONNECTED)); 


function send_data($data) 

if(is_resource($this->connection)) 

if($this->debug) 
echo nl2br($data.CRLF); 
return fwrite($this->connection, $data.CRLF, strlen($data)+2); 

else 

return FALSE; 



function &get_data() 


$return = ”; 
$line = ”; 

if(is_resource($this->connection)) 

while(strpos($return, CRLF) === FALSE OR substr($line,3,1) !== ‘ ‘) 

$line = fgets($this->connection, 512); 
$return .= $line; 

if($this->debug===true) 
echo nl2br($return.CRLF); 
return $return; 


else 

return FALSE; 



function set($var, $value) 

$this->$var = $value; 
return TRUE; 

} // End of class 
?> 

标签:
php,a,simple,smtp,class

无为清净楼资源网 Design By www.qnjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无为清净楼资源网 Design By www.qnjia.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。