主頁 > 後端開發 > 簡單的權限管理php

簡單的權限管理php

2020-09-22 21:44:28 後端開發

轉發自https://www.cnblogs.com/shenzikun1314/p/6604867.html#4262295

 

  • 首先,要明白的基礎理論是用戶,角色,權限之間的關系是一對多,還是多對多,據此來建立表,

 

一個用戶可以屬于多個角色,比如鄧超,他是孫儷的丈夫,同時是他小孩的父親,還是他老爸的兒子,那么這里他一共有丈夫,父親,兒子3個角色,

一個角色可以有多個用戶,比如學生(角色),張三,李四,王五等,

所以用戶跟角色是多對多的關系,

 

一個角色可以多個權限,比如把文章模塊分為查看,修改,添加,洗掉這4個權限,普通用戶只有查看的權限,但管理員他可以同時有這4個權限,

一個權限也可以被多個角色同時擁有,普通用戶和管理員都有查看權限,

所以權限跟角色也是多對多的關系,


 

 

  • 下面開始建表

第一張用戶表

 

 

 

第二張角色表

 

 

 

 第三張權限表

 

 

 接下來是2張中間表,

用戶-角色表(要設定多對多的外鍵關聯關系)

 

 

 最后一張角色-權限表(設定多對多的關聯關系)

 

 

 


 

  • 接下來是代碼

第一個guanli.php,用到ajax等jquery語法,要參考jquery檔案,這個頁面是修改用戶的角色權限

 

 

 

<?php
error_reporting(E_ALL ^ E_DEPRECATED);
        include("DB.class.php");
        $sql = "select * from qx_user";
        $arr = $dao->getAll($sql);
        // var_dump($arr);
        // exit;
        $sql = "select * from qx_juese";
        $arr2 = $dao->getAll($sql);
        foreach($arr as $v){
            // var_dump($v);
            // exit;
        }
        ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題檔案</title>
        <script src="https://www.cnblogs.com/mzzone/p/assets/js/jquery-1.8.2.min.js"></script>

<!-- <script src="https://www.cnblogs.com/dist/js/jquery-1.11.2.min.js"></script> -->
</head>

<body>

<h1>用戶與角色管理</h1>
<div>
請選擇用戶:
    <select id="user">
        <?php foreach($arr as $v){
        //     var_dump($v);
        // exit;
         ?>

            <option value="https://www.cnblogs.com/mzzone/p/<?php echo"$v[id]" ?>"> <?php echo "$v[username]";?></option>
        <?php } ?>
    </select>
</div>
<br />
<div>
請選擇角色:

<?php foreach($arr2 as $v2){ ?>
<input type='checkbox' value="https://www.cnblogs.com/mzzone/p/<?php echo"$v2[id]" ?>" class='ck' /><?php echo "$v2[juese_name]" ?>
        <?php } ?>

</div>
<br />

<input type="button" value="https://www.cnblogs.com/mzzone/p/確定" id="btn" />

</body>
<script type="text/javascript">
$(document).ready(function(e) {
    //選中默認角色
    Xuan();
    //當用戶選中變化的時候,去選中相應角色
    $("#user").change(function(){
            Xuan();
        })
    //點擊確定保存角色資訊
    $("#btn").click(function(){
            var uid = $("#user").val();
            var juese = "";
            var ck = $(".ck");
            for(var i=0;i<ck.length;i++)
            {
                if(ck.eq(i).prop("checked"))
                {
                    juese += ck.eq(i).val()+"|";
                }
            }
            juese = juese.substr(0,juese.length-1);
            $.ajax({
                    url:"chuli.php",
                    data:{uid:uid,juese:juese,type:1},
                    type:"POST",
                    dataType:"TEXT",
                    success: function(data){
                            alert("保存成功!");
                        }
                });
        })
});
//選中默認角色
function Xuan()
{
    var uid = $("#user").val();
    $.ajax({
        url:"chuli.php",
        data:{uid:uid,type:0},
        type:"POST",
        dataType:"TEXT",
        success: function(data){
                // var juese = data.trim().split("|");
                // var ck = $(".ck");
                // ck.prop("checked",false);
                // for(var i=0;i<ck.length;i++)
                // {
                //     if(juese.indexOf(ck.eq(i).val())>=0)
                //     {
                //         ck.eq(i).prop("checked",true);
                //     }
                // }
                // console.log(data);
                var obj = eval('(' + data + ')');
                console.log(obj);
                var str="";
                for(var i=0;i<obj.length;i++){
                    str+=" ";
                    str+=obj[i].juese_id;
                }
                str=$.trim(str)
                console.log($.trim(str));

                var ck = $(".ck");
                ck.prop("checked",false);
                for(var i=0;i<ck.length;i++)
                {
                    if(str.indexOf(ck.eq(i).val())>=0)
                    {
                        ck.eq(i).prop("checked",true);
                    }
                }
                
            }
        });
}
</script>
</html>

