php后台多用户权限组思路与实现程序代码

网站开发少不了有网站后台,有了后台自然要对用户有同角色来分配一下,特别是多用户系统的情况下,如我一个系统要有多个管理员,那么我这些管理要分成,编辑,友情连接,管理员等,那我们要有权限和角色分配,今天我们就来看我以前做的一个系统吧。

先介绍一下文件,

adminconfig.php 这是后台系统中所有文件权限配置。

fun.php 这是一个功能函数

left.php 网站后台根据用户登录的ID来加载相对应的功能菜单

op.php 调用adminconfig.php 默认权限文件

opsava.php  保存用户权限成一个php文件

好了我们先来看看 fun.php文件吧。

 代码如下 复制代码

<?
function findsub($keys ,$userid=‘abc‘ ) //此函数重要就是为了调用用户的权限信息
{
 include(‘user/‘.$userid.‘.php‘); 
 foreach($bb as $key=>$submenu)
 {    
  foreach($submenu  as $subkey=>$menuitem)
  {
   if( $subkey == $keys )
   {
    return 1;    
   }
  }  
 }
}

//下面为生成用户的php权限文件
//写入
function cache_write($name, $var, $values) {
 $cachefile = ‘op/user/‘.$name.‘.php‘;
 $cachetext = "<?phprn".‘$‘.$var.‘=‘.arrayeval($values)."rn?>";
 if(!swritefile($cachefile, $cachetext))
 {
  exit("File: $cachefile write error.");
 }
}

//数组转换成字串
function arrayeval($array, $level = 0) {
$space = ‘‘;
 for($i = 0; $i <= $level; $i++) {
  $space .= "t";
 }
$evaluate = "Arrayn$space(n";
$comma = $space;
 foreach($array as $key => $val) {
  $key = is_string($key) ? ‘‘‘.addcslashes($key, ‘‘‘).‘‘‘ : $key;
  $val = !is_array($val) && (!preg_match("/^-?d+$/", $val) || strlen($val) > 12) ? ‘‘‘.addcslashes($val, ‘‘‘).‘‘‘ : $val;
  if(is_array($val)) {
   $evaluate .= "$comma$key => ".arrayeval($val, $level + 1);
  } else {
   $evaluate .= "$comma$key => $val";
  }
   $comma = ",n$space";
 }
  $evaluate .= "n$space)";
  return $evaluate;
}

//写入文件
function swritefile($filename, $writetext, $openmod=‘w‘) {
 if(@$fp = fopen($filename, $openmod)) {
  flock($fp, 2);
  fwrite($fp, $writetext);
  fclose($fp);
  return true;
 } else {
  exit("File: $filename write error.");
  return false;
 }
}

?>

adminconfig.php 后台权限配置文件,以一个数组形式保存

 代码如下 复制代码

<?
$menus = array(
 
  ‘news‘ => array(
   ‘caption‘=>‘资讯管理‘,
   ‘icon‘=>‘admin/icon_15.gif‘,
   ‘sub‘ => array(
    ‘newsaddtype‘ => array(‘caption‘ => ‘分类增加‘, ‘url‘ => ‘news/addtype.php‘),
    ‘newstypemange‘ => array(‘caption‘ => ‘分类管理‘, ‘url‘ => ‘news/typemange.php‘),    
    ‘newsnewsend‘ => array(‘caption‘ => ‘发布资讯‘, ‘url‘ => ‘news/newsend.php‘),
    ‘newsnewmange‘ => array(‘caption‘ => ‘资讯管理‘, ‘url‘ => ‘news/newmange.php‘),
    ‘newscomments‘ => array(‘caption‘ => ‘评论管理‘, ‘url‘ => ‘news/comments.php‘),
    
   ),
  ),
  
  ‘ask‘ => array(
   ‘caption‘=>‘问卷调查‘,
   ‘icon‘=>‘admin/icon_15.gif‘,
   ‘sub‘ => array(
    ‘voteadmin_subject_add‘ => array(‘caption‘ => ‘添加投票主题‘, ‘url‘ => ‘vote/admin_subject_add.php‘),
    ‘voteadmin_subject‘ => array(‘caption‘ => ‘管理投票主题‘, ‘url‘ => ‘vote/admin_subject.php‘),
    ‘voteadmin_title_add‘ => array(‘caption‘ => ‘添加投票问题‘, ‘url‘ => ‘vote/admin_title_add.php‘),
    ‘voteadmin_title‘ => array(‘caption‘ => ‘管理投票问题‘, ‘url‘ => ‘vote/admin_title.php‘),
    ‘voteadmin_question_add‘ => array(‘caption‘ => ‘添加投票答案‘, ‘url‘ => ‘vote/admin_question_add.php‘),
    ‘voteadmin_question‘ => array(‘caption‘ => ‘管理投票答案‘, ‘url‘ => ‘vote/admin_question.php‘),
    ‘voteadmin_system‘ => array(‘caption‘ => ‘投票初始配置‘, ‘url‘ => ‘vote/admin_system.php‘)
   ),
  ),
  ‘ads‘ => array(
   ‘caption‘=>‘广告管理‘,
   ‘icon‘=>‘admin/icon_15.gif‘,
   ‘sub‘ => array(
    ‘ada‘ => array(‘caption‘ => ‘增加广告‘, ‘url‘ => ‘ada.php‘),
    ‘adm‘ => array(‘caption‘ => ‘广告管理‘, ‘url‘ => ‘adm.php‘),   
    ‘flashadd‘ => array(‘caption‘ => ‘焦点图广告增加‘, ‘url‘ => ‘flashadd.php‘),
    ‘flashad‘ => array(‘caption‘ => ‘焦点图广告管理‘, ‘url‘ => ‘flashad.php‘)
   ),
  ), 
  
  
  ‘mange‘ => array(
   ‘caption‘=>‘系统管理员‘,
   ‘icon‘=>‘admin/icon_15.gif‘,
   ‘sub‘ => array(
    ‘adminuser‘ => array(‘caption‘ => ‘管理员添加‘, ‘url‘ => ‘adminuser.php‘),
    ‘modpass‘ => array(‘caption‘ => ‘密码修改‘, ‘url‘ => ‘modpass.php‘)    
   ),
  ),
 );
