jjzjj

php - PHP 输出的有效图像总是 "contain errors",这可能是什么原因造成的?

coder 2024-04-06 原文

几个月前,我使用 PHP 5.3 为客户编写了一个网站。它在我自己的 LAMP 网络服务器上完美运行。但是,当他尝试将它安装到自己的服务器(目前是在 CentOS 5 上运行 DirectAdmin 的 OVH 服务器)时,他遇到了一个我无法解决的问题。

网站可以存储通过表单上传的图片。图片在上传时带有水印并移动到网络服务器中的目录(一些元数据存储在数据库中,但这与此问题无关)。

为了向用户显示这些图像,使用如下脚本:

header("Content-type: image/jpeg");
ob_start();
echo file_get_contents($path);
$size = ob_get_length();
$img = ob_get_contents();
ob_end_clean();
header ("Content-length: " . $size);
echo $img;

不幸的是,这总是返回损坏的图像(在 Firefox 中,“图像无法显示,因为它包含错误”)。现在,经过仔细测试,我知道:

  • 图像已正确上传到服务器。存储在网络服务器中的图像数据是有效的,可以像普通图像一样通过FTP获取。

  • 如果我将 $img 存储到上一个脚本的最后一行之前的文件中,如下所示:

    $fh = fopen("test.jpg", "w");
    fwrite($fh, $img);
    fclose($fh);
    

    它还会将正确的图像数据保存到文件中。因此,数据在发送到用户的网络浏览器之前是完整无缺的。

  • header 已正确发送。

但是!如果我使用 text/plain header 而不是 image/jpeg,我可以看到返回的乱码与使用记事本在本地打开文件时显示的乱码不同(或者直接通过 apache 将图像作为文本文件发送)。在原始图像中,我可以看到一些 EXIF。在由 PHP 生成然后发送到用户 Web 浏览器的图像中,我仍然看到 JFIF 魔术代码(用于 JPEG 文件图像格式),但其余部分看起来不同。

恐怕我在 PHP 或 Apache 上遇到与编码、缓冲、内容压缩或类似问题相关的配置相关问题。有谁知道我可以尝试解决这个问题吗?

编辑:

更改脚本以使用:

$img = file_get_contents($path);
$size = filesize($path);

问题保持不变,但内容现在看起来与真实图像与从 PHP 发送的图像完全相同。根据 header ,内容编码为 gzip。有什么想法吗?

最佳答案

好吧,经过一些调查,它变成了 PHP 脚本中臭名昭著的字节顺序标记签名(当然,与抑制错误的输出缓冲相结合)。
看来只要重新保存没有BOM的文件就可以解决问题

有用吗?

header("Content-type: image/jpeg");
echo file_get_contents($path);

还是这个?

header("Content-type: image/jpeg");
readfile($path);

下载此图像(使用 wget 或在其上建立链接并使用“另存为”)并查看差异。它可能会阐明原因

是的。 ob 在这里绝对没有任何关系。如果你想获得一个文件大小 - 有一个(惊喜!)它的函数

header("Content-type: image/jpeg");
header ("Content-length: " . filesize($path));
readfile($path);

关于php - PHP 输出的有效图像总是 "contain errors",这可能是什么原因造成的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7371989/

有关php - PHP 输出的有效图像总是 "contain errors",这可能是什么原因造成的?的更多相关文章

  1. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  2. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  3. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  4. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  5. ruby - 如何以所有可能的方式将字符串拆分为长度最多为 3 的连续子字符串? - 2

    我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123

  6. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  7. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  8. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

  9. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  10. ruby - 通过 erb 模板输出 ruby​​ 数组 - 2

    我正在使用puppet为ruby​​程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby​​不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这

随机推荐