php怎么高效获取远程图片尺寸

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php怎么高效获取远程图片尺寸相关的知识,希望对你有一定的参考价值。

getimagesize这个函数获取远程图片的效率太低了
有没有快速的方法??

/**
 * 获取远程图片的宽高和体积大小
 *
 * @param string $url 远程图片的链接
 * @param string $type 获取远程图片资源的方式, 默认为 curl 可选 fread
 * @param boolean $isGetFilesize 是否获取远程图片的体积大小, 默认false不获取, 设置为 true 时 $type 将强制为 fread 
 * @return false|array
 */
function myGetImageSize($url, $type = 'curl', $isGetFilesize = false) 

    // 若需要获取图片体积大小则默认使用 fread 方式
    $type = $isGetFilesize ? 'fread' : $type;
 
     if ($type == 'fread') 
        // 或者使用 socket 二进制方式读取, 需要获取图片体积大小最好使用此方法
        $handle = fopen($url, 'rb');
 
        if (! $handle) return false;
 
        // 只取头部固定长度168字节数据
        $dataBlock = fread($handle, 168);
    
    else 
        // 据说 CURL 能缓存DNS 效率比 socket 高
        $ch = curl_init($url);
        // 超时设置
        curl_setopt($ch, CURLOPT_TIMEOUT, 5);
        // 取前面 168 个字符 通过四张测试图读取宽高结果都没有问题,若获取不到数据可适当加大数值
        curl_setopt($ch, CURLOPT_RANGE, '0-167');
        // 跟踪301跳转
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
        // 返回结果
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
 
        $dataBlock = curl_exec($ch);
 
        curl_close($ch);
 
        if (! $dataBlock) return false;
    
 
    // 将读取的图片信息转化为图片路径并获取图片信息,经测试,这里的转化设置 jpeg 对获取png,gif的信息没有影响,无须分别设置
    // 有些图片虽然可以在浏览器查看但实际已被损坏可能无法解析信息 
    $size = getimagesize('data://image/jpeg;base64,'. base64_encode($dataBlock));
    if (empty($size)) 
        return false;
    
 
    $result['width'] = $size[0];
    $result['height'] = $size[1];
 
    // 是否获取图片体积大小
    if ($isGetFilesize) 
        // 获取文件数据流信息
        $meta = stream_get_meta_data($handle);
        // nginx 的信息保存在 headers 里,apache 则直接在 wrapper_data 
        $dataInfo = isset($meta['wrapper_data']['headers']) ? $meta['wrapper_data']['headers'] : $meta['wrapper_data'];
 
        foreach ($dataInfo as $va) 
            if ( preg_match('/length/iU', $va)) 
                $ts = explode(':', $va);
                $result['size'] = trim(array_pop($ts));
                break;
            
        
    
 
    if ($type == 'fread') fclose($handle);
 
    return $result;

 
// 测试的图片链接
echo '<pre>';
$result = myGetImageSize('http://s6.mogujie.cn/b7/bao/120630/2kpa6_kqywusdel5bfqrlwgfjeg5sckzsew_345x483.jpg_225x999.jpg', 'curl');
print_r($result);
echo '<hr />';
$result = myGetImageSize('http://s5.mogujie.cn/b7/bao/120629/6d3or_kqytasdel5bgevsugfjeg5sckzsew_801x1193.jpg', 'fread');
print_r($result);
echo '<hr />';
$result = myGetImageSize('https://gss0.baidu.com/7LsWdDW5_xN3otqbppnN2DJv/zhengmingjiang/pic/item/1c5f338c6d22d797503d92f9.jpg', 'fread', true);
print_r($result);
echo '<hr />';
$result = myGetImageSize('http://www.vegandocumentary.com/wp-content/uploads/2009/01/imveganlogotransparentbackground.png', 'curl', true);
print_r($result);
echo '<hr />';
$result = myGetImageSize('http://jiaoyou.ai9475.com/front/templates/jiaoyou/styles/default/image/ad_pic_1.gif', 'fread');
print_r($result);

追问

就知道复制粘贴
你试过能用么??!!!

追答

既然发出来 自然试过

参考技术A 如果是批量的获取尺寸,建议用curl获取图片加载到本机内存或者硬盘,然后再处理。
如果是单张的,没什么好方法。获取速度取决于网速。
参考技术B php中提供的应该就只有这个了…

微信小程序学习点滴《十二》:图片等比例缩放 获取屏幕尺寸图片尺寸 自适应

原文:http://www.wxapp-union.com/portal.php?mod=view&aid=360

