使用Laravel Intervention库无法缓存动态图像

心脏777

带有请求的Web控制台

我目前正在使用Laravel 5,并利用干预图像集成:http : //image.intervention.io/

我正在动态使用它,因此图像具有这样的URL:

http://example.org/media/1600x340/2/image_name.jpg

因此所有工作正常,但注意这些图像将不会缓存。其他的,但我不是动态的。

这是我的htaccess

<FilesMatch "\.(ico|pdf|jpg|jpeg|png|gif|html|htm|xml|txt|xsl)$">
    Header set Cache-Control "max-age=31536050"
</FilesMatch>

<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType image/jpg "access plus 1 year"
ExpiresByType image/jpeg "access plus 1 year"
ExpiresByType image/gif "access plus 1 year"
ExpiresByType image/png "access plus 1 year"
ExpiresByType text/css "access plus 1 month"
ExpiresByType application/pdf "access plus 1 month"
ExpiresByType text/x-javascript "access plus 1 month"
ExpiresByType application/x-shockwave-flash "access plus 1 month"
ExpiresByType image/x-icon "access plus 1 year"
ExpiresDefault "access plus 2 days"
</IfModule>

如果我实际上是通过FTP连接并查看缓存的图像,则它们的存储方式如下:

/ storage / framework / cache / 55 / ba / 0245f7453543100cf0aaa4709eca82f4

如果每次必须重新加载缓存,那么缓存有什么意义呢?我怀疑问题在于浏览器不知道这些文件是什么(它们没有扩展名),因此不缓存它们。

这是一些laravel示例代码:

$cache_image = Image::cache( function ( $image ) use ( $size, $name ) {
    return $image->make( url( '/uploads/' . $name ) )->resize( $size[0], $size[1], function ( $constraint ) {
        $constraint->aspectRatio();
        $constraint->upsize();
    } );
}, $cache_length )->sharpen(5);

...

return Response::make( $cache_image, 200, [ 'Content-Type' => 'image' ] );

chrome中的标题如下所示:

GET /media/1600x340/2/img_0033-copy.jpg HTTP/1.1
Host: mywebsite.com.au
Connection: keep-alive
Accept: image/webp,*/*;q=0.8
User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2357.130 Safari/537.36 FirePHP/4Chrome
Referer: http://mywebsite.com.au/functions
Accept-Encoding: gzip, deflate, sdch
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6
Cookie: __cfduid=d4fee20f7753d88962b94c880cec57f981435071761; _gat=1; _ga=GA1.3.1903752380.1435076392; XSRF-TOKEN=eyJpdiI6IkFpMHJDTDZtTTVoczVaSkxaZ1hjNmc9PSIsInZhbHVlIjoiVlVRSk1ibCtCWHpZNW5SQkl0NTA2bVN2Tmh4c0N6aW5TWGZ1Njk1WG1Gb05XXC91dW5DYjdLNWpGXC9kSWFsYXZ6bDZMQ0NmZE15UlVvMFV3OEN1bWJPZz09IiwibWFjIjoiZGI1OTYwM2IwZTNhYWFlM2I5NGExNTkzNTlkN2YxNGI4Y2IzNjI5ODU5Y2RjNTRkODYxMWIxNDJiMDM3NGI5YyJ9; laravel_session=eyJpdiI6Ikc5a3ZibmZraG9aZElnYWFKUG5CWHc9PSIsInZhbHVlIjoiblRWcDRxQW9ORGl0RFdubDJ3NTdXR3lNdUcyWmtnSkEyXC9sZFI3VWQ2NkVBdUxJNWVpZU5ubEZ2RG1HbVF6SHdYNFhob21UOEVjOVZxMklKdndxQ3dBPT0iLCJtYWMiOiIwMThlMGZkMTdlNWM5MDQ4OWYxNzIwMzE2NzhhMzEzMjg1MGM4NjI2NzRkMmJhMWEzNmUzN2MyNjJhYzdjNjQ1In0%3D
X-FirePHP-Version: 0.0.6
X-Wf-Max-Combined-Size: 261120

有任何想法吗?希望我可以用htaccess文件来解决这个问题

Pinkal Vansia

您可以将其缓存在浏览器端。只需向响应添加标头,如下所示,

return Response::make( $cache_image, 200, [ 'Content-Type' => 'image' ] )
       ->setMaxAge(604800) //seconds
       ->setPublic();

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何使用JQuery制作显示动态图像放大版本的弹出窗口?

如何使用JQuery向表中的特定单元格添加动态图像?

如何使用Selenium和Python从链接中提取动态图像?

在“反应式旋转木马” React中加载动态图像(使用API获取)

使用Dropbox作为磁盘的Laravel图像缓存

如何使用Capybara匹配动态图像文件名?

无法在Django中使用动态图片网址

在VF页面中导出Excel-使用动态图像URL时图像未显示

使用Express html-pdf包时图像不是从动态图像路径渲染的

如何使用任何npm软件包从数据库生成和下载具有动态图像路径的pdf

使用JCROP和JQUERY通过基于jsp..url的图像源/动态图像无法裁剪图像

如何使用phpmail在电子邮件正文上添加动态图像

如何使用动态图像URI缓存图像?

获取使用动态图像拍打的图像的标识符

动态图像缓存handler.ashx不缓存

如何使用Laravel中的Intervention图像处理库以自定义比例调整图像大小

使用资产的Symfony2动态图像

如何使用Laravel 5的Intervention.io库删除图像

无法在Laravel中使用Intervention上传大图像

使用Laravel 5.2中的javascript的模式视图中的动态图像

使用 php 和 mysqli 的动态图像滑块

向 img html 元素显示动态图像数据 - Laravel、Collective

React - 使用 props 加载动态图像

使用 Laravel 对象在 vue 模板中动态图像的数据绑定样式

使用 ajax 在引导模式上加载动态图像

如何使用 Intervention Image Cache 输出缓存的图像?

如何使用 *ngFor 从 baseurl+filename 显示动态图像

未找到 webpack 的 React 组件中使用的动态图像 src

如何在 Nuxt 中使用动态图像?