我这次使用的ThinkPHP版本是:3.2.3版本,还有会使用到一个弹出层插件,叫 layer,官网地址是:http://layer.layui.com/。废话不多说,进入撸码环节。

1、通用方法编写

  这个是后端公共方法,现在暂时写两个方法,再往后开发想到有需要的话,就会继续添加更多的公共方法。

<?php

/**
* JSON数据返回
*/
function jsonResult($status,$message,$data){
$result=array(
'status'=>$status,
'message'=>$message,
'data'=>$data
);
exit(json_encode($result));
} /**
* MD5加密密码
*/
function getMd5Password($password){
return md5($password.C('MD5_PRE'));
}
?>

  公共弹出JS方法封装

var dialog = {
/**
* 错误弹出层
* @param {String} 内容
*/
error: function(message) {
layer.open({
content: message,
icon: 2,
title: '错误提示'
});
}, /**
* 成功弹出层
* @param {String} 内容
* @param {String} 跳转地址
*/
success: function(message, url) {
layer.open({
content: message,
icon: 1,
yes: function() {
location.href = url;
}
});
}, /**
* 确认弹出层
* @param {String} 内容
* @param {String} 跳转地址
*/
confirm: function(message, url) {
layer.open({
content: message,
icon: 3,
btn: ['是', '否'],
yes: function() {
location.href = url;
}
});
}, /**
* 无需跳转到指定页面的确认弹出层
* @param {string} 内容
*/
toconfirm: function(message) {
layer.open({
content: message,
icon: 3,
btn: ['确定']
});
}, /**
* 加载层
*/
load:function(){
var index = layer.load(1, {
shade: [0.6,'#000'] //0.1透明度的白色背景
});
return index;
}
}

2、登录功能:

    后台用户操作类,添加在Model层,主要用于一些数据操作

<?php
namespace Common\Model;
use Think\Model; /**
* 后台用户操作类
*/
class AdminModel extends Model{
private $_db=null; public function __construct(){
$this->_db=M('admin');
} /**
* 根据用户名获取用户信息
* $username string 用户名
*/
public function getAdminByUserName($username=''){
$ret=$this->_db->where("user_name='{$username}'")->find();
return $ret;
} /**
* 根据adminid更新数据
* $id int id
* $data object 需更新的数据
*/
public function updateByAdminId($id,$data){
if(!$id || !is_numeric($id)){
throw_exception("ID不合法");
}
if(!$data || !is_array($data)){
throw_exception('更新的数据不合法');
}
return $this->_db->where("admin_id={$id}").save($data);
}
}
?>

  

    登录功能后端实现逻辑

<?php
namespace Admin\Controller;
use Think\Controller; class LoginController extends Controller{
public function index(){
if(session('adminUser')){
$this->redirect('/admin.php?c=index');
}
$this->display();
} public function check(){
$username=$_POST['username'];
$password=$_POST['password'];
if(!trim($username)){
return jsonResult(0, '用户名不能为空');
}
if(!trim($password)){
return jsonResult(0, '密码不能为空');
} $ret=D('Admin')->getAdminByUsername($username);
if(!ret || $ret['status']!=1){
return jsonResult(0, '该用户不存在');
} if($ret['password']!=getMd5Password($password)){
return jsonResult(0, '用户名或密码错误');
} D("Admin")->updateByAdminId($ret['admin_id'],array('last_login_time'=>time()));
session('adminUser',$ret);
return jsonResult(1, '登录成功');
}
}
?>

  前端JS登录逻辑实现

