若是本文圖片顯示不出來,請看個人博客 http://vb2005xu.iteye.com/blog/2114518 php
近日在對charsen的修改版上進行了再次的修改與調整,對原版的qee v3 作了更多的bug修改,目前通過測試基本可使用,雖然還有一些坑,可是代碼量始終只有那麼一點,填補起來應該很方便,加上qee-v3確實有些技術知識點可供學習..
因 爲 qee-v3 只給出了一些極簡單的庫支持,而郵件功能在項目開發過程當中又是不可或缺的部分,因此就集成了swiftmailer, 這個庫在國外的知名度蠻高的,在性能上比phpmailer要好很多,尤爲是對大附件的支持上.惟獨的缺陷就是中文文檔太少,爲了方便使用,故對其作了如 下封裝....
若是非要對這個封裝代碼起個名字,那就叫作 qser-mailer 吧
先給出一個如何使用的demo,我的感受仍是比較方便和簡單的 html
Php代碼
- <?php
-
- namespace qser\app\actions;
-
- use qeephp\mvc\BaseAction;
- use qeephp\Config;
-
- use qeephp\tools\Logger;
- use qeephp\storage\mysql\DataSource;
- use qeephp\storage\Meta;
-
- use qser\app\models\Post;
- use qser\libraries\Validator;
- use qser\libraries\PinyinLib;
-
- class IndexAction extends BaseAction
- {
-
- /**
- * @var mysql\DataSource
- */
- private $_ds;
- private $_handle;
-
- function execute()
- {
- try{
- $post5 = Post::find_one(5);
- }
- catch( \Exception $ex )
- {
- Logger::instance('test')->fatal($ex);
- }
- Logger::instance('test')->debug($post5);
-
- dump('indexAction',PinyinLib::topinyin("我愛北京天門"));
- ///dump($this->app);
-
- // $value = 7;
- // $result = Validator::validateBatch($value, array(array('is_int'),array('between', 2, 6)));
- // var_dump($result);
-
- $this->view(array('action' => 'a', __DIR__));
-
- <span style="color: #ff6600;"><strong>$email = array('vb@qq.com');
- $content = $this->result;
- $this->app->tool('mail')->mailer->send(function($message) use($email,$content)
- {
- $text = $content->execute();
- $message->to($email)->subject('qeev3 測試郵件');
- $message->setBody($text, 0 ? 'text/plain' : 'text/html');
- $message->attachData($text,'runtest',array('as' => $message->encodeAttachmentName('啥都好說')));
- $message->attach(MYAPP_SRC_PATH . '/tmp/tests.log',array('as' => $message->encodeAttachmentName('尼瑪')));
- });
- </strong></span>
- // dump($this->app->tool('mail')->mailer , $email);
- //
- //dump( $post5 );
-
- /*
- $sql = 'show tables';
- $result = $this->_ds->execute($sql);
- dump($result,$sql); // out resource
-
- $result = $this->_ds->find_one('post',null);
- dump($result,'post_one');
-
- $result = $this->_ds->find('post',null)->fetch();
- dump($result,'fetch');
-
- $result = $this->_ds->find('post',null)->sort('post_id DESC')->fetch();
- dump($result,'fetch by sort');
- */
-
- //$result = $this->_ds->find('post',null)->fetch_all();
- // dump($result,'fetch_all');
- //
- //$meta = new Meta('qser\\app\\models\\Revision');
-
- //$meta = array();
- // dump( $meta ,'meta');
-
- }
-
- protected function __before_execute()
- {
- // init resource
- // $this->_ds = new DataSource( Config::get('storage.domains.default') );
- // $this->_ds->connect();
- // $this->_ds->set_logger(Logger::instance('test'));
- // $this->_handle = $this->_ds->handle();
-
- // $this->_ds->execute('SET AUTOCOMMIT=0');
- // $this->_ds->execute('START TRANSACTION');
-
- // foreach (self::post_recordset() as $post)
- // {
- // $this->_ds->insert('qser_posts', $post);
- // }
-
- // $this->_ds->execute('COMMIT');
- // $this->_ds->execute('SET AUTOCOMMIT=1');
-
-
- return true;
- }
-
- // test func
-
- static function post_recordset($begin_post_id = 31)
- {
- static $authors = array('dualface', 'liaoyulei', 'lownr', 'dox', 'quietlife');
-
- $recordset = array();
- for ($post_id = $begin_post_id; $post_id < $begin_post_id + 10; $post_id++)
- {
- $author = $authors[mt_rand(0, count($authors) - 1)];
- $recordset[$post_id] = array(
- 'post_id' => $post_id,
- 'title' => 'post ' . $post_id,
- 'author' => $author,
- 'click_count' => mt_rand(1, 999),
- );
- }
- return $recordset;
- }
-
- static function revisions_recordset($begin_post_id = 1)
- {
- $recordset = array();
- $created = time();
- for ($post_id = $begin_post_id; $post_id < $begin_post_id + 5; $post_id++)
- {
- $num_rev = mt_rand(1, 5);
- for ($i = 0; $i < $num_rev; $i++)
- {
- $recordset[] = array(
- 'post_id' => $post_id,
- 'body' => sprintf('post %u rev %u', $post_id, $i),
- 'created' => $created,
- );
- }
- }
- return $recordset;
- }
- }
測試的結果蠻好,如圖所示,中文附件名字也能正常顯示,灰常給力是否是
------------------------------------------------------------
全部代碼以下所示: mysql
Php代碼
- <?php namespace qser\app\tools;
-
- use qeephp\mvc\App;
- use qser\libraries\Mail\Mailer;
-
- class MailTool
- {
- /**
- * 當前請求
- *
- * @var Mailer
- */
- public $mailer;
-
- /**
- * Create a new Mailer instance.
- *
- * @param App $app
- * @param array $config
- */
- public function __construct(App $app, array $config) {
- $this->mailer = new Mailer($config);
- }
-
- }
Php代碼
- <?php
-
- namespace qser\libraries\Mail;
-
- if (!defined('SWIFT_INIT_LOADED')) {
- require ROOT_PATH . '/packages/swiftmailer/lib/swift_init.php';
- }
-
- use Swift_Mailer;
- use Swift_Message;
- use qeephp\tools\Logger;
- use qser\libraries\Mail\Provider;
-
- class Mailer
- {
-
- /**
- * The Swift Mailer instance.
- *
- * @var \Swift_Mailer
- */
- protected $swift;
-
- /**
- * The global from address and name.
- *
- * @var array
- */
- protected $from;
-
- /**
- * The log writer instance.
- *
- * @var ILogger
- */
- protected $logger;
-
- /**
- * Indicates if the actual sending is disabled.
- *
- * @var bool
- */
- protected $pretending = false;
-
- /**
- * Array of failed recipients.
- *
- * @var array
- */
- protected $failedRecipients = array();
-
- /**
- * Create a new Mailer instance.
- *
- * @param array $config
- * @return void
- */
- public function __construct(array $config)
- {
- $this->swift = Provider::registerSwiftMailer($config);
-
- $logger = val($config, 'logger' , false);
- if ($logger)
- {
- $this->setLogger(Logger::instance($logger));
- }
-
- $from = val($config, 'from' , false);
-
- if (is_array($from) && isset($from['address']))
- {
- $this->alwaysFrom($from['address'], $from['name']);
- }
-
- // Here we will determine if the mailer should be in "pretend" mode for this
- // environment, which will simply write out e-mail to the logs instead of
- // sending it over the web, which is useful for local dev environments.
- $pretend = val($config, 'pretend' , false);
-
- $this->pretend($pretend);
- }
-
- /**
- * Set the global from address and name.
- *
- * @param string $address
- * @param string $name
- * @return void
- */
- public function alwaysFrom($address, $name = null)
- {
- $this->from = compact('address', 'name');
- }
-
- /**
- * Send a new message.
- *
- * @param callback $callback
- * @return int
- */
- public function send($callback)
- {
- $message = $this->createMessage();
- $data['message'] = $message;
-
- if ($callback && is_callable($callback))
- {
- call_user_func($callback,$message);
- }
- else
- {
- throw new \InvalidArgumentException('Invalid mail send callback.');
- }
-
- $message = $message->getSwiftMessage();
-
- return $this->sendSwiftMessage($message);
- }
-
- /**
- * Send a Swift Message instance.
- *
- * @param \Swift_Message $message
- * @return int
- */
- protected function sendSwiftMessage($message)
- {
- if ( !$this->pretending)
- {
- return $this->swift->send($message, $this->failedRecipients);
- }
- elseif (isset($this->logger))
- {
- $this->logMessage($message);
-
- return 1;
- }
- }
-
- /**
- * Log that a message was sent.
- *
- * @param \Swift_Message $message
- * @return void
- */
- protected function logMessage($message)
- {
- $emails = implode(', ', array_keys((array) $message->getTo()));
-
- $this->logger->info("Pretending to mail message to: {$emails}");
- }
-
- /**
- * Create a new message instance.
- *
- * @return Message
- */
- protected function createMessage()
- {
- $message = new Message(new Swift_Message);
-
- // If a global from address has been specified we will set it on every message
- // instances so the developer does not have to repeat themselves every time
- // they create a new message. We will just go ahead and push the address.
- if (isset($this->from['address']))
- {
- $message->from($this->from['address'], $this->from['name']);
- }
-
- return $message;
- }
-
- /**
- * Tell the mailer to not really send messages.
- *
- * @param bool $value
- * @return void
- */
- public function pretend($value = true)
- {
- $this->pretending = $value;
- }
-
- /**
- * Get the Swift Mailer instance.
- *
- * @return \Swift_Mailer
- */
- public function getSwiftMailer()
- {
- return $this->swift;
- }
-
- /**
- * Get the array of failed recipients.
- *
- * @return array
- */
- public function failures()
- {
- return $this->failedRecipients;
- }
-
- /**
- * Set the log writer instance.
- *
- * @param Logger $logger
- */
- public function setLogger(Logger $logger)
- {
- $this->logger = $logger;
- }
-
- }
Php代碼
- <?php namespace qser\libraries\Mail;
-
- use Swift_Image;
- use Swift_Attachment;
-
- class Message {
-
- /**
- * The Swift Message instance.
- *
- * @var \Swift_Message
- */
- protected $swift;
-
- /**
- * Create a new message instance.
- *
- * @param \Swift_Message $swift
- * @return void
- */
- public function __construct($swift)
- {
- $this->swift = $swift;
- }
-
- /**
- * Add a "from" address to the message.
- *
- * @param string $address
- * @param string $name
- * @return \qser\libraries\Mail\Message
- */
- public function from($address, $name = null)
- {
- $this->swift->setFrom($address, $name);
-
- return $this;
- }
-
- /**
- * Set the "sender" of the message.
- *
- * @param string $address
- * @param string $name
- * @return \qser\libraries\Mail\Message
- */
- public function sender($address, $name = null)
- {
- $this->swift->setSender($address, $name);
-
- return $this;
- }
-
- /**
- * Set the "return path" of the message.
- *
- * @param string $address
- * @return \qser\libraries\Mail\Message
- */
- public function returnPath($address)
- {
- $this->swift->setReturnPath($address);
-
- return $this;
- }
-
- /**
- * Add a recipient to the message.
- *
- * @param string|array $address
- * @param string $name
- * @return \qser\libraries\Mail\Message
- */
- public function to($address, $name = null)
- {
- return $this->addAddresses($address, $name, 'To');
- }
-
- /**
- * Add a carbon copy to the message.
- *
- * @param string $address
- * @param string $name
- * @return \qser\libraries\Mail\Message
- */
- public function cc($address, $name = null)
- {
- return $this->addAddresses($address, $name, 'Cc');
- }
-
- /**
- * Add a blind carbon copy to the message.
- *
- * @param string $address
- * @param string $name
- * @return \qser\libraries\Mail\Message
- */
- public function bcc($address, $name = null)
- {
- return $this->addAddresses($address, $name, 'Bcc');
- }
-
- /**
- * Add a reply to address to the message.
- *
- * @param string $address
- * @param string $name
- * @return \qser\libraries\Mail\Message
- */
- public function replyTo($address, $name = null)
- {
- return $this->addAddresses($address, $name, 'ReplyTo');
- }
-
- /**
- * Add a recipient to the message.
- *
- * @param string|array $address
- * @param string $name
- * @param string $type
- * @return \qser\libraries\Mail\Message
- */
- protected function addAddresses($address, $name, $type)
- {
- if (is_array($address))
- {
- $this->swift->{"set{$type}"}($address, $name);
- }
- else
- {
- $this->swift->{"add{$type}"}($address, $name);
- }
-
- return $this;
- }
-
- /**
- * Set the subject of the message.
- *
- * @param string $subject
- * @return \qser\libraries\Mail\Message
- */
- public function subject($subject)
- {
- $this->swift->setSubject($subject);
-
- return $this;
- }
-
- /**
- * Set the message priority level.
- *
- * @param int $level
- * @return \qser\libraries\Mail\Message
- */
- public function priority($level)
- {
- $this->swift->setPriority($level);
-
- return $this;
- }
-
- /**
- * 編碼附件名稱(可用於顯示中文附件名)
- *
- * @param string $file
- *
- * @return string
- */
- public function encodeAttachmentName($name)
- {
- return "=?UTF-8?B?" . base64_encode($name) . "?=";
- }
-
- /**
- * Attach a file to the message.
- *
- * @param string $file
- * @param array $options
- * @return \qser\libraries\Mail\Message
- */
- public function attach($file, array $options = array())
- {
- $attachment = $this->createAttachmentFromPath($file);
-
- return $this->prepAttachment($attachment, $options);
- }
-
- /**
- * Create a Swift Attachment instance.
- *
- * @param string $file
- * @return \Swift_Attachment
- */
- protected function createAttachmentFromPath($file)
- {
- return Swift_Attachment::fromPath($file);
- }
-
- /**
- * Attach in-memory data as an attachment.
- *
- * @param string $data
- * @param string $name
- * @param array $options
- * @return \qser\libraries\Mail\Message
- */
- public function attachData($data, $name, array $options = array())
- {
- $attachment = $this->createAttachmentFromData($data, $name);
-
- return $this->prepAttachment($attachment, $options);
- }
-
- /**
- * Create a Swift Attachment instance from data.
- *
- * @param string $data
- * @param string $name
- * @return \Swift_Attachment
- */
- protected function createAttachmentFromData($data, $name)
- {
- return Swift_Attachment::newInstance($data, $name);
- }
-
- /**
- * Embed a file in the message and get the CID.
- *
- * @param string $file
- * @return string
- */
- public function embed($file)
- {
- return $this->swift->embed(Swift_Image::fromPath($file));
- }
-
- /**
- * Embed in-memory data in the message and get the CID.
- *
- * @param string $data
- * @param string $name
- * @param string $contentType
- * @return string
- */
- public function embedData($data, $name, $contentType = null)
- {
- $image = Swift_Image::newInstance($data, $name, $contentType);
-
- return $this->swift->embed($image);
- }
-
- /**
- * Prepare and attach the given attachment.
- *
- * @param \Swift_Attachment $attachment
- * @param array $options
- * @return \qser\libraries\Mail\Message
- */
- protected function prepAttachment($attachment, $options = array())
- {
- // First we will check for a MIME type on the message, which instructs the
- // mail client on what type of attachment the file is so that it may be
- // downloaded correctly by the user. The MIME option is not required.
- if (isset($options['mime']))
- {
- $attachment->setContentType($options['mime']);
- }
-
- // If an alternative name was given as an option, we will set that on this
- // attachment so that it will be downloaded with the desired names from
- // the developer, otherwise the default file names will get assigned.
- if (isset($options['as']))
- {
- $attachment->setFilename($options['as']);
- }
-
- $this->swift->attach($attachment);
-
- return $this;
- }
-
- /**
- * Get the underlying Swift Message instance.
- *
- * @return \Swift_Message
- */
- public function getSwiftMessage()
- {
- return $this->swift;
- }
-
- /**
- * Dynamically pass missing methods to the Swift instance.
- *
- * @param string $method
- * @param array $parameters
- * @return mixed
- */
- public function __call($method, $parameters)
- {
- $callable = array($this->swift, $method);
-
- return call_user_func_array($callable, $parameters);
- }
-
- }
-------- 配置信息以下所示 web
寫道
# Tools 設置 'app.tools' => array( # mail 工具配置 'mail' => array( 'class' => 'qser\\app\\tools\\MailTool', 'driver' => 'smtp', #Supported: "smtp", "mail", "sendmail" 'host' => 'smtp.qq.com', 'port' => 4650, 'encryption' => 'ssl', 'username' => "noreply@sese.cn", 'password' =>"qwaszyss", 'pretend' => false,#啓用此選項,郵件不會真正發送,而是寫到日誌文件中 'logger' => 'test', #使用日誌對象 'from' => array('address' => 'noreply@sese.cn', 'name' => '易結網'), ), ),