• 《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://".$_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");
        }
    这是业务代码。。。

    此项目已经夭折。

    积累知识,分享知识,学习知识。
  • 相关阅读:
    ubuntu 通过命令将数据复制到u盘
    项目感言--功能的模块化
    java 中变量的存储与引用
    java 基础拾漏
    自动完成--autoComplete插件(2)
    自动完成--autoComplete插件
    Linux查看端口
    Linux查看系统信息
    js splice方法
    slice、substring、substr
  • 原文地址:https://www.cnblogs.com/bin-pureLife/p/3816465.html
Copyright © 2020-2023  润新知