《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");
    }

 

这是业务代码。。。

《deetom》项目开发历程<五> PHP邮件,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。