全部产品
存储与CDN 数据库 安全 应用服务 数加·人工智能 数加·大数据基础服务 互联网中间件 视频服务 开发者工具 解决方案 物联网
对象存储 OSS

图片处理

更新时间:2017-08-08 11:12:44

OSS图片处理,是OSS对外提供的海量、安全、低成本、高可靠的图片处理服务。用户将原始图片上传保存到OSS,通过简单的 RESTful 接口,在任何时间、任何地点、任何互联网设备上对图片进行处理。图片处理提供图片处理接口,图片上传请使用上传接口。基于OSS图片处理,用户可以搭建自己的图片处理服务。

图片处理基础功能

OSS图片处理提供以下功能:

图片处理使用

图片处理使用标准的 HTTP GET 请求来访问,所有的处理参数是编码在 URL 中的QueyString。

匿名访问

如果图片文件(Object)的访问权限是 公共读 ,如下表所示的权限,则可以匿名访问图片服务。

Bucket权限 Object权限
公共读私有写(public-read)或
公共读写(public-read-write)
默认(default)
任意权限 公共读私有写(public-read)或
公共读写(public-read-write)

通过如下格式的三级域名匿名访问图片处理:

  1. http://bucket.<endpoint>/object?x-oss-process=image/action,parame_value
  • bucket:用户的存储空间(bucket)名称
  • endpoint:用户存储空间所在数据中心的访问域名
  • object:用户上传在OSS上的图片文件
  • image:图片处理保留标志符
  • action:用户对图片做的操作,如缩放、裁剪、旋转等
  • parame:用户对图片做的操作所对应的参数

例如:

  1. http://image-demo.oss-cn-hangzhou.aliyuncs.com/example.jpg?x-oss-process=image/resize,w_100

自定义样式,使用如下格式的三级域名匿名访问图片处理:

  1. http://bucket.<endpoint>/object?x-oss-process=x-oss-process=style/name
  • style:用户自定义样式系统保留标志符
  • name:自定义样式名称,即控制台定义样式的 规则名

例如:

  1. http://image-demo.oss-cn-hangzhou.aliyuncs.com/example.jpg?x-oss-process=style/oss-pic-style-w-100

通过级联处理,可以对一张图片顺序实施多个操作,格式如下:

  1. http://bucket.<endpoint>/object?x-oss-process=image/action,parame_value/action,parame_value/...

例如:

  1. http://image-demo.oss-cn-hangzhou.aliyuncs.com/example.jpg?x-oss-process=image/resize,w_100/rotate,90

图片服务也支持HTTPS访问,例如:

  1. https://image-demo.oss-cn-hangzhou.aliyuncs.com/example.jpg?x-oss-process=image/resize,w_100

授权访问

对私有权限的文件(Object),如下表所示的权限,必须通过授权才能访问图片服务。

Bucket权限 Object权限
私有读写(private) 默认权限(default)
任意权限 私有读写(private)

生成带签名的图片处理的URL代码如下:

  1. <?php
  2. require_once __DIR__ . '/vendor/autoload.php';
  3. use OSS\OssClient;
  4. $endpoint = "<endpoint, 例如http://oss-cn-hangzhou.aliyuncs.com>";
  5. $accessKeyId = "<access_key_id>";
  6. $accessKeySecret = "<access_key_secret>";
  7. $bucket = "<bucket_name>";
  8. $object = "example.jpg";
  9. $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
  10. /**
  11. * 生成一个带签名的可用于浏览器直接打开的url, URL的有效期是3600秒
  12. */
  13. $timeout = 3600;
  14. $options = array(
  15. OssClient::OSS_PROCESS => "image/resize,m_lfit,h_100,w_100" );
  16. $signedUrl = $ossClient->signUrl($bucket, $object, $timeout, "GET", $options);
  17. Common::println("rtmp url: \n" . $signedUrl);

提示:

  • 授权访问支持 自定义样式HTTPS级联处理
  • signedUrl 过期时间单位是

SDK访问

对于任意权限的图片文件,都可以直接使用 SDK 访问图片、进行处理。

提示:

  • 图片处理的完整代码请参考:GitHub
  • SDK处理图片文件支持 自定义样式HTTPS级联处理

基础操作

