[Module User] - Thư viện Role
Tiếp tục series xây dựng project với PHP căn bản thì trong bài này mình sẽ viết thư viện xử lý phân quyền và kiểm tra trạng thái đăng nhập. Tại sao mình lại viết thành một thư viện? Tại vì tất cả các thao tác trong admin đều phải kiểm tra chức vụ của người dùng rồi mới tiến hành xử lý.

1. Viết thư viện phân quyền Role
Tất cả các hàm liên quan đến phân quyền mình sẽ đặt trong file libs/role.php. Bạn mở file này lên và nhập nội dung sau vào:
// Hàm thiết lập là đã đăng nhập
function set_logged($username, $level){
    session_set('ss_user_token', array(
        'username' => $username,
        'level' => $level
    ));
}
// Hàm thiết lập đăng xuất
function set_logout(){
    session_delete('ss_user_token');
}
// Hàm kiểm tra trạng thái người dùng đã đăng hập chưa
function is_logged(){
    $user = session_get('ss_user_token');
    return $user;
}
// Hàm kiểm tra có phải là admin hay không
function is_admin(){
    $user  = is_logged();
    if (!empty($user['level']) && $user['level'] == '1'){
        return true;
    }
    return false;
}
Bài viết này được đăng tại [free tuts .net]
Mình sẽ giải thích sơ lược các hàm trong thư viện.
Hàm thiết lập trạng thái đăng nhập:
function set_logged($username, $level){
    session_set('ss_user_token', array(
        'username' => $username,
        'level' => $level
    ));
}
Đối với mỗi người dùng chúng ta sẽ lưu hai thông tin là tên đăng nhập và cấp độ. Để lưu thông tin người dùng thì ta phải sử dụng đến thư viện Session lưu với key là ss_user_token.
Hàm thiết lập đăng xuất:
function set_logout(){
    session_delete('ss_user_token');
}
Để thiết lập đăng xuất ta chỉ việc sử dụng Session để xóa đi key ss_user_token.
Hàm kiểm tra trạng thái đăng nhập:
function is_logged(){
    $user = session_get('ss_user_token');
    return $user;
}
Để kiểm tra trạng thái đăng nhập thì ta sẽ kiểm tra giá trị Session của key ss_user_token có tồn tại hay không.
Hàm kiểm tra có phải là admin hay không:
function is_admin(){
    $user  = is_logged();
    if (!empty($user['level']) && $user['level'] == '1'){
        return true;
    }
    return false;
}
Để kiểm tra người dùng có phải là admin hay không thì ta kiểm tra level nếu bằng 1 là admin và ngược lại không phải là admin.
2. Lời kết
Như vậy là mình đã viết xong thư viện quản lý phân quyền và đăng nhập của người dùng. Bài tiếp theo chúng ta sẽ tìm hiểu về file bootstrap admin/index.php.

 Xây dựng chức năng đăng nhập và đăng ký với php và mysql
            Xây dựng chức năng đăng nhập và đăng ký với php và mysql         Bảng mã ASCII chuẩn các hệ nhị phân - thập phân - thập lục phân
            Bảng mã ASCII chuẩn các hệ nhị phân - thập phân - thập lục phân         Cách khai báo biến trong PHP, các loại biến thường gặp
            Cách khai báo biến trong PHP, các loại biến thường gặp         Bài 26: Hàm isset() và empty() trong php
            Bài 26: Hàm isset() và empty() trong php         Các kiểu dữ liệu trong PHP và các loại biến tương ứng
            Các kiểu dữ liệu trong PHP và các loại biến tương ứng         Bài 19: Phương thức GET và POST trong php
            Bài 19: Phương thức GET và POST trong php         Download và cài đặt Vertrigo Server
            Download và cài đặt Vertrigo Server         Bài 20: Các hàm xử lý chuỗi trong php
            Bài 20: Các hàm xử lý chuỗi trong php         Thẻ li trong HTML
                Thẻ li trong HTML             Thẻ article trong HTML5
                Thẻ article trong HTML5             Cấu trúc HTML5: Cách tạo template HTML5 đầu tiên
                Cấu trúc HTML5: Cách tạo template HTML5 đầu tiên             Cách dùng thẻ img trong HTML và các thuộc tính của img
                Cách dùng thẻ img trong HTML và các thuộc tính của img             Thẻ a trong HTML và các thuộc tính của thẻ a thường dùng
                Thẻ a trong HTML và các thuộc tính của thẻ a thường dùng             
                