## 1.form表單
```
{include file="common/header"}
<body>
<div class="layui-fluid">
<div class="layui-row">
<form class="layui-form">
<!-- <input type="hidden" name="__token__" value="{$Request.token}" /> -->
<div class="layui-form-item">
<label for="username" class="layui-form-label">
<span class="x-red">*</span>管理員名稱
</label>
<div class="layui-input-inline">
<input type="text" id="username" name="username" required="required" lay-verify="username" autocomplete="off" class="layui-input" onblur="ajaxName()">
</div>
<div class="layui-form-mid layui-word-aux">
<span class="x-red">*</span>將會成為您唯一的登入名
</div>
</div>
<div class="layui-form-item">
<label for="L_pass" class="layui-form-label">
<span class="x-red">*</span>密碼
</label>
<div class="layui-input-inline">
<input type="password" id="L_pass" name="password" required="required" lay-verify="pass" autocomplete="off" class="layui-input">
</div>
<div class="layui-form-mid layui-word-aux">
6到16個字符
</div>
</div>
<div class="layui-form-item">
<label for="L_repass" class="layui-form-label">
<span class="x-red">*</span>確認密碼
</label>
<div class="layui-input-inline">
<input type="password" id="L_repass" name="password" required="required" lay-verify="repass" autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<label for="L_email" class="layui-form-label">
<span class="x-red">*</span>郵箱
</label>
<div class="layui-input-inline">
<input type="text" id="L_email" name="email" required="required" lay-verify="email" autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">所屬用戶組</label>
<div class="layui-input-inline">
<select name="role_id">
{volist name="role_data" id="role"}
<option value="{$role.id}">{$role.remark}</option>
{/volist}
</select>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">是否啟用</label>
<div class="layui-input-block">
<input type="radio" name="status" value="1" title="是" checked=""><div class="layui-unselect layui-form-radio layui-form-radioed"><i class="layui-anim layui-icon layui-anim-scaleSpring"></i><div>是</div></div>
<input type="radio" name="status" value="0" title="否"><div class="layui-unselect layui-form-radio"><i class="layui-anim layui-icon"></i><div>否</div></div>
</div>
</div>
<div class="layui-form-item">
<label for="L_repass" class="layui-form-label"></label>
<button class="layui-btn" lay-filter="add" lay-submit="">增加</button>
</div>
</form>
</div>
</div>
<script>
//ajax查詢是否重名
function ajaxName(){
var username = $('#username').val();
$.ajax({
type:"post",
dataType:"json",
data:{username:username},
url:"{:url('admin/ajaxName')}",
success:function(data){
if (data.status == 1) {
layer.alert(data.info, {
title: '提示框',
icon: 0,
});
return false;
}
}
},'json');
}
layui.use(['form', 'layer'],
function() {
$ = layui.jquery;
var form = layui.form,
layer = layui.layer;
//自定義驗證規則
form.verify({
username: function(value, item){ //value:表單的值、item:表單的DOM對象
if (value.length < 3) {
return '管理員名稱至少得3個字符';
}
if(!new RegExp("^[a-zA-Z0-9_\u4e00-\u9fa5\\s·]+$").test(value)){
return '管理員名稱不能有特殊字符';
}
if(/(^\_)|(\__)|(\_+$)/.test(value)){
return '管理員名稱首尾不能出現下劃線\'_\'';
}
if(/^\d+\d+\d$/.test(value)){
return '管理員名稱不能全為數字';
}
},
pass: function(value, item){
if(!new RegExp("^[a-zA-Z0-9_\u4e00-\u9fa5\\s·]+$").test(value)){
return '密碼不能有特殊字符';
}
if(/(^\_)|(\__)|(\_+$)/.test(value)){
return '密碼首尾不能出現下劃線\'_\'';
}
if(/^\d+\d+\d$/.test(value)){
return '密碼不能全為數字';
}
if (value.length < 6) {
return '密碼至少得3個字符';
}
if (value.length > 16) {
return '密碼最多16個字符';
}
},
repass: function(value) {
if ($('#L_pass').val() != $('#L_repass').val()) {
return '兩次密碼不一致';
}
},
});
//監聽提交
form.on('submit(add)',
function(data) {
//獲取表單數據
var dataadd = data.field;
$.ajax({
type:"post",
dataType:"json",
data:{data:dataadd},
url:"{:url('admin/save')}",
success:function(data){
if (data.status == 1) {
layer.alert(data.info, {
title: '提示框',
icon: 0,
});
} else {
layer.alert(data.info, {
title: '提示框',
icon: 0,
});
}
}
},'json');
return false;
});
});
</script>
</body>
</html>
```
## 2.控制器
```
/**
* 保存新建管理員
*
* @param \think\Request $request
* @return \think\Response
*/
public function save($data)
{
if (!Request()->isAjax()) {
return json(array('status' => 0, 'info' => '提交類型錯誤'));
} else {
//驗證
$admin_username = db('admin')->field('username')->select();
if ($data['username'] == $admin_username['username']) {
return json(array('status' => 0, 'info' => '管理員名稱不得重復!'));
}
if ( empty($data['username'])) {
return json(array('status' => 0, 'info' => '管理員名稱不得為空!'));
}
if ( empty($data['password'])) {
return json(array('status' => 0, 'info' => '密碼不得為空!'));
}
//獲取數據,除去所屬角色id
$userData['username'] = $data['username'];
$userData['password'] = md5(md5($data['password']) . $data['salt']);
$userData['salt'] = getRandKey();//隨機一組數字
$userData['status'] = $data['status'];
$userData['login_time'] = time();
$userData['login_ip'] = get_client_ip();
$userData['add_time'] = time();
$userData['email'] = $data['email'];
$res = db('admin')->insert($userData, 0, 1);
//添加管理員和角色中間表
$role_user['role_id'] =$data['role_id'];
$role_user['user_id'] = $res;
$roleadd = Db('role_user')->insert($role_user);
if($res && $roleadd){
//記錄操作日志
save_log('管理員名稱:' . $userData['username'] . '添加成功', 2);
return json(array('status' => 1, 'info' => '添加管理員成功'));
}else{
return json(array('status' => 0, 'info' => '添加管理員失敗'));
}
}
}
```
- 簡介
- 前端
- html
- css
- css選擇器
- fiex布局
- 盒裝模型
- javascript
- 原型鏈
- 作用域
- 事件綁定
- dom
- bom
- jquery
- 選擇器
- jquery事件綁定
- layui
- bootstrap
- vue
- 路由(Vue Router)
- Vue CLI
- axios
- vant
- 打包部署
- 自定義組件
- 一些前端效果
- 點擊復制功能
- 后端
- php框架
- thinkphp
- 隱藏index.php
- thinkphp實現多表查詢
- thinkphp使用ajax單圖上傳
- thinkphp使用ajax圖集上傳
- thinkphp使用ajax查詢是否重名
- thinkphp使用ajax表單上傳
- where多個條件
- 郵件發送功能
- thinkphp短信寶發送短信
- tp5事務
- validate驗證二維數組
- yii2
- yii配置郵件
- yii的CRUD操作
- layui中兩種展示表單的方式
- laravel
- laravel實例
- laravel登錄
- laravel前端注冊
- laravel列表
- laravel刪除
- laravel編輯
- laravel新增
- Laravel 目錄結構
- Laravel 路由
- Laravel 控制器
- Laravel 模型讀操作
- Laravel 模型增、刪、改操作
- Laravel 中間件
- Laravel 視圖
- Laravel ,YII,thinkphp 框架的區別
- 會話控制
- session
- session存入redis
- session創建
- session刪除
- cookie
- 面向對象
- 三大特性
- 魔術方法
- 修飾符
- obj變量
- php
- php版本差異
- php7與php5的區別
- PHP 內存溢出問題
- 數據類型
- PHP 垃圾回收機制(GC)
- 文件目錄操作
- php函數
- 字符串相關函數
- 數組相關函數
- 超全局數組與超全局變量
- php魔術方法
- 引用變量
- php類庫
- 1.根據隨機數生成6位密鑰
- 2.獲取客戶端IP地址
- 3.多維數組變成一維數組
- 4.判斷是否是微信瀏覽器
- 5.判斷是否是移動端
- 6.隱藏手機號碼156***8956
- 7.隱藏郵箱 9533*****@qq.com
- 8.數組排序
- 9.添加操作日志
- 10.無線分類按子分類排序
- 11.從數組中刪除空白的元素
- 12.字符串相關類庫
- curl模擬post/get請求
- 替換中間四位數
- PHP地理位置計算
- 生成唯一訂單號
- 阿拉伯數字轉化為大寫
- 時間戳轉為中文時間
- php獲取本年、本月、本周時間戳和日期格式的實例代碼(分析)
- 去除數據庫的數據空格
- 壓縮Zip文件和文件打包下載
- PHP常用六大設計模式
- 單例模式
- 工廠模式
- 注冊樹模式
- 策略模式
- 適配器模式
- 觀察者模式
- 數據庫
- 留言板功能
- 所了解的數據庫
- sql server
- Memecached
- MongoDB
- mysql
- 存儲引擎(MyISAM與InnoDB)
- 庫表CRUD操作
- 索引
- 事務
- mysql常用命令
- 悲觀鎖和樂觀鎖
- 數據庫優化
- 大流量大并發優化
- Redis
- redis相關考點
- 開啟redis
- redis緩存cache
- redis存儲session
- redis限制提交次數
- 緩存雪崩,擊穿,穿透(copy)
- redis數據結構及使用場景
- 消息隊列
- Redis、Memecached 區別?
- phpstudy升級mysql版本
- 分表
- 讀寫分離
- linux
- 開發環境搭建
- mysql配置
- centos7(lnmp)環境搭建
- ubuntu(lnmp)環境搭建
- Nginx
- nginx四個基本功能
- nginx重啟出錯
- Nginx 的反向代理
- 用戶用戶組
- 虛擬機安裝
- linux常用命令
- chmod命令
- ubuntu下apt-get 命令
- 釋放內存
- 云鎖安裝及使用
- 大部隊搭建
- Centos開啟端口命令
- Centos禁止root登錄
- Centos7修改22端口
- Rsync備份
- 開啟端口
- 微信開發
- 輔助開發
- 網站SEO
- TCP/IP協議
- HTTP 請求全過程
- http狀態碼
- http和https的區別
- http請求三部分
- tcp三次握手
- 三次握手的作用
- tcp四次揮手
- CMS
- 織夢CMS
- 帝國cms
- wordpress
- 禪知cms
- 八大接口
- 微信支付
- 支付寶支付
- 郵件
- 微博登錄
- QQ登錄
- 快遞
- 天氣
- 常見算法
- 快速排序
- 冒泡排序
- 選擇排序
- 插入排序
- 二分查找
- 希爾排序
- V2Ray搭建
- AJAX
- GIT
- RBAC用戶權限管理數據庫設計
- 開發中遇到的一些問題
- 資料購買
- 建立ssr服務器
- 簡單建
- 申請并使用ssl證書
- 正則表達式手冊
- phpstorm
- 注冊碼
- 備用注冊碼
- 網站設計概要
- 網站相關功能代碼
- 權限(RBAC/AUTH)
- 無限級分類
- 記住登錄狀態
- email找回密碼
- 企業網站開發概要
- 網站后臺
- 文章管理
- 欄目管理 CRUD 上級欄目
- 欄目管理
- 友情鏈接
- 操作日志
- 登錄注冊
- 權限管理
- 網站配置
- 網站前臺
- 首頁
- 新聞動態
- 聯系
- 案例
- 關于
- 單店鋪商城開發概要
- 面試準備
- 有意思的面試題
- 拉鉤面試要求
- 慕課面試視頻知識總結
- 面試題匯總
- 題目1
- 一些工作的要求
- 前端炒的
- 面試項目介紹
- MySQL面試100 問
- 術語庫
- redis相關
- php操作redis
- redis消息隊列(異步)
- redis消息隊列(同步)