## 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消息队列(同步)