?>

left.php文件很简单就是根据用户登录后ID读出权限

 代码如下 复制代码

<?
$userid = $_SESSION[‘adminid‘];
include("op/admincofig.php");
include("op/user/".$userid.".php");

foreach($bb as $key=>$submenu)
{    
 echo
"<tr><td  bgcolor="#D879A7"
style="line-height:22px;text-align:center;color:#ffffff;"> nr
<font color="#EA6A8D"
face="Webdings"></font><b>".$menus[$key][‘caption‘]."</b><br
/></td></tr> nr <tr ><td bgcolor="F5E8F1">";
 foreach($submenu  as $subkey=>$menuitem)
 {
  $tmparr = explode("|",$menuitem);
  echo
"<font color="#EA6A8D" face="Webdings">4</font><a
href=‘".$tmparr[1]."‘
target="mainframe">".$tmparr[0]."</a><br> nr";
 }
 echo "</td></tr> nr "; 
}

如图

op.php这个文件就是要调用我们的adminconfig.php文件,然后利用fun.php文件中函数把提供过来的数据保存成数组如图

点击保存我们调用了opsava.php 文件,代码如下

 代码如下 复制代码

<?
include("op/fun.php");
if( $_POST )
{
 $sarray =  $_POST ;
 cache_write($userid,‘bb‘,$sarray);//写入缓存
 echo "<script>alert(‘编辑保存成功!‘);location=‘op.php?userid=".$userid."‘;</script>";

}
?>

保存成功后文件内容如

 代码如下 复制代码

<?php
$bb=Array
 (
 ‘member‘ => Array
  (
  ‘user_search‘ => ‘会员升级管理|user_search.php‘
  ),
 ‘membercy‘ => Array
  (
  ‘cyuser_search‘ => ‘会员升级管理|cyuser_search.php‘,
  ‘cyuser_search5‘ => ‘交友会员|cyuser_search.php?grade=5‘
  ),
 ‘userid‘ => 7,
 ‘button‘ => ‘保存编辑‘
 )
?>

这样的话我们的left只要加载 7.php文件就只会显示这里在的文件,这样一个基本的后台权限就完成了。

原站原创教程转载注明来源:http://www.php100.com/phper/php.html

时间: 2024-11-13 09:53:07

php后台多用户权限组思路与实现程序代码的相关文章

Web应用程序系统的多用户权限控制设计及实现-栏目模块【8】

前五章均是从整体上讲述了Web应用程序的多用户权限控制实现流程,本章讲述Web权限管理系统的基本模块-栏目模块.栏目模块涉及到的数据表为目录表. 1.1分组域 为了更规范和方便后期系统的二次开发和维护,对应特定的业务模块采用Area(域)的方式开发,栏目模块的开发域如下图所示: 由于在Areas下还建立了一个新的目录SystemManage,故需要改变原来的路由.栏目模块的路由文件名称为pageGroupAreaRegistration.改变路由代码的文件名称为如下: using System.

