vr-shopxo-source/extend/base/Email.php

270 lines
6.9 KiB
PHP
Raw Normal View History

2018-12-28 10:58:37 +00:00
<?php
// +----------------------------------------------------------------------
// | ShopXO 国内领先企业级B2C免费开源电商系统
// +----------------------------------------------------------------------
2021-03-16 02:34:52 +00:00
// | Copyright (c) 2011~2099 http://shopxo.net All rights reserved.
2018-12-28 10:58:37 +00:00
// +----------------------------------------------------------------------
2021-03-16 02:34:52 +00:00
// | Licensed ( https://opensource.org/licenses/mit-license.php )
2018-12-28 10:58:37 +00:00
// +----------------------------------------------------------------------
// | Author: Devil
// +----------------------------------------------------------------------
namespace base;
2019-01-11 10:04:30 +00:00
2019-01-11 09:09:33 +00:00
use phpmailer\PHPMailer;
2018-12-28 10:58:37 +00:00
/**
* Email驱动
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-01-10T21:51:08+0800
*/
class Email
{
private $interval_time;
private $expire_time;
private $key_code;
2022-03-27 15:36:26 +00:00
private $is_frq;
2018-12-28 10:58:37 +00:00
public $error;
private $obj;
/**
* [__construct 构造方法]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-07T14:03:02+0800
2022-03-27 15:36:26 +00:00
* @param [int] $params['interval_time'] [间隔时间默认30单位]
* @param [int] $params['expire_time'] [到期时间默认30单位]
* @param [string] $params['key_prefix'] [验证码种存储前缀key默认 空)]
* @param [string] $params['is_frq'] [是否验证频率(默认 是)]
2018-12-28 10:58:37 +00:00
*/
2022-03-27 15:36:26 +00:00
public function __construct($params = [])
2018-12-28 10:58:37 +00:00
{
2022-03-27 15:36:26 +00:00
$this->interval_time = isset($params['interval_time']) ? intval($params['interval_time']) : 30;
$this->expire_time = isset($params['expire_time']) ? intval($params['expire_time']) : 30;
$this->key_code = isset($params['key_prefix']) ? trim($params['key_prefix']).'_sms_code' : '_sms_code';
$this->is_frq = isset($params['is_frq']) ? intval($params['is_frq']) : 1;
2018-12-28 10:58:37 +00:00
}
/**
* [EmailInit 邮件初始化]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-10T11:03:38+0800
*/
private function EmailInit()
{
// 建立邮件发送类
2019-01-11 10:04:30 +00:00
$this->obj = new PHPMailer();
2018-12-28 10:58:37 +00:00
// 使用smtp方式发送
$this->obj->IsSMTP();
// 服务器host地址
$this->obj->Host = MyC('common_email_smtp_host');
//smtp验证功能
$this->obj->SMTPAuth = true;
2019-05-21 03:10:04 +00:00
2018-12-28 10:58:37 +00:00
// 端口
$this->obj->Port = MyC('common_email_smtp_port', 25, true);
2019-05-21 03:10:04 +00:00
// SSL方式加密
if(MyC('common_email_is_use_ssl', 0, true) == 1)
{
$this->obj->SMTPSecure = 'ssl';
}
2018-12-28 10:58:37 +00:00
// 邮箱用户名
$this->obj->Username = MyC('common_email_smtp_name');
// 邮箱密码
$this->obj->Password = MyC('common_email_smtp_pwd');
// 发件人
$this->obj->From = MyC('common_email_smtp_account');
// 发件人姓名
$this->obj->FromName = MyC('common_email_smtp_send_name');
// 是否开启html格式
2019-01-11 09:09:33 +00:00
$this->obj->isHTML(true);
2018-12-28 10:58:37 +00:00
// 设置编码
2018-12-29 05:13:09 +00:00
$this->obj->CharSet = 'utf-8';
2018-12-28 10:58:37 +00:00
}
/**
* [SendHtml html邮件发送]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-10T10:56:43+0800
2022-03-27 15:36:26 +00:00
* @param [string] $params['email'] [收件邮箱]
* @param [string] $params['content'] [内容]
* @param [string] $params['title'] [标题]
* @param [string] $params['code'] [验证码]
* @param [string] $params['username'] [收件人名称]
2018-12-28 10:58:37 +00:00
*/
2022-03-27 15:36:26 +00:00
public function SendHtml($params = [])
2018-12-28 10:58:37 +00:00
{
2022-03-27 15:36:26 +00:00
if(empty($params['email']))
2018-12-28 10:58:37 +00:00
{
$this->error = '收件邮箱不能为空';
return false;
}
2022-03-27 15:36:26 +00:00
if(empty($params['content']))
2018-12-28 10:58:37 +00:00
{
$this->error = '发送内容不能为空';
return false;
}
2022-03-27 15:36:26 +00:00
if(empty($params['title']))
2018-12-28 10:58:37 +00:00
{
$this->error = '邮件标题不能为空';
return false;
}
// 是否频繁操作
2022-03-27 15:36:26 +00:00
if($this->is_frq == 1)
2018-12-28 10:58:37 +00:00
{
2022-03-27 15:36:26 +00:00
if(!$this->IntervalTimeCheck())
{
$this->error = '防止造成骚扰,请勿频繁发送';
return false;
}
2018-12-28 10:58:37 +00:00
}
// 验证码替换
2022-03-27 15:36:26 +00:00
if(!empty($params['code']))
2018-12-28 10:58:37 +00:00
{
2022-03-27 15:36:26 +00:00
$params['content'] = str_replace('#code#', $params['code'], $params['content']);
2018-12-28 10:58:37 +00:00
}
// 邮件初始化
$this->EmailInit();
// 收件人地址可以替换成任何想要接收邮件的email信箱,格式("收件人email","收件人姓名")
2022-03-27 15:36:26 +00:00
$this->obj->AddAddress($params['email'], isset($params['username']) ? $params['username'] : $params['email']);
2018-12-28 10:58:37 +00:00
// 邮件标题
2022-03-27 15:36:26 +00:00
$this->obj->Subject = $params['title'];
2018-12-28 10:58:37 +00:00
// 邮件内容
2022-03-27 15:36:26 +00:00
$this->obj->Body = $params['content'];
2018-12-28 10:58:37 +00:00
// 邮件正文不支持HTML的备用显示
2022-03-27 15:36:26 +00:00
$this->obj->AltBody = strip_tags($params['content']);
2018-12-28 10:58:37 +00:00
// 发送邮件
if($this->obj->Send())
{
2022-03-27 15:36:26 +00:00
// 种session
if($this->is_frq == 1)
2018-12-28 10:58:37 +00:00
{
2022-03-27 15:36:26 +00:00
$this->KindofSession(empty($params['code']) ? '' : $params['code']);
2018-12-28 10:58:37 +00:00
}
return true;
} else {
$this->error = $this->obj->ErrorInfo;
}
return false;
}
/**
* [KindofSession 种验证码session]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-07T14:59:13+0800
2022-03-27 15:36:26 +00:00
* @param [string] $value [存储值或验证码]
2018-12-28 10:58:37 +00:00
*/
2022-03-27 15:36:26 +00:00
private function KindofSession($value = '')
2018-12-28 10:58:37 +00:00
{
2022-03-27 15:36:26 +00:00
$data = [
'value' => $value,
'time' => time(),
];
2021-07-18 15:42:10 +00:00
MyCache($this->key_code, $data, $this->expire_time);
2018-12-28 10:58:37 +00:00
}
/**
* [CheckExpire 验证码是否过期]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-05T19:02:26+0800
* @return [boolean] [有效true, 无效false]
*/
public function CheckExpire()
{
2021-07-18 15:42:10 +00:00
$data = MyCache($this->key_code);
2020-01-25 17:05:08 +00:00
if(!empty($data))
2018-12-28 10:58:37 +00:00
{
return (time() <= $data['time']+$this->expire_time);
}
return false;
}
/**
* [CheckCorrect 验证码是否正确]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-05T16:55:00+0800
* @param [string] $code [验证码默认从post读取]
* @return [booolean] [正确true, 错误false]
*/
public function CheckCorrect($code = '')
{
2020-06-03 05:38:13 +00:00
// 安全验证
if(SecurityPreventViolence($this->key_code, 1, $this->expire_time))
{
// 验证是否正确
2021-07-18 15:42:10 +00:00
$data = MyCache($this->key_code);
2020-06-03 05:38:13 +00:00
if(!empty($data))
2018-12-28 10:58:37 +00:00
{
2020-06-03 05:38:13 +00:00
if(empty($code) && isset($_POST['code']))
{
$code = trim($_POST['code']);
}
2022-03-27 15:36:26 +00:00
return (isset($data['value']) && $data['value'] == $code);
2018-12-28 10:58:37 +00:00
}
2020-06-03 05:38:13 +00:00
}
2018-12-28 10:58:37 +00:00
return false;
}
/**
* [Remove 验证码清除]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-08T10:18:20+0800
* @return [other] [无返回值]
*/
public function Remove()
{
2021-07-18 15:42:10 +00:00
MyCache($this->key_code, null);
2020-06-03 05:38:13 +00:00
SecurityPreventViolence($this->key_code, 0);
2018-12-28 10:58:37 +00:00
}
/**
* [IntervalTimeCheck 是否已经超过控制的间隔时间]
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-03-10T11:26:52+0800
* @return [booolean] [已超过间隔时间true, 未超过间隔时间false]
*/
private function IntervalTimeCheck()
{
2021-07-18 15:42:10 +00:00
$data = MyCache($this->key_code);
2020-01-25 17:05:08 +00:00
if(!empty($data))
2018-12-28 10:58:37 +00:00
{
return (time() > $data['time']+$this->interval_time);
}
return true;
}
}
?>