$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); }