找回密码
 立即注册
搜索
查看: 207|回复: 0

phpMyAdmin导入文件错误的解决办法

[复制链接]

989

主题

92

回帖

5万

积分

管理员

积分
55362
发表于 2022-7-4 17:01:12 | 显示全部楼层 |阅读模式
5 G1 w- G$ a- j7 l* E, I) M
phpMyAdmin 这货的升级速度确实是快,今天已然升级到 4.2.3 了,打算升级一下 phpMyAdmin 并简单测试一下,在导入文件的时候发生以下错误:
/ l& o! _1 e! E$ K0 N8 ~Uploaded file cannot be moved, because the server has open_basedir enabled without access to the directory (for temporary files).
5 s- h1 Q# N# f5 u2 R0 m* X8 v而在之前的版本 4.2.2 的时候,导入文件是没有问题的。相同的环境,因为版本升级而导致的问题,那肯定是代码有变动了。于是开始比较两个版本之间有什么不同。
+ j2 c+ ^3 b& Q% X' r6 I       
; p* \/ T7 S* D3 z7 w6 k既然是导入文件出的问题,那就来比较一下 phpMyAdmin 根目录下的 import.php 文件。
4 ~* b2 ?. t" O" ?& d7 C版本 4.2.2 的 import.php 中第 376 行:$ t$ _' S% v  c" {
$tmp_subdir = sys_get_temp_dir();版本 4.2.3 的 import.php 中第 376 行:/ m: z% j  L: m1 j4 N$ v( v. M5 m  \  Y
$tmp_subdir = ini_get('upload_tmp_dir');从代码中可以看出,导入文件的临时目录的获取方式变更了。前者使用了 PHP 的函数 sys_get_temp_dir 返回用于临时文件的目录;后者使用了 PHP 的函数 ini_get 来获取 php.ini 配置文件里 upload_tmp_dir 的值。如果在 php.ini 中 upload_tmp_dir 的值没有定义的话,那就会出现以上的错误。
( k" D0 k& M, g0 h; gLAMP一键安装脚本中,默认的 php.ini 中没有设置 upload_tmp_dir 的值(此处在官方的 php.ini-production 中也未定义),所以解决办法就是:6 ^* z2 w* D" r. G5 _# ]$ o
在 php.ini 中将 upload_tmp_dir 设为 /tmp 即可。
! A( |6 Q9 W1 ?: f- K. R8 z7 K" @# T如果安装环境是 LAMP一键安装脚本 的话,则修改文件位于 /usr/local/php/etc/php.ini,其他的环境则根据实际情况找到 php.ini 来修改。
1 q- j' w3 h( }( j0 V修改前:
5 [4 }& t6 Z& }' H3 @: _( s0 r;upload_tmp_dir =修改后:  R5 {" @. P1 h. S# M2 ~9 |
upload_tmp_dir = /tmp在 Apache 的配置文件 httpd-vhosts.conf 中定义的 php_admin_value open_basedir 已包含了 /tmp 目录。而关于 /tmp 目录的权限一般已默认是 777 ,具备了可写权限。
2 |* y+ n- H* ?3 j( U/ E0 D. v按照上述步骤修改完 php.ini 后,需重启 Apache 。: O  W$ b6 n# B! c+ @6 Y6 f
service httpd restart重启完毕,再次登录 phpMyAdmin 并导入文件就一切正常了。) y6 Q4 b, L  B5 v
最后吐槽 phpMyAdmin:: n  Y5 ~: U+ U& |' o
phpMyAdmin 导入文件的代码(import.php)中,导入文件的临时目录的获取方式几度变更,在版本4.0.8 中则是这样的:$ L. y, y2 f! [0 U$ n% ]5 }
$tmp_subdir = (PMA_IS_WINDOWS ? '.\\tmp\\' : 'tmp/');在设置了 open_basedir 的情况下,最终(最新版 4.2.3)的解决方案是跟 php.ini 里的设置绑定了。那如果用户不能设置(比如虚拟主机用户) php.ini 中的 upload_tmp_dir 那不就意味着无法使用导入文件功能了么。
! u5 Y5 b( Z% B8 r个人觉得,可以加个判断条件,如果从  php.ini 中读到的 upload_tmp_dir 的值为空,则改用 sys_get_temp_dir 函数获取用于临时文件的目录,然后再来判断获得的目录是否具备可写权限。这里给出的参考代码如下:/ n: j' I' d8 W) I
$tmp_subdir = ini_get('upload_tmp_dir'); if (empty($tmp_subdir)) {    $tmp_subdir = sys_get_temp_dir();}
3 d+ w$ ~+ J# ?9 {! `0 V7 q2014年06月21日更新:
! g0 @  p% }- f3 vphpMyAdmin 更新到 4.2.4 后,import.php 如我所料地改成了以上我给出的建议代码。
8 N1 d; y9 n& L参考链接:0 P# n2 m& C! w5 l9 h8 B2 \# |/ m
http://docs.phpmyadmin.net/en/latest/faq.html#i-cannot-insert-a-text-file-in-a-table-and-i-get-an-error-about-safe-mode-being-in-effect
$ t& ~$ R0 E% j' thttp://sourceforge.net/p/phpmyadmin/bugs/4405/
3 b. z. `* E, z0 B& {; |7 I1 M; M- D* J5 v0 D
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|

GMT+8, 2026-5-6 08:37 AM , Processed in 0.078195 second(s), 23 queries .

Powered by xyh-moon X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表