PHP中执行exec遇到的坑(linux权限的坑)

坑一 

今天在使用php中的exec()命令,下载搜狗推广数据报表压缩包,解压的时候遇到一个坑,搜狗给了一个链接,在浏览器访问的时候直接下载的是.zip的压缩包,于是使用
//下载压缩包
exec("wget -O /home/www/test/filename.zip 'sougou_url'");//注意url要用单引号包含住
//解压
exec('unzip -o /home/www/test/filename.zip);

结果报错:解压失败,于是到shell终端用命令解压 还是报错如图:

问了运维说是文件格式不是zip格式的,用了多种解压命令试过之后原来是.7z格式的压缩包,这就不得不说搜狗比较坑了。

因为windows下的解压工具是集成有7z格式的,所以在window下解压不报错:

既然找到问题了,就好解决了(注意:centos上默认是没有p7zip的需要安装   yum install -y p7zip);

然后将上面的exec()做如下修改:

exec("wget -O /home/www/test/filename.7z 'sogou_url'");
chmod("./report/sogou/tmp/filename.7z",0777);//此处要给权限否则下一个命令无法执行
exec('7za x /home/www/test/filename.csv.7z -r -o./report/sogou/');

切记文件的用户权限,因为我在终端用的是root用户,修改完文件权限后,程序运行exec操作文件会报错没权限,这是因为php所属用户不是root,只需要将文件的用户改成php用户就可以了。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值