这样做是为什么,帮忙看看好么

WBOY
发布: 2016-06-23 13:55:17
原创
964 人浏览过

defined ( 'IN' ) or die ( 'Access Denied' );
这句话。在前台控制器文件都有,但是为什么要这么做,他在index.php文件定义了这个常量,然后来检查他是否被定义,但是前台控制器本来就是用来访问的,为什么要加这个定义啊。不是根本没有用吗?


回复讨论(解决方案)

如果IN没有定义,则退出执行,并输出Access Denied

作用是当IN没有定义时,不执行后面的程序。

这样就会输出ok
define('IN', 123);
defined ( 'IN' ) or die ( 'Access Denied' );
echo 'ok';
如果define('IN', 123);这句不存在,就输出AccessDenied

这样做目的是控制入口,你的程序应该是只能用index.php?controller=xxx&action=xxx 形式访问的吧。
如果用户直接访问 controller.php 要被禁止。所以加了这段判断。

例如你的目录结构
app/controller/c.php
index.php

define('IN','xxx'); 这句在index.php定义
如果用户直接访问 index.php?controller=c 会执行 app/controller/c.php 因为IN有定义了,所以可以执行。
但用户直接访问app/controller/c.php 因为IN没有定义,所以不能执行。

凡是有这句的程序文件,都不能直接访问到
而只能在 index.php 中包含

这样做目的是控制入口,你的程序应该是只能用index.php?controller=xxx&action=xxx 形式访问的吧。
如果用户直接访问 controller.php 要被禁止。所以加了这段判断。

例如你的目录结构
app/controller/c.php
index.php

define('IN','xxx'); 这句在index.php定义
如果用户直接访问 index.php?controller=c 会执行 app/controller/c.php 因为IN有定义了,所以可以执行。
但用户直接访问app/controller/c.php 因为IN没有定义,所以不能执行。



谢谢兄弟,我也刚刚弄懂,然后看了你的回答更懂了。谢谢

凡是有这句的程序文件,都不能直接访问到
而只能在 index.php 中包含




谢谢版主 ,每次来提问都有你回答 - - 每次得到答案 都信心倍增啊。
相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板