1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- <?php
- require dirname(__FILE__, 2) . '/vendor/autoload.php';
- $secretId = "SECRETID"; //替换为用户的 secretId,请登录访问管理控制台进行查看和管理,https://console.cloud.tencent.com/cam/capi
- $secretKey = "SECRETKEY"; //替换为用户的 secretKey,请登录访问管理控制台进行查看和管理,https://console.cloud.tencent.com/cam/capi
- $region = "ap-beijing"; //替换为用户的 region,已创建桶归属的region可以在控制台查看,https://console.cloud.tencent.com/cos5/bucket
- $cosClient = new Qcloud\Cos\Client(
- array(
- 'region' => $region,
- 'scheme' => 'https', //协议头部,默认为http
- 'credentials'=> array(
- 'secretId' => $secretId,
- 'secretKey' => $secretKey)));
- try {
- // -------------------- 1. 下载时处理-原图存储在COS -------------------- //
- $object = 'xxx.jpg';
- $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
- $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
- $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
- $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
- $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
- $query = $ciProcessParams->queryString();
- $downloadUrl = $cosClient->getObjectUrl('examplebucket-1250000000', $object); // 获取下载链接
- echo "{$downloadUrl}&{$query}"; // 携带签名的图片地址以“&”连接
- // -------------------- 1. 下载时处理-原图存储在COS -------------------- //
- // -------------------- 2. 下载时处理-原图来自其他链接 -------------------- //
- $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
- $ciProcessParams->addParam('detect-url', 'https://xxx.com/xxx.jpg');
- $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
- $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
- $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
- $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
- $query = $ciProcessParams->queryString();
- $downloadUrl = $cosClient->getObjectUrl('examplebucket-1250000000', ''); // 获取下载链接
- echo "{$downloadUrl}&{$query}";
- // -------------------- 2. 下载时处理-原图来自其他链接 -------------------- //
- // ---------------------------- 3. 上传时处理 ---------------------------- //
- $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
- $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
- $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
- $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
- $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
- $picOperations = new Qcloud\Cos\ImageParamTemplate\PicOperationsTransformation();
- $picOperations->setIsPicInfo(1); // is_pic_info
- $picOperations->addRule($ciProcessParams, "output.png"); // rules
- $result = $cosClient->putObject(array(
- 'Bucket' => 'examplebucket-125000000', //存储桶名称,由BucketName-Appid 组成,可以在COS控制台查看 https://console.cloud.tencent.com/cos5/bucket
- 'Key' => 'object.jpg',
- 'Body' => fopen('/tmp/local.jpg', 'rb'), // 本地文件
- 'PicOperations' => $picOperations->queryString(),
- ));
- // 请求成功
- print_r($result);
- // ---------------------------- 3. 上传时处理 ---------------------------- //
- // --------------------- 4. 云上数据处理 ------------------------------ //
- $ciProcessParams = new Qcloud\Cos\ImageParamTemplate\CIProcessTransformation('AIImageCrop');
- $ciProcessParams->addParam('width', 100); // 需要裁剪区域的宽度,与height共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片宽度的像素值
- $ciProcessParams->addParam('height', 100); // 需要裁剪区域的高度,与width共同组成所需裁剪的图片宽高比例;输入数字请大于0、小于图片高度的像素值;width : height建议取值在[1, 2.5]之间,超过这个范围可能会影响效果
- $ciProcessParams->addParam('fixed', 0); // 是否严格按照 width 和 height 的值进行输出。
- $ciProcessParams->addParam('ignore-error', 1); // 当此参数为1时,针对文件过大等导致处理失败的场景,会直接返回原图而不报错。
- $picOperations = new Qcloud\Cos\ImageParamTemplate\PicOperationsTransformation();
- $picOperations->setIsPicInfo(1); // is_pic_info
- $picOperations->addRule($ciProcessParams, 'output.jpg'); // rules
- $result = $cosClient->ImageProcess(array(
- 'Bucket' => 'examplebucket-1250000000', //存储桶名称,由BucketName-Appid 组成,可以在COS控制台查看 https://console.cloud.tencent.com/cos5/bucket
- 'Key' => 'test.jpg',
- 'PicOperations' => $picOperations->queryString(),
- ));
- // 请求成功
- print_r($result);
- // --------------------- 4. 云上数据处理 ------------------------------ //
- } catch (\Exception $e) {
- // 请求失败
- echo($e);
- }
|