前端到後臺ThinkPHP開發整站(2)

来源:http://www.cnblogs.com/lzy138/archive/2017/07/18/7197978.html
-Advertisement-
Play Games

我這次使用的ThinkPHP版本是:3.2.3版本,還有會使用到一個彈出層插件,叫 layer,官網地址是:http://layer.layui.com/。廢話不多說,進入擼碼環節。 1、通用方法編寫 這個是後端公共方法,現在暫時寫兩個方法,再往後開發想到有需要的話,就會繼續添加更多的公共方法。 公 ...


  我這次使用的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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 正題前的嘮叨 本人是才出來工作不久的小白菜一顆,技術很一般,總是會有遇到一些很簡單的問題卻不知道怎麼做,這些問題可能是之前解決過的。發現這個問題,想著提升一下自己的技術水平,將一些學的新的‘好’東西記錄下來,一是加深印象;二是以後可以作為參考;三是希望博友們可以提出不足和可以優化的地方,一起討論。 ...
  • 眾所周知,我們在寫程式的時候,好習慣是在重要的代碼打上日誌。以便監控程式運行的性能和記錄可能發生的錯誤。但是,如果日誌是基於同步IO文件操作,那麼就必須考慮到訪問總次數或併發數目。如果總次數或併發數目非常大,比如10W或者1K/s 或更多,那麼就要註意IO的同步性能對程式速度的拖慢效應了。 這個時候 ...
  • 本期同樣帶給大家分享的是阿笨在實際工作中遇到的真實業務場景,請跟隨阿笨的視角去如何採用基於開源組件SmartThreadPool線程池技術實現多任務批量處理。在工作中您是否遇到過如何快速高效的處理Job任務列表、如何通過多線程批量處理訂單、如何多線程群發簡訊、如何批量上傳圖片到遠程圖片伺服器或者雲存... ...
  • 最近單位開發一個項目,其中需要用到自動升級功能。因為自動升級是一個比較常用的功能,可能會在很多程式中用到,於是,我就想寫一個自動升級的組件,在應用程式中,只需要引用這個自動升級組件,並添加少量代碼,即可實現自動升級功能。因為我們的程式中可能包含多個類型的文件,比如exe、dll、 config、xm... ...
  • 本期同樣帶給大家分享的是阿笨在實際工作中遇到的真實業務場景,請跟隨阿笨的視角去如何實現採用微軟的ASP.NET OWIN技術承載WebAPI服務,如果您對本期的教程內容感興趣,那麼請允許讓阿笨帶著大家一起學習吧! 廢話不多說,直接上乾貨,我們不生產乾貨,我們只是乾貨的搬運工。 ...
  • 註解是jdk1.5新增的特性.大家都知道,jdk1.5在java的發展史上有著劃時代的意義.而註解的出現,在某種程度上顛覆了框架的設計.比如,spring在註解出現後,改善了原先五大組件的模式,增加了基於註解的實現方式.現在重點講講註解的使用. 元註解: jdk1.5定義了4個元註解,元註解的作用是 ...
  • 字元串轉換成其他基本類型,以及包裝類的自動裝箱、拆箱 ...
  • Desert King Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 26009 Accepted: 7219 Description David the Great has just become the king of a ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...