我服务的图像不正确,它们都显示为旋转90度

时间:2018-03-03 11:31:03

标签: php html image

我曾经发现这段代码可以将服务器中的图像提供给客户端:

$filename = $_GET["filename"];
if ($filename == null || strlen($filename) < 1){
    return null;
}

$fp = fopen($filename, 'rb');

// send the right headers
header("Content-Type: image/jpeg");
header("Content-Length: " . filesize($filename));

// dump the picture and stop the script
fpassthru($fp);
exit;

当我通过浏览器运行这个php文件时(比如在浏览器的地址栏中调用此脚本),肖像图像显示肖像。 但是当我在HTML文件中运行它时(我动态设置了src元素的img)所有肖像图像都显示为横向(如旋转90度)。

我应该在响应(-headers)中包含图像是横向还是纵向的内容?

这是我在html中加载图片的方式:

document.getElementById('next').src = "image.php?filename=" + data;

这是从我的html页面调用并且图像显示正确时请求的样子:

enter image description here

这是不正确的版本 enter image description here

我可以看到标题不同,但这有什么不同? (除了我知道如何在设置图像源时设置标题)

我还注意到的一件事是,在这两种情况下,当我右键单击并保存图像时,文件名是image.jfi,我认为这是一个奇怪的扩展?

1 个答案:

答案 0 :(得分:1)

在Exif中设置了方向。图片没有旋转phisicaly。 图像查看器可以使用它,但标签中的浏览器不会旋转它。

您可以通过 imagemagick --auto-orient http://imagemagick.org/Usage/photos/#orient

在服务器上旋转图片

你也可以在飞行中旋转它&#34;#34;。只需通过 exif_read_data()获取Exif信息,如果它在&#39; Orientation&#39; <中有3(180degree),6(90CW)或8(-90CCW),则将其旋转/ strong>

// dump the picture and stop the script
$source = imagecreatefromjpeg($filename);
$exif = exif_read_data($filename);
if (isset($exif['Orientation'])) {
   switch($exif['Orientation']) {
        case 3: // 180 degree
            $rotate=imagerotate($source,180,0);
            break;
        case 6: // 90 CW
            $rotate=imagerotate($source,-90,0);
            break;
        case 8: // 90 CCW
            $rotate=imagerotate($source,90,0);
            break;
        default:
            $rotate=imagerotate($source,0,0);
            break;
    }
    imagejpeg($rotate);
    imagedestroy($source);
    imagedestroy($rotate);
} else {
    imagejpeg($source);
    imagedestroy($source);
}

但当然最好准备一次所有照片。