图片处理的基础操作包括,获取图片信息格式转换缩放裁剪旋转效果水印等。

  1. <?php
  2. require_once __DIR__ . '/vendor/autoload.php';
  3. use OSS\OssClient;
  4. $endpoint = "<endpoint, 例如http://oss-cn-hangzhou.aliyuncs.com>";
  5. $accessKeyId = "<access_key_id>";
  6. $accessKeySecret = "<access_key_secret>";
  7. $bucket = "<bucket_name>";
  8. $object = "example.jpg";
  9. $download_file = "download.jpg";
  10. $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
  11. // 先把本地的example.jpg上传到指定$bucket, 命名为$object
  12. $ossClient->uploadFile($bucket, $object, "example.jpg");
  13. // 图片缩放
  14. $options = array(
  15. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  16. OssClient::OSS_PROCESS => "image/resize,m_fixed,h_100,w_100" );
  17. $ossClient->getObject($bucket, $object, $options);
  18. // 图片裁剪
  19. $options = array(
  20. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  21. OssClient::OSS_PROCESS => "image/crop,w_100,h_100,x_100,y_100,r_1" );
  22. $ossClient->getObject($bucket, $object, $options);
  23. // 图片旋转
  24. $options = array(
  25. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  26. OssClient::OSS_PROCESS => "image/rotate,90" );
  27. $ossClient->getObject($bucket, $object, $options);
  28. // 图片锐化
  29. $options = array(
  30. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  31. OssClient::OSS_PROCESS => "image/sharpen,100" );
  32. $ossClient->getObject($bucket, $object, $options);
  33. // 图片水印
  34. $options = array(
  35. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  36. OssClient::OSS_PROCESS => "image/watermark,text_SGVsbG8g5Zu-54mH5pyN5YqhIQ" );
  37. $ossClient->getObject($bucket, $object, $options);
  38. // 图片格式转换
  39. $options = array(
  40. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  41. OssClient::OSS_PROCESS => "image/format,png" );
  42. $ossClient->getObject($bucket, $object, $options);
  43. // 获取图片信息
  44. $options = array(
  45. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  46. OssClient::OSS_PROCESS => "image/info" );
  47. $ossClient->getObject($bucket, $object, $options);
  48. //最后删除上传的$object
  49. $ossClient->deleteObject($bucket, $object);

自定义样式

  1. <?php
  2. require_once __DIR__ . '/vendor/autoload.php';
  3. use OSS\OssClient;
  4. $endpoint = "<endpoint, 例如http://oss-cn-hangzhou.aliyuncs.com>";
  5. $accessKeyId = "<access_key_id>";
  6. $accessKeySecret = "<access_key_secret>";
  7. $bucket = "<bucket_name>";
  8. $object = "example.jpg";
  9. $download_file = "download.jpg";
  10. $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
  11. // 先把本地的example.jpg上传到指定$bucket, 命名为$object
  12. $ossClient->uploadFile($bucket, $object, "example.jpg");
  13. $style = "style/oss-pic-style-w-300";
  14. $options = array(
  15. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  16. OssClient::OSS_PROCESS => $style);
  17. $ossClient->getObject($bucket, $object, $options);
  18. //最后删除上传的$object
  19. $ossClient->deleteObject($bucket, $object);

级联处理

  1. <?php
  2. require_once __DIR__ . '/vendor/autoload.php';
  3. use OSS\OssClient;
  4. $endpoint = "<endpoint, 例如http://oss-cn-hangzhou.aliyuncs.com>";
  5. $accessKeyId = "<access_key_id>";
  6. $accessKeySecret = "<access_key_secret>";
  7. $bucket = "<bucket_name>";
  8. $object = "example.jpg";
  9. $download_file = "download.jpg";
  10. $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint, false);
  11. // 先把本地的example.jpg上传到指定$bucket, 命名为$object
  12. $ossClient->uploadFile($bucket, $object, "example.jpg");
  13. $style = "image/resize,m_fixed,w_100,h_100/rotate,90";
  14. $options = array(
  15. OssClient::OSS_FILE_DOWNLOAD => $download_file,
  16. OssClient::OSS_PROCESS => $style);
  17. $ossClient->getObject($bucket, $object, $options);
  18. //最后删除上传的$object
  19. $ossClient->deleteObject($bucket, $object);

图片处理工具

  • 可视化图片处理工具 ImageStyleViever ,可以直观的看到OSS图片处理的结果
  • OSS图片处理的功能、使用演示 页面
本文导读目录