jsp的权限控制思路

这两天接触的一个项目的权限控制思路,控制页面权限.action权限.页面内容权限 1用户 2角色 3权限组 4权限 5菜单 权限控制的5个基本模块: 用户: 用户与角色关联 角色: 角色与权限关联 给角色赋予权限:将所有权限列出: 权限组:用于归类权限 权限: 权限可以是一个菜单(当权限的url和菜单的url相同时即为菜单权限) 获取菜单列表时根据权限过滤菜单: if (menuUrl.equals(auth.getUrl()) || (user!=null && user.getId()

Web应用程序系统的多用户权限控制设计及实现-用户模块【7】

前五章均是从整体上讲述了Web应用程序的多用户权限控制实现流程,本章讲述Web权限管理系统的基本模块-用户模块.用户模块涉及到的数据表为用户表. 1.1分组域 为了更规范和方便后期系统的二次开发和维护,对应特定的业务模块采用Area(域)的方式开发,用户模块的开发域如下图所示: 由于在Areas下还建立了一个新的目录SystemManage,故需要改变原来的路由.用户模块的路由文件名称为OperatorManageAreaRegistration.改变路由代码的文件名称为如下: using Sy

使用Camera进行拍照 &amp; 后台静默拍照的思路

Android中的Camera可以用来进行自定义相机.取景框实时预览.拍照等操作.在5.0中,这个类不推荐使用了,新出了一个Camera2,那个东西没怎么研究过,反正一时半会用不到.本篇讲解的是如果用这个对象进行拍照,最后在提及下如何进行后台的静默拍照. API翻译:http://bbs.51cto.com/thread-1063856-1.html(挺简单易懂的) 一.CameraManager 这个类是我自己封装的,不是API提供的.我在这里封装了打开相机,获取相机ID,保存拍照图片的操作.

AndroidManifest.xml系统权限组

public static final String ACCOUNTS 这个常量定义了直接访问由账号管理器管理的账号的权限 常量值:android.permission-group.ACCOUNTS. public static final String COST_MONEY 这个常量定义了能够让用户使用产生间接服务功能的权限.例如,这个权限组允许直接进行电话拨号.直接发送SMS消息等. 常量值:android.permission-group.COST_MONEY. public static

ASP.NET通用权限组件思路设计

开篇 做任何系统都离不开和绕不过权限的控制,尤其是B/S系统工作原理的特殊性使得权限控制起来更为繁琐,所以就在想是否可以利用IIS的工作原理,在IIS处理客户端请求的某个入口或出口通过判断URL来达到控制权限的目的,这样就可以减少通常要在每个页面或按钮都要添加的权限验证代码. 通常的权限验证模式 一般的权限验证会控制到菜单(页面)就可以满足,复杂一点的会要求控制到按钮(功能点),这个都需要做一下几点工作: 1.按权限生成菜单,这是所有系统都要做的: 2.在每个页面的开始处添加登录和权限的验证,调

基于Vue实现后台系统权限控制

原文地址:http://refined-x.com/2017/08/29/基于Vue实现后台系统权限控制/,转载请注明出处. 用Vue/React这类双向绑定框架做后台系统再适合不过,后台系统相比普通前端项目除了数据交互更频繁以外,还有一个特别的需求就是对用户的权限控制,那么如何在一个Vue应用中实现权限控制呢?下面是我的一点经验. 权限控制是什么 在权限的世界里服务端提供的一切都是资源,资源可以由请求方法+请求地址来描述,权限是对特定资源的访问许可,所谓权限控制,也就是确保用户只能访问到被分配

nagios 多用户权限管理---特定用户访问特定主机或服务

nagios 多用户权限管理---特定用户访问特定主机或服务1.nagios安装????????????------------2.添加用户和密码htpasswd?/usr/local/nagios/etc/htpasswd.users?eddy 3.修改配置vim?/usr/local/nagios/etc/cgi.cfguse_authentication=1authorized_for_read_only=eddy 4.添加联系人vi?/usr/local/nagios/etc/objec

auth_group权限组管理

1.权限组的表分析 auth_group  ---  是存储权限分组 auth_permission --- 存放用户可以使用那个表 auth_group_permission --- 连接权限分组和能使用权限的表 auth_users_group --- 连接用户信息表和权限分组表 后台的功能实现 # 在apps/admin/views.py中创建如下类: class GroupsManageView(View): """ /admin/groups/ 渲染页面和发送前端展