好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

php网站权限控制 php访问权限

很多站长朋友们都不太清楚php网站权限控制,今天小编就来给大家整理php网站权限控制,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 php、HTML、网页设计,如何设定权限? 2、 php后台多用户权限设置及实现思路 3、 php权限管理如何实现? 4、 php网站文件目录权限如何开 5、 在php网站中用户权限 php、HTML、网页设计,如何设定权限?

比如你登录后存储用户名是用session, 而且键名是user

那么

在网页2头部加上如下代码:

<?php

 session_start();

 if ( $_SESSION['user'] != 'bc' ) {

  echo '<script>alert("无权限");</script>';

  die; 

}

其他的同理!

当然, 具体项目这样做的话, 肯定是不现实的, 那么多用户, 都用用户名来判断的话, 会整死人的!

所以, 我这个代码也只是跟着你的思路走而已!

建议: 数据库再增加一个字段, 用于记录该用户权限

登录成功后, 同时取出该用户的权限字段值,并进行储存( 比如session )

然后在每个页面用权限字段来进行判断!

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/'.$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/ /".$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文件就只会显示这里在的文件,这样一个基本的后台权限就完成了。

php权限管理如何实现?

我得做法是,用形如:\x0d\x0a \x0d\x0a修改文章,1,删除文章,1,新增文章,1\x0d\x0a这样的字符串来保存权限值\x0d\x0a读取后explode为数组,需要校验权限的时候,用\x0d\x0aif($array["修改文章"])\x0d\x0a判断是否有权限。

php网站文件目录权限如何开

将权限设置成777就可以了啊。chmod 777 【文件名】

“777”代表权限,对应rwdrwdrwd,从左往右第一位‘7’代表属主的权限对应第一组‘rwd’,r标识可以读,w代表可以写,x代表可以执行。

第二位‘7’代表属组的权限,第三位‘7’代表所有人的权限。例如只允许属主读写执行赋予700权限对应rwd权限。也可以使用a、u、字母表示权限,比如chmod a+x 【文件名】 是赋予任何人执行的权限,chmod a+r 【文件名】是赋予所有人读得权限,chmod a+w 【文件名】是赋予所有人写的权限,等等。

不过设置777不安全,最好设置成可读就可以了,744应该可以。

在php网站中用户权限

4个表

用户表(用户信息表)

权限表(设置可以访问的页面)

角色表(如果申请用户的时候有多项选择的时候添加,没有则不需要)

用户权限对应关系表(这个表是用于给每个用户赋权)

如果用户访问页面的时候,判断是否存在访问权限(查用户权限对应关系表),如果有正常访问,如果没有页面跳转。不过跳到登录页面感觉不太合理,你判断用户是否有权限的时候,他应该是登录状态,如果再跳到登录页面感觉不合理。

判断是否存在访问权限可以封装成公共类,每个页面初始化的时候都调用这个公共类。可以通过用户ID进行判断。

同是普通用户,那就加标识,判断的时候再判断一下标识,然后根据标识进行页面跳转。

以上,希望能帮到你。

关于php网站权限控制的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于php网站权限控制 php访问权限的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did197286
更新时间:2023-04-26   阅读:32次

上一篇: php乱码更改格式 php echo乱码

下一篇:php变量zaihtml php变量以哪个符号开头

最新资料更新

  • 1.php会员登录与注册 php 用户登录
  • 2.php菱形的输出 php输出菱形星号
  • 3.php调用裁剪插件 phpcrawl
  • 4.修改文件限制php php修改上传文件大小
  • 5.包含Zend转php的词条
  • 6.phphtml补全 html自动补全代码
  • 7.php配置smtp php配置文件的文件名是什么
  • 8.php网站界面代码 php网页
  • 9.php函数补全 php自动补全
  • 10.php薪资1680 php一个月能挣多少钱
  • 11.登录htmlphp 登录html
  • 12.php余数1 php math
  • 13.php添加字体水印 php设置字体
  • 14.关于php2esgbi的信息
  • 15.杭州php前景如何 杭州php培训学校
  • 16.php圆形头像代码 php生成圆形图
  • 17.php如何页面静态化 php实现页面静态化
  • 18.phpnodelay的简单介绍
  • 19.php扩展的路径 php常用扩展有哪些
  • 20.php安全验证 php安全问题

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://www.haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]