第二個登錄頁面login.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題檔案</title>
</head>

<body>
<h1>登錄頁面</h1>
<form action="logincl.php" method="post">
<input type="text" name="username" />
<input type="password" name="pwd" />
<input type="submit" value="登錄" />
</form>
</body>
</html>

第三個頁面處理登錄頁面logincl.php

<?php
header('content-type: text/html; charset=utf-8');
session_start();
include("DB.class.php");
$username = $_POST["username"];
$pwd = $_POST["pwd"];
  // $uid=$_POST["uid"];

// $sql="select pwd from qx_user where uid='{$uid}'";
// $mm = $dao->getOne($sql); 

// if($mm==$pwd && !empty($pwd))
// {
//     $_SESSION["uid"]=$uid;
//     header("location:main.php");
// }


$username = $_POST['username'];
  // 獲取post傳過來的密碼
   $password = $_POST['pwd'];
 

 $sql = "select * from qx_user where username = '$username' and pwd = '$pwd' ";
 $res = $dao->getRow($sql);



  
     if($res){//如果存在,跳回本頁面
        $_SESSION['username'] = $username;
        $_SESSION["uid"]=$res["id"];

          echo '<script language="JavaScript">;
          alert("登錄成功");location.href="https://www.cnblogs.com/mzzone/p/main.php";</script>;';
          
          exit;

         
     }else{//如果不存在
        
        echo '<script language="JavaScript">;
          alert("登錄失敗");</script>;';
        
        //注冊成功之后跳轉到指定頁面
        echo "<script>location.href='https://www.cnblogs.com/mzzone/p/#'</script>";
     }

第4個頁面查看權限main.php,輸出登錄的用戶的所有權限u1和u2對比

 

 

第二次登錄u2

 

 

 

<?php  session_start(); ?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題檔案</title>
</head>

<body>

<h1>
當前用戶:<?php echo "$_SESSION[username]";?>
</h1>
<?php
error_reporting(E_ALL ^ E_DEPRECATED);

// session_start();
include("DB.class.php");

if(empty($_SESSION["uid"]))
{
    header("location:qx_login.php");
    exit;
}
//登錄者用戶名
$uid = $_SESSION["uid"];


//根據用戶名查角色
$sjs = "select juese_id from qx_user_juese where user_id='{$uid}'";
$ajs = $dao->getAll($sjs);
// var_dump($ajs);
// exit;
//定義一個存放功能代號的陣列
$arr = array();
//根據角色代號查功能代號
foreach($ajs as $vjs)
{
        $jsid = $vjs['juese_id']; //角色代號
        $sgn = "select quanxian_id from qx_js_qx where juese_id='{$jsid}'";
        $strgn = $dao->getAll($sgn);
        // $agn = explode("|",$strgn);
        // var_dump($strgn);
        // echo "xxx";
        // exit;
        foreach($strgn as $vgn)
        {
            
            array_push($arr,$vgn['quanxian_id']);

            
        }    
}

//去重,顯示
// var_dump($arr);
//         exit;
$arr = array_unique($arr);
// var_dump($arr);
//         exit;
foreach($arr as $v)
{
    $sql = "select * from qx_quanxian where id='{$v}'";
    $attr = $dao->getRow($sql);

    
    
     // var_dump($attr);
     //     exit;
     // echo "{$attr['id']},{$attr['qx_name']}";
     echo "<div code='{$attr["id"]}'>{$attr["qx_name"]}</div>";
    // <input type='checkbox' value="https://www.cnblogs.com/mzzone/p/$attr[id]" class='ck' />
        
}

?>



</body>
</html>

第5個工具類代碼DB.class.php,在建構式__construct()中修改默認的配置引數,資料庫名,用戶名,密碼等,否則會連接資料庫失敗,

