亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mayfish 數(shù)據(jù)入庫驗證代碼

 更新時間:2010年04月30日 10:54:39   作者:  
mayfish 可以靈活的自定義將要執(zhí)行寫入的數(shù)據(jù)內容的校驗規(guī)則,以減少開發(fā)人員手動對每一個字段的數(shù)據(jù)進行校驗的麻煩。
一般在把數(shù)據(jù)寫入數(shù)據(jù)庫之前,先對將要寫入的數(shù)據(jù)進行校驗,可以避免出現(xiàn)比較嚴重的安全問題(例如一般性的SQL注入攻擊)。
mayfish 可以靈活的自定義將要執(zhí)行寫入的數(shù)據(jù)內容的校驗規(guī)則,以減少開發(fā)人員手動對每一個字段的數(shù)據(jù)進行校驗的麻煩。
例子如下:
一、首先定義數(shù)據(jù)庫模塊
復制代碼 代碼如下:

<?php
class MemberModel extends AppModel
{
/** 設置數(shù)據(jù)庫表名稱 **/
protected $tableName = "members";
/**
* 數(shù)據(jù)驗證規(guī)則
*/
protected $verify = array(
array("NotEmpty", "username", "用戶名不能留空"),
array("hasOne", "username", "此用戶已經(jīng)存在,請換另一個用戶名稱再試一次"),
array("NotEmpty", "password", "密碼不能留空"),
array("NotEmpty", "email", "郵箱地址不能留空"),
array("isEmail", "email", "郵箱地址格式不正確"),
array("hasOne", "email", "郵箱地址已經(jīng)被占用")
);
/**
* 覆蓋父類添加數(shù)據(jù)入庫的方法
* 先對用戶密碼進行md5加密,再調用父類的方法寫入數(shù)據(jù)庫中
*/
public function create($data) {
$data = array_map("addslashes", $data); //將數(shù)據(jù)中的標點符號(單、雙引號)進行安全轉義
$data["password"] = md5($data["password"]);
return parent::create($data);
}
}
?>

二、執(zhí)行數(shù)據(jù)寫入操作
復制代碼 代碼如下:

//執(zhí)行寫入數(shù)據(jù)的片段...
//執(zhí)行數(shù)據(jù)入庫的操作
private function PostData() {
$fields = array("username", "password", "email");
$post = array_map("trims", $_POST); //清除所有數(shù)據(jù)兩邊多余的空格
$post = parseHTML($post, $fields); //將指定的字段內容進行清除HTML處理
$data = parseFields($post, $fields); //提取可以寫入數(shù)據(jù)庫的字段(防止別人繞過你的頁面進行提交一些別有用心的數(shù)據(jù))
$DB = & M("member");
//進行數(shù)據(jù)驗證
if (!$DB->verify($data)) {
//驗證失敗,取出失敗的原因,并提交到模板頁面中
$this->assign("error", $DB->getVerifyError());
//把提交過來的數(shù)據(jù)也提交到模板中(用以實現(xiàn)用戶好像沒有離開過頁面的感覺)
$this->assign("default", $post);
//渲染注冊頁面模板
$this->display("/register.html");
}
else {
//寫入數(shù)據(jù)庫
$result = $DB->create($data);
//返回布爾型,說明數(shù)據(jù)寫入失敗,渲染注冊頁面模板
if (is_bool($result)) {
$this->assign("default", $post);
$this->display("/register.html");
}
else {
//注冊成功,渲染注冊成功頁面模板
$this->assign("username", $data["username"]);
$this->display("/reg_success.html");
}
}
}

可執(zhí)行驗證的規(guī)則有
NotEmpty 不能為空
Number 只能是整數(shù)
isEmail 郵箱地址是否正確
hasOne 是否是唯一(是否重復,是否已經(jīng)存在)
Regex 自定義正則表達式

驗證的格式為
array(驗證方法, 進行驗證的字段名稱, 驗證錯誤的提示信息)
對于正則表達示的驗證
array("Regex", "mobile", '/^13\d{9}$/', "用戶名不能留空") 

MayFish 下載

相關文章

  • PHP的runkit擴展如何使用

    PHP的runkit擴展如何使用

    PHP 運行的時候,也就是部署完成后,我們是不能修改常量的值,也不能修改方法體內部的實現(xiàn)的。也就是說,我們編碼完成后,將代碼上傳到服務器,這時候,我們想在不修改代碼的情況去修改一個常量的值是不行的。但是,runkit 擴展卻可以幫助我們完成這個功能。
    2021-05-05
  • PHP 函數(shù)學習簡單小結

    PHP 函數(shù)學習簡單小結

    下面是一些php下經(jīng)常用的函數(shù),都是些必須要知道的函數(shù),只有知道有個函數(shù)與功能,才可能組裝成完整的功能強大的系統(tǒng)。
    2010-07-07
  • PHP+Javascript實現(xiàn)在線拍照功能實例

    PHP+Javascript實現(xiàn)在線拍照功能實例

    這篇文章主要介紹了PHP+Javascript實現(xiàn)在線拍照功能的方法,涉及javascript插件的使用及php圖片上傳的相關實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • php瀏覽歷史記錄的方法

    php瀏覽歷史記錄的方法

    這篇文章主要介紹了php瀏覽歷史記錄的方法,涉及php操作cookie的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-03-03
  • PHP中文分詞的簡單實現(xiàn)代碼分享

    PHP中文分詞的簡單實現(xiàn)代碼分享

    對于中文搜索引擎來說, 中文分詞是整個系統(tǒng)最基礎的部分之一, 因為目前基于單字的中文搜索算法并不是太好。
    2011-07-07
  • php基礎知識:函數(shù)基礎知識

    php基礎知識:函數(shù)基礎知識

    php基礎知識:函數(shù)基礎知識...
    2006-12-12
  • php 使用redis鎖限制并發(fā)訪問類示例

    php 使用redis鎖限制并發(fā)訪問類示例

    本篇文章主要介紹了php 使用redis鎖限制并發(fā)訪問類,可以限制用戶請求,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-11-11
  • PHP 遠程文件管理,可以給表格排序,遍歷目錄,時間排序

    PHP 遠程文件管理,可以給表格排序,遍歷目錄,時間排序

    PHP 遠程文件管理,可以給表格排序,遍歷目錄,時間排序 點擊表格第一行,頭部就可以排序了,這個列子是當前目錄的
    2009-08-08
  • PHP帶節(jié)點操作的無限分類實現(xiàn)方法詳解

    PHP帶節(jié)點操作的無限分類實現(xiàn)方法詳解

    這篇文章主要介紹了PHP帶節(jié)點操作的無限分類實現(xiàn)方法,可實現(xiàn)無限分類及針對節(jié)點的添加、刪除、移動等功能,需要的朋友可以參考下
    2016-11-11
  • PHP開發(fā)過程中常用函數(shù)收藏

    PHP開發(fā)過程中常用函數(shù)收藏

    此中將收藏我在工作中用到的一些PHP函數(shù)。有自己寫的,也會有網(wǎng)上收集的。此文不斷更新中
    2009-12-12

最新評論