内容处置:内联标题不会内嵌显示图像?

时间:2010-05-14 04:06:41

标签: php image codeigniter http-headers content-disposition

我正在尝试在页面上显示内嵌图像。它由一个codeigniter控制器提供服务。

class Asset extends MY_Controller {

    function index( $folder, $file ) {

        $asset = "assets/$folder/$file";

        if ( !file_exists( $asset ) ) {
            show_404();
            return;
        }

        switch ( $folder ) {
        case 'css':
            header('Content-type: text/css');
            break;
        case 'js':
            header('Content-type: text/javascript');
            break;
        case 'images':
            $ext = substr( $file, strrpos($file, '.') );
            switch ( $ext ) {
            case 'jpg':
                $ext = 'jpeg';
                break;
            case 'svg':
                $ext = 'svg+xml';
                break;
            }

            header('Content-Disposition: inline');
            header('Content-type: image/'.$ext);
        }

        readfile( $asset );
    }

}

当我在Chrome的Chrome中加载图片时,会弹出下载窗口。我知道当浏览器无法显示内联内容时,无论如何都会强制下载,但这些是PNG和GIF图像,否则会在浏览器中显示。在IE中它不强制下载,但它以ASCII格式显示图像。

如果我注释掉整个图像的情况,那么FF和Chrome都会显示ASCII而不是图像。

我认为设置内容类型会允许FF和Chrome显示实际图像,并且还允许将该位置用作src。

javascript和css当然很好。

任何人都有任何想法如何让图像正确显示?

1 个答案:

答案 0 :(得分:5)

尝试删除Content-disposition标头。默认情况下,它们应该以内联方式显示。

无论如何,你应该做错事。我刚刚在Opera和IE中进行了测试,他们确实使用内容处置标题内嵌显示图像。我用过:

<?php
header('Content-Disposition: inline');
header('Content-type: image/png');

readfile('Untitled.png');

使用浏览器的开发工具检查响应标题。

修改

这个错误可能导致了这个问题:

<?php
echo substr( "file.ext", strrpos("file.ext", '.') );

给出“.ext”而不是“ext”。替换为strrpos()+ 1。