通过url获取图片尺寸的几种方法:JS和php
来源:互联网 发布:网络信息点测试 编辑:程序博客网 时间:2024/05/16 05:59
首先是js的方法,通过new一个Image对象,设置src属性,并监听complete和onload事件,图片加载完成后输出图片的宽度和高度
function checkPicurl(url){
var img = new Image();img.src = url;
img.onerror = function(){
alert(name+" 图片加载失败,请检查url是否正确");
return false;
};
if(img.complete){
console.log(img.width+" "+img.height);
}else{
img.onload = function(){
console.log(img.width+" "+img.height);
img.onload=null;//避免重复加载
}
}
}
php方法:
使用php是因为出现了这样的需求:已经入库一批数据,这些数据的url字段值没有拼接图片宽和高的信息,而需求是希望记录,这样就要从表中识别出没有拼图片宽高的数据,并分别获取每个图片url的尺寸信息,在更新到表中。通过java实现相对繁琐,而php中提供了GetImageSize函数,可以获取本地和网络图片的尺寸信息,函数说明如下:
GetImageSize:取得图片的长宽。
语法: array getimagesize(string filename, array [imageinfo]);
返回值: 数组
函数种类: 图形处理
内容说明
本函数可用来取得 GIF、JPEG 及 PNG 三种 WWW 上图片的高与宽,不需要安装 GD library 就可以使用本函数。返回的数组有四个元素。返回数组的第一个元素 (索引值 0) 是图片的高度,单位是像素 (pixel)。第二个元素 (索引值 1) 是图片的宽度。第三个元素 (索引值 2) 是图片的文件格式,其值 1 为 GIF 格式、 2 为 JPEG/JPG 格式、3 为 PNG 格式。第四个元素 (索引值 3) 为图片的高与宽字符串,height=xxx width=yyy。可省略的参数 imageinfo 用来取得一些图片的相关信息,例如 IPTC (http://www.xe.net/iptc) 的 APP13 标记,就可以加在图片中,可利用 iptcparse() 来解析。
使用范例
<?php
function MyImg($imgfile) {
$size = GetImageSize($imgfile);
echo "<img src=\"$imgfile\" $size[3]>";
}
MyImg("img/img1.gif");
MyImg("http://img02.sogoucdn.com/app/a/100520052/5a1f885e25b7af28822b14dc069a5f16");
?>
- 通过url获取图片尺寸的几种方法:JS和php
- Python通过url获取图片的几种方法
- PHP获取重定向URL的几种方法
- js和php获取当前url的方法
- js获取url参数的几种方法
- js获取url参数值的几种方法
- JS获取URL地址的几种方法
- JS获取几种URL地址的方法
- JS获取几种URL地址的方法小结
- JS获取几种URL地址的方法
- js通过URL快速获取图片宽高的方法
- php获取请求url时响应的报头信息几种方法
- 使用JS准确获取URL网址中参数的几种方法
- JS获取IP、MAC和主机名的几种方法
- JS获取IP、MAC和主机名的几种方法
- JS获取IP、MAC和主机名的几种方法
- JS获取IP、MAC和主机名的几种方法
- JS获取IP、MAC和主机名的几种方法
- Android里merge和include标签的使用
- Fragment 类相关小知识
- CodeForces 204A Little Elephant and Interval
- ORMLite应用之去Annotation化
- 学习笔记:NSScanner类的使用
- 通过url获取图片尺寸的几种方法:JS和php
- 图像语义分析--深度学习方法
- 【入门】计算等腰三角形中的数字的位置
- 留不住的2014
- 【BZOJ3890】【Usaco2015 Jan】Meeting Time 拓扑图简单DP
- TTTAttributedLabel 使用方法
- activity继承Cocos2dxActivity后无法监听安卓返回按键
- Objective-C省市区用类代替字典存储和读取
- jsp总结