php预定义常量目录分隔符
目录分隔符,是定义php的内置常量。在调试机器上,
在windows我们习惯性的使用“\”作为文件分隔符,
但是在linux上系统不认识这个标识,于是就要引入这个php内置常量了:DIRECTORY_SEPARATOR
php的内置常量DIRECTORY_SEPARATOR是一个显示系统分隔符的命令,
DIRECTORY_SEPARATOR是php的内部常量,不需要任何定义与包含即可直接使用。
在 Windows 中,斜线(/)和反斜线(\)都可以用作目录分隔符,在linux上路径的分隔符是/,这就导致了一个问题,
比如开发机器是windows,有一个图片上传程序,,而我们又使用了(\)作为文件分隔符,
调试机器上指定的上传文件保存目录是:define('ROOT',dirname(__FILE__)."\upload"),在本地调试都很正常,
但是上传到linux服务器的时候会发现会出错。
这个问题就是出在文件的分隔符上,windows上习惯性的使用\作为文件分隔符,
但是在linux上人家是不认识这个标识的,人家只认识/,于是就要引入下面这个php内置常量了:DIRECTORY_SEPARATOR。
上面的写法可以改写为以下无错写法:
define('ROOT',dirname(__FILE__).DIRECTORY_SEPARATOR."upload");
这样就可以确保不会出错了。
例如discuz里面是这样写的:define('S_ROOT',dirname(__FILE__).DIRECTORY_SEPARATOR);
回到问题本身上,DIRECTORY_SEPARATOR是一个返回跟操作系统相关的路径分隔符的php内置命令,
在windows上返回\,而在linux或者类unix上返回/,就是这么个区别,
通常在定义包含文件路径或者上传保存目录的时候会用到。
更多相关文章
- 如何在XMLHttpRequest中获取实际文件?
- MySql数据库——文件
- mysql日志文件过大导致磁盘空间不够的问题
- PHP读取Excel文件的内容并写入Mysql数据库
- 如何创建a '。sql的文件
- MySQL(Navicat)运行.sql文件时报错:[Err] 2006
- 有没有一种方法可以在不破坏外键依赖关系的情况下将MySQL数据库
- 如何将xml文件转换为mysql?
- 如何将CSV文件中的值实际分割为MySQL数据库