一、登錄成功發送郵件
? ? ? ? 在根目錄下app文件夾下controller文件夾下common文件夾下,修改Login.php,代碼如下
<?php
/*** 登錄退出操作* User: 龍哥·三年風水* Date: 2024/10/29* Time: 15:53*/
namespace app\controller\common;
use app\controller\Emptys;
use app\model\permission\Admin;
use app\model\param\System as SystemModel;
use Email\EmailSender;
use Redis\Redis;
use app\model\common\Token as TokenModel;
use Encipher\Encrypt;
class Login extends Emptys
{//驗證碼展示public function getCode(){$re = app()->make(\Other\Captcha::class)->create();$base64 = 'data:image/png;base64,' . base64_encode($re->getData());return succ('SUCCESS',$base64);}//登錄public function doLogin(){$param = $this->request->param();$validate = new \app\validate\common\Login;$result = $validate->check($param);//參數驗證if (!$result) return err($validate->getError());//驗證碼的正確性if (!app()->make(\Other\Captcha::class)->check($param['captcha_code'])) return err('驗證碼錯誤');if (time() + 5 < strtotime($param['login_time'])) return err('非法登錄');$resData = Admin::dataFind(['email' => trim($param['username'])], 'id,realname,password,ip,status', true);//用戶信息的正確性if (empty($resData) && empty($resData['id'])) return err('用戶不存在');if ($resData['status'] !== 1) return err('該賬號已被禁用');$systemParam = SystemModel::dataFind(['id' => 1],'security_password,platform_token_expira');if ($resData['password'] !== sha1($param['password'] . $systemParam['security_password'])) return err('賬號對應的密碼錯誤');if(!empty($resData['ip'])){if($resData['ip'] != $this->request->header('x-real-ip'))return err('禁止訪問,不在IP白名單中');}//寫入Token日志$data['token_type'] = 1;$data['menu_name'] = 'CommonLoginDoLogin';$data['admin_id'] = $resData['id'];$data['random_number'] = alnum();$data['create_time'] = date('Y-m-d',strtotime($param['login_time']));$data['login_time'] = $param['login_time'];$data['expire_time'] = strtotime($param['login_time']) + $systemParam['platform_token_expira'];$token = $data['admin_id'] . $data['random_number'];$data['token'] = sha1(sha1($token) . strtotime($data['login_time']));TokenModel::save($data,[]);//加入跨站攻擊驗證隊列Redis::select(config('cache.stores.redis.token_db'))->setex('token_' . $data['token'],$systemParam['platform_token_expira'],$resData['id']);Redis::select(config('cache.stores.redis.token_db'))->setex('token_' . $resData['id'],$systemParam['platform_token_expira'],Encrypt::encryptRsa($data['token']));$emailSender = new EmailSender();$emailSender::send($param['username'],'登錄系統',$resData['realname'].'于'.$param['login_time'].'登錄系統');return succ('登錄成功',Encrypt::encryptRsa($token));}
}
二、退出成功發送郵件
? ? ? ? 1、更改前端apijs文件
? ? ? ? ? ? ? ? 在根目錄下src文件夾下api文件夾下,修改common.js文件,代碼如下:
// 退出
export function logout() {return request({url: '/permission/member/logout',method: 'post'})
}
? ? ? ? 2、后端api更改路由
? ? ? ? ? ? ? ? 在根目錄下route文件夾下,修改app.php文件,代碼如下:
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006~2018 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <liu21st@gmail.com>
// +----------------------------------------------------------------------
use think\facade\Route;Route::get('think', function () {return 'hello,ThinkPHP6!';
});
Route::post('index/index','Index/index');// 測試使用
Route::post('index/generate_rsa','Index/generateRsa');// 生成rsa公私鑰文件使用
// 特殊操作
Route::get('login/get_code', 'common.Login/getCode');// 獲取驗證碼使用
Route::post('login/do_login', 'common.Login/doLogin');// 登錄提交接口
Route::post('upload/file','common.Upload/file');// 上傳文件接口
Route::post('publics/get_info','common.Publics/getInfo');// 獲取公有數據接口
Route::group('permission',function (){// 個人資料Route::post('member/personal_data','permission.Member/personalData');// 獲取個人信息接口Route::post('member/personal_menu','permission.Member/personalMenu');// 獲取個人菜單接口Route::post('member/update_personal','permission.Member/updatePersonal');// 修改個人信息接口Route::post('member/logout', 'permission.Member/logout');// 退出登錄接口// 管理員操作Route::get('admin/get_list','permission.Admin/getList');// 獲取管理員列表Route::post('admin/get_all','permission.Admin/getAll');// 獲取管理員所有數據Route::post('admin/get_info','permission.Admin/getInfo');// 獲取管理員單條數據Route::post('admin/save_info','permission.Admin/saveInfo');// 保存管理員數據Route::post('admin/status_info','permission.Admin/statusInfo');// 啟禁用管理員Route::post('admin/delete_info','permission.Admin/deleteInfo');// 刪除管理員// 角色操作Route::get('role/get_list','permission.Role/getList');// 獲取角色列表Route::post('role/get_all','permission.Role/getAll');// 獲取所有角色數據Route::post('role/get_info','permission.Role/getInfo');// 獲取單個角色數據Route::post('role/save_info','permission.Role/saveInfo');// 保存角色數據Route::post('role/status_info','permission.Role/statusInfo');// 啟禁用角色數據Route::post('role/delete_info','permission.Role/deleteInfo');// 刪除角色數據// 菜單操作Route::post('menu/get_all','permission.Menu/getAll');// 獲取所有菜單數據Route::post('menu/get_info','permission.Menu/getInfo');// 獲取單個菜單數據Route::post('menu/save_info','permission.Menu/saveInfo');// 保存菜單數據Route::post('menu/status_info','permission.Menu/statusInfo');// 啟禁用菜單數據Route::post('menu/delete_info','permission.Menu/deleteInfo');// 刪除菜單數據});
Route::group('param',function (){//系統配置Route::post('system/get_info','param.System/getInfo');// 獲取系統參數數據Route::post('system/save_info','param.System/saveInfo');// 保存系統參數數據//上傳配置Route::post('upload/get_info','param.Upload/getInfo');// 獲取上傳參數數據Route::post('upload/save_info','param.Upload/saveInfo');// 保存上傳參數數據//短信配置Route::post('channel_sms/get_info','param.ChannelSms/getInfo');// 獲取郵箱短信參數數據Route::post('channel_sms/save_info','param.ChannelSms/saveInfo');// 保存郵箱短信參數數據//郵件配置Route::post('channel_email/get_info','param.ChannelEmail/getInfo');// 獲取郵箱短信參數數據Route::post('channel_email/save_info','param.ChannelEmail/saveInfo');// 保存郵箱短信參數數據// 圖片格式操作Route::get('image/get_list','param.Image/getList');// 獲取圖片格式列表Route::post('image/get_all','param.Image/getAll');// 獲取所有圖片格式數據Route::post('image/get_info','param.Image/getInfo');// 獲取單個圖片格式數據Route::post('image/save_info','param.Image/saveInfo');// 保存圖片格式數據Route::post('image/status_info','param.Image/statusInfo');// 啟禁用圖片格式數據Route::post('image/delete_info','param.Image/deleteInfo');// 刪除圖片格式數據// 視頻格式操作Route::get('video/get_list','param.Video/getList');// 獲取視頻格式列表Route::post('video/get_all','param.Video/getAll');// 獲取所有視頻格式數據Route::post('video/get_info','param.Video/getInfo');// 獲取單個視頻格式數據Route::post('video/save_info','param.Video/saveInfo');// 保存視頻格式數據Route::post('video/status_info','param.Video/statusInfo');// 啟禁用視頻格式數據Route::post('video/delete_info','param.Video/deleteInfo');// 刪除視頻格式數據// 文件格式操作Route::get('filedoc/get_list','param.Filedoc/getList');// 獲取文件格式列表Route::post('filedoc/get_all','param.Filedoc/getAll');// 獲取所有文件格式數據Route::post('filedoc/get_info','param.Filedoc/getInfo');// 獲取單個文件格式數據Route::post('filedoc/save_info','param.Filedoc/saveInfo');// 保存文件格式數據Route::post('filedoc/status_info','param.Filedoc/statusInfo');// 啟禁用文件格式數據Route::post('filedoc/delete_info','param.Filedoc/deleteInfo');// 刪除文件格式數據// 部門配置操作Route::get('department/get_list','param.Department/getList');// 獲取部門配置列表Route::post('department/get_all','param.Department/getAll');// 獲取所有部門配置數據Route::post('department/get_info','param.Department/getInfo');// 獲取單個部門配置數據Route::post('department/save_info','param.Department/saveInfo');// 保存部門配置數據Route::post('department/status_info','param.Department/statusInfo');// 啟禁用部門配置數據Route::post('department/delete_info','param.Department/deleteInfo');// 刪除部門配置數據// 級別配置操作Route::get('grade/get_list','param.Grade/getList');// 獲取級別配置列表Route::post('grade/get_all','param.Grade/getAll');// 獲取所有級別配置數據Route::post('grade/get_info','param.Grade/getInfo');// 獲取單個級別配置數據Route::post('grade/save_info','param.Grade/saveInfo');// 保存級別配置數據Route::post('grade/status_info','param.Grade/statusInfo');// 啟禁用級別配置數據Route::post('grade/delete_info','param.Grade/deleteInfo');// 刪除級別配置數據// 郵箱配置操作Route::get('sms/get_list','param.Sms/getList');// 獲取短信配置列表Route::post('sms/get_all','param.Sms/getAll');// 獲取所有短信配置數據Route::post('sms/get_info','param.Sms/getInfo');// 獲取單個短信配置數據Route::post('sms/save_info','param.Sms/saveInfo');// 保存短信配置數據Route::post('sms/status_info','param.Sms/statusInfo');// 啟禁用短信配置數據Route::post('sms/delete_info','param.Sms/deleteInfo');// 刪除短信配置數據
});
Route::miss('Emptys/index');
? ? ? ? 3、添加退出方法
? ? ? ? ? ? ? ? 在根目錄下app文件夾下controller文件夾下permission文件夾下,修改Member.php文件,代碼如下:
<?php
/*** 個人信息控制-也就是登錄者信息及角色對外方法* User: 龍哥·三年風水* Date: 2024/10/30* Time: 14:18*/
namespace app\controller\permission;
use app\controller\Base;
use app\model\param\Department as PDModel;
use app\model\param\Grade as PGModel;
use app\model\permission\Role as PRModel;
use app\model\param\System as PSModel;
use app\model\permission\Admin as PAModel;
use Other\Tree;
use Redis\Redis;
use app\model\permission\Menu as PMModel;
use Email\EmailSender;
use app\model\common\Token as TokenModel;
class Member extends Base
{/*** 獲取個人信息* User: 龍哥·三年風水* Date: 2024/10/30* Time: 14:23* @ return \think\response\Json*/public function personalData(){$data = [];$data['username'] = $this->username;$data['avatar'] = $this->avatar;$data['email'] = $this->email;$data['realname'] = $this->realname;$data['ip'] = empty($this->ip) ? '' : $this->ip;$departmentTitle = PDModel::dataFind(['id' => $this->departmentId],'title',false);$data['department_title'] = empty($departmentTitle) ? '' : $departmentTitle;$gradeTitle = PGModel::dataFind(['id' => $this->gradeId],'title',false);$data['grade_title'] = empty($gradeTitle) ? '' : $gradeTitle;$data['rolename'] = PRModel::dataFind(['id' => $this->roleId],'rolename',false);$res = $this->getRoleMenu();$data['key'] = $res['key'];$data['butt'] = $res['butts'];return succ('操作成功',$data);}/*** 登錄者菜單權限* User: 龍哥·三年風水* Date: 2024/11/5* Time: 17:32* @ return \think\response\Json*/public function personalMenu(){$listMenu = unserialize(Redis::select(config('cache.stores.redis.cache_db'))->get('menu_list'.$this->userId));if($listMenu === false){if(count($this->rules) == 0)$this->setAuth();$listMenu = PMModel::getAll([['id', 'in', $this->rules], ['status', '=', 1], ['is_menu', '=', 1]], 'id,menuname,pid,title,path,component,icon,redirect,always_show,is_hidden,is_icon,is_cache','sort DESC,id DESC');if(empty($listMenu)) return err("該用戶沒有權限");$seconds = rand(60,120);Redis::select(config('cache.stores.redis.cache_db'))->setex('menu_list'.$this->userId,$seconds,serialize($listMenu));}$data['menu'] = Tree::list_to_tree($listMenu,0, 'id', 'pid', 'children');return succ('操作成功',$data);}/*** 修改個人資料* User: 龍哥·三年風水* Date: 2024/11/5* Time: 9:31*/public function updatePersonal(){$param = $this->request->param();$validate = new \app\validate\permission\UpdateAdmin;$param['id'] = $this->userId;if (!$validate->check($param)) return err($validate->getError());if(!empty($param['password'])){$securityPassword = PSModel::dataFind(['id' => 1],'security_password')['security_password'];$data['password'] = sha1($param['password'] . $securityPassword);}$data['username'] = $param['username'];$data['avatar'] = empty($param['avatar']) ? $this->avatar : $param['avatar'];$data['realname'] = $param['realname'];$data['email'] = $param['email'];PAModel::redisSave($data, $this->userId);return succ('操作成功',[]);}//退出public function logout(){$redisToken = Redis::select(config('cache.stores.redis.token_db'))->get('token_' . $this->token);if(!empty($redisToken)){$emailSender = new EmailSender();$emailSender::send($this->email,'退出系統',$this->realname.'于'.date('Y-m-d H:i:s',time()).'退出系統');TokenModel::save(['expire_time' => time()], ['token' => $this->token]);Redis::select(config('cache.stores.redis.token_db'))->del('token_' . $redisToken);Redis::select(config('cache.stores.redis.token_db'))->del('token_' . $this->token);}return succ('退出成功');}
}
? ? ? ? 4、刪除登錄文件里面的退出方法
? ? ? ? ? ? ? ? 在根目錄下app文件夾下controller文件夾下common文件夾下,修改Login.php文件,代碼如下:
<?php
/*** 登錄退出操作* User: 龍哥·三年風水* Date: 2024/10/29* Time: 15:53*/
namespace app\controller\common;
use app\controller\Emptys;
use app\model\permission\Admin;
use app\model\param\System as SystemModel;
use Email\EmailSender;
use Redis\Redis;
use app\model\common\Token as TokenModel;
use Encipher\Encrypt;
class Login extends Emptys
{//驗證碼展示public function getCode(){$re = app()->make(\Other\Captcha::class)->create();$base64 = 'data:image/png;base64,' . base64_encode($re->getData());return succ('SUCCESS',$base64);}//登錄public function doLogin(){$param = $this->request->param();$validate = new \app\validate\common\Login;$result = $validate->check($param);//參數驗證if (!$result) return err($validate->getError());//驗證碼的正確性if (!app()->make(\Other\Captcha::class)->check($param['captcha_code'])) return err('驗證碼錯誤');if (time() + 5 < strtotime($param['login_time'])) return err('非法登錄');$resData = Admin::dataFind(['email' => trim($param['username'])], 'id,realname,password,ip,status', true);//用戶信息的正確性if (empty($resData) && empty($resData['id'])) return err('用戶不存在');if ($resData['status'] !== 1) return err('該賬號已被禁用');$systemParam = SystemModel::dataFind(['id' => 1],'security_password,platform_token_expira');if ($resData['password'] !== sha1($param['password'] . $systemParam['security_password'])) return err('賬號對應的密碼錯誤');if(!empty($resData['ip'])){if($resData['ip'] != $this->request->header('x-real-ip'))return err('禁止訪問,不在IP白名單中');}//寫入Token日志$data['token_type'] = 1;$data['menu_name'] = 'CommonLoginDoLogin';$data['admin_id'] = $resData['id'];$data['random_number'] = alnum();$data['create_time'] = date('Y-m-d',strtotime($param['login_time']));$data['login_time'] = $param['login_time'];$data['expire_time'] = strtotime($param['login_time']) + $systemParam['platform_token_expira'];$token = $data['admin_id'] . $data['random_number'];$data['token'] = sha1(sha1($token) . strtotime($data['login_time']));TokenModel::save($data,[]);//加入跨站攻擊驗證隊列Redis::select(config('cache.stores.redis.token_db'))->setex('token_' . $data['token'],$systemParam['platform_token_expira'],$resData['id']);Redis::select(config('cache.stores.redis.token_db'))->setex('token_' . $resData['id'],$systemParam['platform_token_expira'],Encrypt::encryptRsa($data['token']));$emailSender = new EmailSender();$emailSender::send($param['username'],'登錄系統',$resData['realname'].'于'.$param['login_time'].'登錄系統');return succ('登錄成功',Encrypt::encryptRsa($token));}
}