var login={
check:function(){
//获取登录页面中的用户名 和 密码
var username=$('input[name="username"]').val(),
password=$('input[name="password"]').val();
if(!username){
dialog.error('用户名不能为空');
}
if(!password){
dialog.error('密码不能为空');
} var url="/index.php?m=admin&c=login&a=check",
data={
"username":username,
"password":password
};
var load = dialog.load();
$.post(url,data,function(result){
layer.close(load);
if(result.status==0){
return dialog.error(result.message);
}
if(result.status==1){
return dialog.success(result.message,'/admin.php?c=index');
}
},'JSON');
}
}

  今天就简单的做到这里了,项目的开始,造轮子的时间比较长,轮子造好了,车就可以开快了!(๑╹◡╹)ノ"""

源码地址:https://github.com/YoZiLin/TP-CMS

前端到后台ThinkPHP开发整站(2)的更多相关文章

  1. 前端到后台ThinkPHP开发整站--php开发案例

    前端到后台ThinkPHP开发整站--php开发案例 总结 还是需要做几个案例,一天一个为佳,那样才能做得快. 从需求分析着手,任务体系要构建好,这样才能非常高效. 转自: 前端到后台ThinkPHP ...

  2. 前端到后台ThinkPHP开发整站(6)

    今天终于把整个后台管理系统弄好了,其实没什么难点,只是作为一个Thinphp学习的练手项目,这个项目,现在还只能算是做了一半,还有前台展示方面的功能没有完成.先过一遍后台的功能吧! 1.首页 2.菜单 ...

  3. 前端到后台ThinkPHP开发整站(5)

    今天周五了,这个项目做了五个晚上了,明天周末不用上班有一整天的时间来结束这个项目了,今晚主要把后台界面给弄出来了. 大概的整个后台界面就是这个样子了,接下来的工作就是搬砖了,一个个菜单功能填上去就是了 ...

  4. 前端到后台ThinkPHP开发整站(4)

    今晚继续我的这个项目的开发,今晚也是写的不多,主要写了一个菜单管理功能的CURD方法,前端界面还没有进行编写. 菜单管理Model层的代码: <?php namespace Common\Mod ...

  5. 前端到后台ThinkPHP开发整站(1)

    1.前言: 我个人从来没有写过博客文章,作为一个程序员没有自己的博客算是一个合格的程序员,所以我地想想也要经营起一个的博客,做一个小项目,写这博客算就做这个项目的一个项目笔记吧!现在自学着ThinkP ...

  6. 前端到后台ThinkPHP开发整站(3)

    继续我的这个项目的第三晚的开发了,时间比较少,今晚写的代码不多,今晚仍然是造轮子写一个公共的控制器和一个公共的JS.直接上代码吧! 以下是一个公共的控制器,后台控制器都继承于它,构造函数中进行验证当前 ...

  7. 前端到后台ThinkPHP开发整站(7)

    今晚我继续这个项目的前台开发,把前台的做出来了,现在项目进行一个收尾工作了,还有栏目页和一个文章页的开发,做完这两个算是完成了.说到这里感觉有点松懈了,把剩下两个功能页面做完在吹吧,先看看今天弄的代码 ...

  8. 前端到后台ThinkPHP开发整站(完)

    久违了,今天终于抽空把最后的写完了,这是这个项目的最后一篇文章了,把前台的栏目控制器和文章内容控制器的功能实现了. 栏目控制器: <?php namespace Home\Controller; ...

  9. 前端资源多个产品整站一键打包&包版本管理(一)

    来新公司工作的第五个月.整站资源打包管理也提上了日程. 问题: 首先.什么是整站的打包管理呢? 我们公司的几个重要产品都在同一个webapp里面,但是,不同的开发部门独立开发不同的产品,长期以来,我们 ...

随机推荐

  1. commons-logging 结合 log4j, 初始化生命周期 初探

    -------commons-logging---------- Log log=LogFactory.getLog(clazz); LogFactory这是个抽象日志工厂,更像个工具? 通过线程上下 ...

  2. 文档模型(JSON)使用介绍

    一.背景 E.F.Codd在1970年首次提出了数据库系统的关系模型,从此开创了数据库关系方法和关系数据理论的研究,为数据库技术奠定了理论基础,数据库技术也开始蓬勃发展.而随着几大数据库厂商陆续发布的 ...

  3. <jsp:include>和<%@include%>的区别

    个人笔记(并非自己总结,而是从别人的博客上看到的) <jsp:include> :动态包含 1.<jsp:include>包含的是html文件 举例: DynamicInclu ...

  4. JS实现为控件添加倒计时功能

    一.概述 在有些报表需求中,需要为控件添加倒计时功能,限制到某一个时间点后能进行一项操作或不能进行某项操作,比如查询,导出功能等等,又需要人性化地显示还有多少时间,即倒计时功能,比如下图中我们限制这个 ...

  5. nodejs服务器部署教程二

    这篇文章主要介绍如何在服务端跑vuejs的项目,如果上一篇教程你成功输出了hello world,那这一篇更简单 首先你要有一个已经能在本地跑的基于vuejs的项目,我就以之前写的仿饿了么的项目为例来 ...

  6. 基于pytorch实现word2vec

    一.介绍 word2vec是Google于2013年推出的开源的获取词向量word2vec的工具包.它包括了一组用于word embedding的模型,这些模型通常都是用浅层(两层)神经网络训练词向量 ...

  7. Andorid源码系列:View的onTouchEvent()与performClick(),performLongClick()调用时机解析

    这是大土豆的第一篇博客,想着工作3年多了,在工作上从一名菜鸟逐渐成长为在项目中能干点事的人,自己对Android的见解也一步步加深,有必要写一些对Android代码和开发过程中的感悟,和广大朋友们分享 ...

  8. 或许你不知道的10条SQL技巧(转自58沈剑原创)

    这几天在写索引,想到一些有意思的TIPS,希望大家有收获. 一.一些常见的SQL实践 (1)负向条件查询不能使用索引 select * from order where status!=0 and s ...

  9. Android-Bluetooth Low Energy(BLE)

    Android Bluetooth Low Energy Android 低功耗蓝牙简介 2016-4-18 Android4.3(API 18)介绍了平台支持的低功耗蓝牙,app可用于发现设备,检索 ...

  10. css的背景background的相关属性

    今天需要做一个占满设备宽度的轮播图,这里作为demo仅展示一张图,下面分别是要操作的图片(这里做了缩放处理,实际的图比较大),以及要实现的效果图,很明显两者是不成比例的:      (图一)     ...