PHP中的getcwd()和__FILE__方法的区别

本文介绍了PHP中使用getcwd()和__FILE__获取文件路径的方法,并通过实例演示了它们在不同上下文中的表现,同时提供了实用的路径定义示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

看下面两个例子

在ch06中建立文件 test.php内容如下

<?php
$a= getcwd();

//变量a的值为D:\php\zend6.1\ch6
$b=__FILE__;

//变量b的值为D:\php\zend6.1\ch6\test.php

?>

由此可见getcwd()返回的是文件所在的绝对路径但是没有文件自身的名字在内。__FILE__则是返回的是文件所在的绝对路径但是有文件自身的名字在内

下面在ch06项目下建立文件夹admincp文件夹。在admincp文件夹下建立文件fff.php。代码如下

<?php
include_once '../test.php';
echo $a;//变量a中的值是D:\php\zend6.1\ch6\admincp
echo '<pre>';
echo $b;//变量b中的值是D:\php\zend6.1\ch6\test.php
?>

由此可见,在另一个文件中包含test.php文件。在test.php文件中用getcwd()获取的test.php的路径变量a在包含之后发生变化。目录结构加上了ffff.php的所在目录admincp,所以·在用文件定位时__FILE__较好

举例

<?php

define('PATH_ROOT',($PATH_ROOT=dirname(__FILE__))?$PATH_ROOT:'..');
$PATH_admincp=PATH_ROOT.'\admincp';
$PATH_picture=PATH_ROOT.'\pciture';
$PATH_admincp_include=$PATH_admincp.'\include';

?>

<?php
include_once dirname(__FILE__).'/../../path.php';
include_once PATH_ROOT."/con_ini.php";

?>


转载于:https://my.oschina.net/pureboys/blog/282384

### 关于 filechecker_revenge 的分析 filechecker_revenge 是一种用于特定场景下的文件校验工具,通常涉及复杂的逻辑处理安全机制。对于该工具的技术信息及其源码分析如下: #### 文件读取路径解析 在给定的代码片段中,存在一段尝试改变当前工作目录并展示某个随机文件源码的操作[^1]: ```php if(chdir(chr(ord(strrev(crypt(serialize(array()))))))) show_source(array_rand(array_flip(scandir(getcwd())))); ``` 这段代码通过一系列函数调用来实现更改工作目录以及显示指定目录下某文件的内容。然而,此行为可能并非预期中的访问根目录而是受限于Web服务器环境配置所影响的结果。 #### IDA Pro 中的NOP操作 针对二进制文件或可执行程序逆向工程过程中遇到的异常字节序列(如 EBFF),可以利用IDA Pro内置脚本语言——IDAPython 进行批量替换为 NOP (No Operation)指令即 `90` 字节来修复此类问题[^2]: ```python for seg_ea in Segments(): for head in Heads(seg_ea, SegEnd(seg_ea)): if Byte(head) == 0xEB and Byte(head + 1) == 0xFF: PatchByte(head, 0x90) ``` #### FileChecker Revenge 使用方法概述 FileChecker Revenge 主要应用于验证文件完整性及检测潜在篡改情况,在实际应用中有以下几个方面值得注意: - **初始化设置**:确保安装依赖库,并按照官方文档完成必要的参数配置。 - **核心功能测试**:运行预设命令以检验基本功能是否正常运作,例如计算哈希值、对比签名等。 - **高级特性探索**:深入研究其提供的API接口或其他扩展模块,以便更好地集成到现有项目当中去。 为了更全面地了解这个工具的具体细节,建议查阅官方发布的最新版本说明技术手册获取最权威的信息资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值