首页 > 代码库 > 《deetom》项目开发历程<五> PHP邮件

《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 =‘cs@csince.com‘;    //smtp登录的密码 这里填入“独立密码” 若为设置“独立密码”则填入登录qq的密码 建议设置“独立密码”            $mail->Password = ‘‘;    //设置发件人邮箱地址 这里填入上述提到的“发件人邮箱”            $mail->From = ‘cs@csince.com‘;    //邮件正文是否为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://www.mamicode.com/‘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");    }

 

这是业务代码。。。