<?php
// namespace Frame\libs;
class DB{
    //主機地址
    var $host;
    //用戶名
    var $username;
    //密碼
    var $password;
    //資料庫名
    var $dbname;
    //字符集
    var $charset;
    //資料庫連接物件,主要用在mysql_query($sql,$this->con);
    private $con;
    //外界獲取的mysqlDB類操作物件
    public static $dao;
    //獲得mysqlDB類物件(單例)
    public static function getInstance($config){
        if(!isset(self::$dao)){
            self::$dao = new self($config);
        }
        return self::$dao;
    } 
    //private禁止外部new,減少new帶來的開銷,并設定默認的配置,
    private function __construct($config){
        $this->host = isset($config['host'])?$config['host']:'localhost';
        $this->port = isset($config['port'])?$config['port']:'3306';
        $this->username = isset($config['username'])?$config['username']:'root';
        $this->password = isset($config['password'])?$config['password']:'root';
        $this->dbname = isset($config['dbname'])?$config['dbname']:'bishe';
        $this->charset = isset($config['charset'])?$config['charset']:'utf8';
        //連接資料庫
        $this->con = $this->connect();
        //設定資料庫名,默認為test
        $this->useDb($this->dbname);
        //設定字符集,默認為utf8, 
        $this->setCharset($this->charset);

    }
    //禁止外部克隆
    private function __clone(){

    }
    //連接不成功在這個分段找,
    //////////////////////////////////////////////////////
    //連接資料庫
    public function connect(){
         $con = 
        mysql_connect("$this->host:$this->port","$this->username","$this->password") or die("連接資料庫失敗");
        return $con;
    }
    //1.執行增、刪、改sql陳述句 
    public function exec($sql){
        $res = mysql_query($sql,$this->con);
        if($res){
             // echo "<br/>sql陳述句:".$sql."<br>";
             // var_dump($res);
             return true;
             
            //要是增刪改有問題可以在這里輸出sql除錯,
        }else{
            echo "<br/>sql陳述句:".$sql;
            echo "<br/出錯資訊>:".mysql_error();
            echo "<br/出錯代碼>:".mysql_errno();
            exit;
        }
    }
    //額外設定字符集
    public function setCharset($charset){
        $sql = "set names '$charset'";
        $this->exec($sql) or die("set");
        //die();
    }
    //額外設定資料庫
    public function useDb($dbname){
        $sql = "use $dbname";
        $this->exec($sql) or die("use");//or die()函式前面需回傳對應的true或false;
    }
    ////////////////////////////////////////////////////////
    //查找出錯在這個部分找,
    //4.將查到的結果集轉為單個資料,這里是索引陣列的第一個欄位,
    public function getOne($sql){
        $rec = mysql_query($sql,$this->con);
        $res = mysql_fetch_row($rec);
        if($res){
            return $res[0];
        }else{
            return false;
        }
    }
    //可能修改的函式全部放在上面,以便查找,下方函式基本不會修改,
    //編號1~4是高頻率使用的函式,
    //2.獲取一行資料(一維)
    public function getRow($sql){
        $rec = mysql_query($sql,$this->con);
        $res = mysql_fetch_assoc($rec);
        if($res){
            return $res;
        }else{
            return false;
        }
    }
    //3.獲取所有資料(二維)
    public function getAll($sql){
        $rec = mysql_query($sql,$this->con);
        $arr = array();//定義 一個陣列
        while($res = mysql_fetch_assoc($rec)){
            $arr[] = $res;
        }
        if($arr){
            return $arr;
        }else{
            return false;
        }
    }

}

$dao = DB::getInstance(null);
?>

第6個chuli.php.這個頁面是用來處理guanli.php發過來的ajax請求,

<?php
error_reporting(E_ALL ^ E_DEPRECATED);

include("DB.class.php");


$type = $_POST["type"];

switch($type)
{
    case 0:
        $uid = $_POST["uid"];
        $sql = "select juese_id from qx_user_juese where user_id='{$uid}'";
        $data = $dao->getAll($sql);
        // $id_list="xx";
        // foreach($data as $v)
        // {
            
        //     $id_list =","+"$v[juese_id]";

        //     echo json_encode($id_list);
        //     exit;


        // }
            // echo json_encode($data);

        echo json_encode($data);
        break;
    case 1:
        $uid = $_POST["uid"];
        $juese = $_POST["juese"];
        $sdel = "delete from qx_user_juese where user_id='{$uid}'";
        $dao->exec($sdel);
        $arr = explode("|",$juese);
        foreach($arr as $v)
        {
            // echo $v;
            $sql = "insert into qx_user_juese values('{$uid}','{$v}')";
            $dao->exec($sql);
        }
        echo "OK";
        break;
}
  • 總結

難點是guanli頁面的ajax請求,

 

 

js決議二維陣列

 

 

 

 

 

 

 

 

(完)

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/107477.html

標籤:PHP

上一篇:【Linux系列】Centos 7安裝 PHP(四)

下一篇:Excel匯入資料庫(php版)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more