前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >if ( ! defined(‘BASEPATH’)) exit(‘No direct script access allowed’)的作用

if ( ! defined(‘BASEPATH’)) exit(‘No direct script access allowed’)的作用

作者头像
全栈程序员站长
发布2022-07-11 11:14:31
1.4K0
发布2022-07-11 11:14:31
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是全栈君。

在看源代码时,发现codeigniter框架的控制器中,总是加上这样一段话;

if(!defined(‘BASEPATH’))exit(‘No direct script access allowed’); 1 刚接触codeigniter,一直没有领会它的作用,后来通过查资料发现其作用是:

为了防止跨站攻击,直接通过访问文件路径用的

另外要注意,这里定义的是:defined()而不是define(),如果你误将defined写成define,将会报一下错误:

A PHP Error was encountered Severity: Warning Message: define() expects at least 2 parameters, 1 given

代码语言:javascript
复制
<?php
 2 //放止用户直接通过路径来访问控制器,如果这样的话会显示找不到
 3 if ( ! defined('BASEPATH')) exit('No direct script access allowed');
 4 
 5 class Hello extends CI_Controller {
 6 
 7     public function sayhello($name,$name2){
 8         echo $name,",Hello CI to ",$name2;
 9     }
10 }

注意 1、defined() 函数仅对 constants 有效(上面的例子不是define(),写成define()的话会报错的)

经常看到这样的语句:

file = fopen(filename, r) or die(“抱歉,无法打开:

or 在这里是这样理解的,因为在PHP中并不区分数据类型,所以$file既可以是int也可以bool,所以这样的语句不会报错。

其实在大多数的语言中, bool or bool这样的语句中,如果前一个值为真后一个值就不会再判断了。这里也是的,所以如果fopen函数执行正确的话,会返回一个大于0的int值(这其实就

是“真”),后面的语句就不会执行了。如果fopen函数执行失败,就会返回false,那么就会判断后面的表达式是否为真了。

结果执行了die()之后,不管返回什么,程序都已经停止执行了,并且显示指定的出错信息,也就达到了调试的目的。

同理:

defined(‘THINK_PATH’) or define(‘THINK_PATH’, __DIR__.’/’);

如果 THINK_PATH 这个常量已经被定义了,那么就不执行 or 后面的 define(‘THINK_PATH’, __DIR__.’/’);

相反,如果没有定义 THINK_PATH 这个常量,那么就会执行后面的 define(‘THINK_PATH’, __DIR__.’/’); 定义 THINK_PATH 常量

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/112174.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年2月9,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 经常看到这样的语句:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档