PHP background multi-user permission group ideas and implementation program code_PHP tutorial

WBOY
Release: 2016-07-20 11:10:50
Original
936 people have browsed it

Website development is indispensable with a website backend. With the backend, it is natural to assign the same roles to users, especially in the case of a multi-user system. If I have multiple administrators in a system, then my management needs to be divided into, edit, and Friendly connections, administrators, etc., then we need to have permissions and role assignments. Today we will take a look at a system I made before.

First introduce the file,

adminconfig.php This is the permission configuration of all files in the background system.

fun.php This is a functional function

left.php The website background loads the corresponding function menu according to the user's login ID

op.php calls adminconfig.php Default permissions file

opsava.php Save user permissions into a php file

Okay, let’s take a look at the fun.php file first.

The code is as follows Copy code
 代码如下 复制代码

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 = "";
 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;
 }
}

?>

function findsub($keys ,$userid='abc' ) //This function is important to call the user's permission information
{
include('user/'.$userid.'.php');
foreach($bb as $key=>$submenu)

foreach($submenu as $subkey =>$menuitem)
{
if( $subkey == $keys )
{
return 1;
}
}
}
}//The following is the php permission file to generate the user
//Write
function cache_write($name, $var, $values) {
$cachefile = 'op/user/'.$name.'.php';
$cachetext = "";
if(!swritefile($cachefile, $cachetext))
{
exit("File: $cachefile write error.");
}
}//Convert array into string
function arrayeval($array, $level = 0) {
$space = '';
for( $i = 0; $i <= $level; $i++) {
$space .= "t";
}
$evaluate = "Arrayn$space(n"; < br />$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;
}//Write file
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 background permission configuration file, saved in the form of an array

The code is as follows Copy code
 代码如下 复制代码

$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')    
   ),
  ),
 );
?>

$menus = array(

'news' = > array(
'caption'=>'Information Management',
'icon'=>'admin/icon_15.gif',
'sub' => array( 'newsaddtype' => array('caption' => 'Add category', 'url' => 'news/addtype.php'),
'newstypemange' => array(' caption' => 'Category management', 'url' => 'news/typemange.php'),
'newsnewsend' => array('caption' => 'Publish information', 'url ' => 'news/newsend.php'),
'newsnewmange' => array('caption' => 'Information Management', 'url' => 'news/newmange.php') ,
'newscomments' => array('caption' => 'Comments Management', 'url' => 'news/comments.php'),

), ),

'ask' => array(
'caption'=>'Questionnaire',
'icon'=>'admin/icon_15 .gif',
'sub' => array(
'voteadmin_subject_add' => array('caption' => 'Add voting topic', 'url' => 'vote/admin_subject_add .php'),
'voteadmin_subject' => array('caption' => 'Manage voting subject', 'url' => 'vote/admin_subject.php'),
'voteadmin_title_add ' => array('caption' => 'Add voting question', 'url' => 'vote/admin_title_add.php'),
'voteadmin_title' => array('caption' => ; 'Manage voting questions', 'url' => 'vote/admin_title.php'),
'voteadmin_question_add' => array('caption' => 'Add voting answers', 'url' = > 'vote/admin_question_add.php'),
'voteadmin_question' => array('caption' => 'Manage voting answer', 'url' => 'vote/admin_question.php'),
'voteadmin_system' => array('caption' => 'Vote initial configuration', 'url' => 'vote/admin_system.php')
),
),
'ads' => array(
'caption'=>'Advertising Management',
'icon'=>'admin/icon_15.gif',
' sub' => array(
'ada' => array('caption' => 'Add advertisement', 'url' => 'ada.php'),
'adm' => array('caption' => 'Ad Management', 'url' => 'adm.php'), 
'flashadd' => array('caption' => 'Focus map Advertisement add', 'url' => 'flashadd.php'),
'flashad' => array('caption' => 'Focus image advertising management', 'url' => 'flashad .php')
),
),


'mange' => array(
'caption'=>'System administrator ',
'icon'=>'admin/icon_15.gif',
'sub' => array(
'adminuser' => array('caption' => 'Add by administrator', 'url' => 'adminuser.php'),
'modpass' => array('caption' => 'Password modification', 'url' => 'modpass .php')
),
),
);
?>

The left.php file is very simple. It reads out the permissions based on the user's ID after logging in.

nr nr ";
}

As shown in the picture

The code is as follows nr nr "; 
}

 代码如下 复制代码

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

foreach($bb as $key=>$submenu)
{    
 echo "

nr ".$menus[$key]['caption']."
";
 foreach($submenu  as $subkey=>$menuitem)
 {
  $tmparr = explode("|",$menuitem);
  echo "4".$tmparr[0]."
nr";
 }
 echo "
Copy code

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

foreach($bb as $key=>$submenu){ 
echo "
nr ".$menus[$key]['caption']."
< /td>
";
foreach($submenu as $subkey=>$menuitem)
{
$tmparr = explode("|",$menuitem);
echo "4".$tmparr[0]."
nr";
}
echo "
 代码如下 复制代码

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

}
?>

op.php This file is to call our adminconfig.php file, and then use the function in the fun.php file to save the provided data into an array as shown in the figure
 代码如下 复制代码

$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' => '保存编辑'
 )
?>

Click save and we call opsava.php file, the code is as follows The code is as follows
Copy code

include("op/fun.php");
if( $_POST )
{
$sarray = $_POST ;
cache_write($userid,'bb',$sarray);//Write cache
echo "<script>alert('Edit and save successfully! ');location='op.php?userid=".$userid."';</script>";

}
?> After successful saving, the file content will be as follows
The code is as follows Copy code
$bb=Array
(
'member' => Array
(
'user_search' => 'Member Upgrade Management|user_search.php'
),
'membercy' => Array
(
'cyuser_search' => 'Member upgrade management|cyuser_search.php',
'cyuser_search5' => 'Dating membership|cyuser_search.php?grade=5'
),
'userid' => ; 7,
'button' => 'Save edit'
)
?> In this case, our left Loading the 7.php file will only display the files here, so that basic background permissions are completed
Original tutorial reprinted with source: http://www.bkjia.com/phper. /php.html http://www.bkjia.com/PHPjc/444699.htmlwww.bkjia.comtruehttp: //www.bkjia.com/PHPjc/444699.htmlTechArticleWebsite development is indispensable with a website backend. With the backend, it is natural to assign the same roles to users, especially if there are multiple users In the case of user systems, if I want to have multiple administrators in one system, then...
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!