open-basedir修改引起上传失败的问题

9275次阅读 843人点赞 作者: WuBin 发布时间: 2021-05-14 14:30:20
扫码到手机查看

open_basedir

open_basedir将PHP所能打开的文件限制在指定的目录树中,包括文件本身。当程序要使用例如fopen()或file_get_contents()打开一个文件时,这个文件的位置将会被检查。当文件在指定的目录树之外,程序将拒绝打开。

设置PHP的php.ini文件中的open_basedir项,可以限制PHP访问的范围,如open_basedir="/apache group/apache2/htdocs",这样就限定了PHP文件只能访问htdocs目录下的内容。

修改方法是在php.ini文件下进行修改。

// 默认前面有分号 需要解开 指定一个目录
open_basedir = "/mydoc/www/mysite/"

指定目录后,上传失效了

开始时,我是懵逼的状态。发现使用该项后,我的UPLOAD无法上传,提示上传成功了,但其实根本没成本,文件夹中也没有上传成功的文件。最后在代码中打印错误日志,发现提示:“找不到临时目录”。

在php.ini关于上传文件部分的设置中看到了upload_tmp_dir这个设定,PHP中说明,通过http在线上传文件的,如果不手动设置上传临时文件夹的话,就会利用操作系统的临时文件夹,因为PHP默认上传临时夹的设定项upload_tmp_dir是空值,所以如果设定了open_basedir的话,程序就无法读写系统的临时文件夹了,所以造成上传的不正常。这时可以手动指定upload_tmp_dir,或不设定open_basedir。这也是便利和安全中的抉择。

另外,open_basedir的设定也会影响某些程序的session的使用(待尝试补充)。

因此,就需要在/mydoc/www/mysite/目录下新建一个目录linshi,并修改PHP上传的临时目录。

// 在php.ini中
upload_tmp_dir =" /mydoc/www/mysite/linshi"

然后重启php-fpm和apache服务。

为什么修改并重启了还不生效?

首先遇事不慌,先phpinfo()看一下 :

发现路径都正常(如果这里不是自己制定的路径,那么返回php.ini中继续修改)

那么问题就可能出在用户对/mydoc/www/mysite/linshi是否有写权限了!一般通过ftp创建的文件夹,默认别人无法写入,因此对于新创建的用于存放临时上传文件的目录,用户是没有写的权限的!

最后给临时目录添加写入权限,问题解决!

相关资料

点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:open_basedir,upload_tmp_dir
推荐阅读
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    9603次阅读 623人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • Vue

    盘点Vue2和Vue3的10种组件通信方式

    Vue中组件通信方式有很多,其中Vue2和Vue3实现起来也会有很多差异;本文将通过选项式API组合式API以及setup三种不同实现方式全面介绍Vue2和Vue3的组件通信方式。

    4297次阅读 317人点赞 发布时间: 2022-08-19 09:40:16 立即查看
  • JS

    几个高级前端常用的API

    推荐4个前端开发中常用的高端API,分别是MutationObserver、IntersectionObserver、getComputedstyle、getBoundingClientRect、requ...

    14452次阅读 948人点赞 发布时间: 2021-11-11 09:39:54 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    13497次阅读 491人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    12015次阅读 963人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    16376次阅读 1307人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    15187次阅读 1234人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    29853次阅读 2347人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    25911次阅读 1994人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录