《deetom》项目开发历程<五> PHP邮件
邮件类库是从github下载的
简单好用;
protected function sendEmail($emailAddress,$realname,$token,$title,$do){ include_once APP_ROOT . ‘doitphp/modules/phpmailer/PHPMailerAutoload.php‘; //示例化PHPMailer核心类 $mail = new PHPMailer(); //是否启用smtp的debug进行调试 开发环境建议开启 生产环境注释掉即可 默认关闭debug调试模式 //$mail->SMTPDebug = 1; //使用smtp鉴权方式发送邮件,当然你可以选择pop方式 sendmail方式等 本文不做详解 //可以参考http://phpmailer.github.io/PHPMailer/当中的详细介绍 $mail->isSMTP(); //smtp需要鉴权 这个必须是true $mail->SMTPAuth=true; //链接qq域名邮箱的服务器地址 $mail->Host = ‘smtp.qq.com‘; //设置使用ssl加密方式登录鉴权 $mail->SMTPSecure = ‘ssl‘; //设置ssl连接smtp服务器的远程服务器端口号 可选465或587 $mail->Port = 465; //设置smtp的helo消息头 这个可有可无 内容任意 $mail->Helo = ‘Hello smtp.qq.com Server‘; //设置发件人的主机域 可有可无 默认为localhost 内容任意,建议使用你的域名 $mail->Hostname = ‘csince.com‘; //设置发送的邮件的编码 可选GB2312 我喜欢utf-8 据说utf8在某些客户端收信下会乱码 $mail->CharSet = ‘UTF-8‘; //设置发件人姓名(昵称) 任意内容,显示在收件人邮件的发件人邮箱地址前的发件人姓名 $mail->FromName = ‘新狮科技‘; //smtp登录的账号 这里填入字符串格式的qq号即可 $mail->Username =‘[email protected]‘; //smtp登录的密码 这里填入“独立密码” 若为设置“独立密码”则填入登录qq的密码 建议设置“独立密码” $mail->Password = ‘‘; //设置发件人邮箱地址 这里填入上述提到的“发件人邮箱” $mail->From = ‘[email protected]‘; //邮件正文是否为html编码 注意此处是一个方法 不再是属性 true或false $mail->isHTML(true); //设置收件人邮箱地址 该方法有两个参数 第一个参数为收件人邮箱地址 第二参数为给该地址设置的昵称 不同的邮箱系统会自动进行处理变动 这里第二个参数的意义不大 $mail->addAddress($emailAddress,$realname); //添加多个收件人 则多次调用方法即可 //$mail->addAddress(‘xxx@163/.com‘,‘在线用户‘); //添加该邮件的主题 $mail->Subject = $title; //添加邮件正文 上方将isHTML设置成了true,则可以是完整的html字符串 如:使用file_get_contents函数读取本地的html文件 $mail->Body = "亲爱的".$realname.":<br/>感谢您的大力支持。<br/>请先登录低糖生活会员中心再点击链接(否则无效)$do。<br/> <a href=‘http://".$_SERVER["SERVER_NAME"] ."/UserCenter/checkEmail?verify=".$token."‘ target= ‘_blank‘>http://".$_SERVER["SERVER_NAME"] ."/UserCenter/checkEmail?verify=".$token."</a><br/> 如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。"; //为该邮件添加附件 该方法也有两个参数 第一个参数为附件存放的目录(相对目录、或绝对目录均可) 第二参数为在邮件附件中该附件的名称 //$mail->addAttachment(‘./d.jpg‘,‘mm.jpg‘); //同样该方法可以多次调用 上传多个附件 //$mail->addAttachment(‘./Jlib-1.1.0.js‘,‘Jlib.js‘); //发送命令 返回布尔值 //PS:经过测试,要是收件人不存在,若不出现错误依然返回true 也就是说在发送之前 自己需要些方法实现检测该邮箱是否真实有效 $status = $mail->send(); // //简单的判断与提示信息 if($status) { return ‘我们已将邮件发送到您填写的邮箱,请查收。‘; }else{ return ‘发送邮件失败,错误信息:‘.$mail->ErrorInfo; } }
这是发送邮件的方法。
include_once APP_ROOT . ‘doitphp/modules/phpmailer/PHPMailerAutoload.php‘; 俺自己需求定制。
项目中是写一个激活邮箱功能:
public function checkEmailAction(){ $model = $this->model("CsUser"); //查看数据库 此用户 是否对邮箱激活过 $res = $model->getOne("id =?",$this->userInfo[‘id‘]); $token = $_GET[‘verify‘]; $startdate=$res[‘email_token_time_ck‘];//从数据库获取 $enddate= date(‘Y-m-d H:i:s‘,time());//当前时间 $date=floor((strtotime($enddate)-strtotime($startdate))/86400*24*60*60); if(!empty($token)){ //用户点击邮箱里面连接到此控制器,做处理。 //验证token if($this->token($res["username"],$res[‘password‘]) == $token ){ if($res["checkEmail"] == 1){ $str = "邮箱激活成功,无需再次激活。"; }else{ if($date < 86400){ $id = $this->userInfo[‘id‘]; $sql = "update induser set `checkEmail` = 1 where `id` = $id "; $model->execute($sql); $str = "恭喜你,邮箱验证成功。"; }else{ $str = "链接已失效,请重新激活邮箱,获得新的激活邮件。"; } } } //当距离上次发邮件验证邮箱时间大于24小时 或者从来没有验证过的时候进入下一层if }else if(($date > 86400 || $startdate == ‘‘) && $res[‘checkEmail‘] == 0){ //代表未曾激活 $token = $this->token($res["username"],$res[‘password‘]); if(empty($res[‘realname‘])){ $str = $this->sendEmail($res[‘email‘],"用户",$token,"激活邮箱","激活邮箱"); }else{ $str = $this->sendEmail($res[‘email‘],$res[‘realname‘],$token,"激活邮箱","激活邮箱"); } //修改数据库 $time = date(‘Y-m-d H:i:s‘,time()); $id = $this->userInfo[‘id‘]; $sql = "update induser set `email_token_time_ck` = ‘$time ‘where `id` = $id "; $model->execute($sql); }else{ $str = "邮箱已激活,无需再次验证。";//邮箱已通过验证 } $this->assign(array( ‘res‘=> $str )); $this->display("checkEmail"); }
这是业务代码。。。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。