这是我在这里的第一个问题,我相信这个问题已经不存在了:)我搜索了,但没有成功。
好了,我有下一个问题。我需要一些想法如何在管理面板中做一个用户的权限。我想有一个超级管理员,管理员和操作员。这里的任何人都会有不同的特权。超级管理员将拥有所有特权,管理员部分和操作员的一些但不是全部将拥有相同的特权。为此,我需要一个后端逻辑。如何在没有很多if语句的情况下做到这一点,让我的代码看起来很漂亮?我使用自己编写的Smarty模板引擎和oop php。我将使用Smarty权限进行赋值,但是下一步呢?有没有人能给我一些点子或示例代码?
谢谢!
发布于 2012-08-10 23:34:13
使用MVC,这是一个相对简单的任务。在一个名为permissions
的表中创建不同的角色,然后在另一个名为user_permissions
的表中创建不同的角色,该表将user_id
连接到permission_id
。然后创建一个函数,可能是在一个名为has_role()
的user
类中。该函数接受两个参数:权限别名和最终的用户id。
如果您希望避免在视图中调用函数,可以在控制器中保存不同的变量,这些变量将传递给视图,例如:
$isAdmin = $user->has_role('admin');
$isOperator = $user->has_role('operator');
如果你只向管理员显示一些内容,你可以在你的视图中这样做:
<?php if($isAdmin): ?>
<p>Admin only content</p>
<?php endif; ?>
但是,如果您有仅限管理的页面,只需将
if(! $this->user->has_role('role')) {
header("Location: /index.php");
die();
}
就能达到目的。当然,所有这一切都可以在没有MVC部分的情况下完成,但是有了它,它就变得更干净了。
发布于 2012-08-10 23:28:11
也许您可以通过拆分管理视图(假设每种类型的用户获得不同的UI体验),然后根据用户的权限包含正确的文件来做到这一点?
Tbh,如果不知道OOP框架的工作原理,就很难回答这个问题,因为这将定义您如何解决问题。
发布于 2012-08-10 23:51:36
class Session {
public static function init() {
@session_start();
}
public static function set($key, $value) {
$_SESSION[$key] = $value;
}
public static function get($key) {
if (isset($_SESSION[$key])) {
return $_SESSION[$key];
}
}
public static function destroy() {
//unset($_SESSION);
session_destroy();
}
}
稍后,您可以在登录php中设置角色,即从mysql获得的$data' role‘:
Session::init();
Session::set('role', $data['role']);
并检查角色的使用情况,例如:
$role = Session::get('role');
if ($role != 'owner') {
Session::destroy();
header('location: '.URL.'login');
exit;
}
https://stackoverflow.com/questions/11910467
复制相似问题