早上在论坛上看到有人写了关于图片等比例缩放的文章,只是判断了图片宽是否大于屏幕宽.我之前在做Android时候也会遇到图片等比例缩放的问题.应该是用图片宽高比和屏幕宽高比做判断.做个笔记.

老规矩,先上图.

1.图片高宽比小于屏幕高宽比

技术分享

 

2.图片高宽比大于屏幕高宽比

技术分享

 

3.这种其实也是图片高宽比小于屏幕高宽比,但是高宽都大于屏幕高宽.所以不能简单用高宽来判断,应该是用高宽比判断后做缩放.

技术分享

 

上代码:

1.index.wxml

  1. <!--index.wxml-->
  2. <!--图片宽大于屏幕宽-->
  3. <image style="width: {{imagewidth}}px; height: {{imageheight}}px;" src="{{imagefirstsrc}}" bindload="imageLoad"></image>
  4. <!--图片高大于屏幕高-->
  5. <!--<image style="width: {{imagewidth}}px; height: {{imageheight}}px;" src="{{imagesecondsrc}}" bindload="imageLoad"></image>-->
  6. <!--图片宽高大于屏幕宽高-->
  7. <!--<image style="width: {{imagewidth}}px; height: {{imageheight}}px;" src="{{imagethirdsrc}}" bindload="imageLoad"></image>-->

2.index.js

  1. //index.js
  2. //获取应用实例
  3. var imageUtil = require(‘../../utils/util.js‘);
  4. var app = getApp()
  5. Page({
  6. data: {
  7. imagefirstsrc: ‘http://bpic.588ku.com/back_pic/00/03/85/1656205138bbe2d.png‘,//图片链接
  8. imagesecondsrc: ‘http://bpic.588ku.com/back_pic/04/07/63/28581203949ca9d.jpg!/fw/400/quality/90/unsharp/true/compress/true‘,//图片链接
  9. imagethirdsrc:‘http://img1.gtimg.com/ent/pics/hv1/13/71/2061/134034643.jpg‘,
  10. imagewidth: 0,//缩放后的宽
  11. imageheight: 0,//缩放后的高
  12. },
  13. onLoad: function () {
  14. },
  15. imageLoad: function (e) {
  16. var imageSize = imageUtil.imageUtil(e)
  17. this.setData({
  18. imagewidth: imageSize.imageWidth,
  19. imageheight: imageSize.imageHeight
  20. })
  21. }
  22. })

 

 

3.util.js

    1. //util.js
    2. function imageUtil(e) {
    3. var imageSize = {};
    4. var originalWidth = e.detail.width;//图片原始宽
    5. var originalHeight = e.detail.height;//图片原始高
    6. var originalScale = originalHeight/originalWidth;//图片高宽比
    7. console.log(‘originalWidth: ‘ + originalWidth)
    8. console.log(‘originalHeight: ‘ + originalHeight)
    9. //获取屏幕宽高
    10. wx.getSystemInfo({
    11. success: function (res) {
    12. var windowWidth = res.windowWidth;
    13. var windowHeight = res.windowHeight;
    14. var windowscale = windowHeight/windowWidth;//屏幕高宽比
    15. console.log(‘windowWidth: ‘ + windowWidth)
    16. console.log(‘windowHeight: ‘ + windowHeight)
    17. if(originalScale < windowscale){//图片高宽比小于屏幕高宽比
    18. //图片缩放后的宽为屏幕宽
    19. imageSize.imageWidth = windowWidth;
    20. imageSize.imageHeight = (windowWidth * originalHeight) / originalWidth;
    21. }else{//图片高宽比大于屏幕高宽比
    22. //图片缩放后的高为屏幕高
    23. imageSize.imageHeight = windowHeight;
    24. imageSize.imageWidth = (windowHeight * originalWidth) / originalHeight;
    25. }
    26. }
    27. })
    28. console.log(‘缩放后的宽: ‘ + imageSize.imageWidth)
    29. console.log(‘缩放后的高: ‘ + imageSize.imageHeight)
    30. return imageSize;
    31. }
    32. module.exports = {
    33. imageUtil: imageUtil
    34. }

以上是关于php怎么高效获取远程图片尺寸的主要内容,如果未能解决你的问题,请参考以下文章

PHP获取远程图片并调整图像大小(转)

qimage::fromData获取RGB数据怎么判断图片尺寸

微信小程序学习点滴《十二》:图片等比例缩放 获取屏幕尺寸图片尺寸 自适应

html5拖拽图片上传,怎么获得图片原始尺寸

android 中怎么控制ImageButton 上的图片与按钮尺寸的匹配

怎么修改淘宝店铺宝贝图片尺寸的宽度