全球主机交流论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

CeraNetworks网络延迟测速工具IP归属甄别会员请立即修改密码
查看: 1099|回复: 7

[经验] 腾讯云边缘安全加速(EdgeOne)之图片优化

[复制链接]
发表于 2023-7-5 16:26:40 | 显示全部楼层 |阅读模式
本帖最后由 ixff 于 2023-7-5 16:46 编辑

EdgeOne 是个好东西,9.9包邮~~

转一篇好文,但是链接和图片都掉了,感兴趣的话,可以查看原文 https://cloud.tencent.com/developer/article/2298557

应用背景
前面已经介绍过 EdgeOne 的基本使用方法(参见 腾讯云下一代CDN(EdgeOne/边缘安全加速)开箱即用 一文),本文将介绍如何使用 EdgeOne Worker 实现图片格式转换。

通过云边缘函数实现自动优化图片格式,可以提升页面加载速度,优化图片加速性能,进而提高网站的用户体验。

产品介绍
腾讯云边缘函数(Edge Functions)提供了 EdgeOne 边缘节点的 Serverless 代码执行环境,您只需编写业务函数代码并设置触发规则,无需配置和管理服务器等基础设施,即可在靠近用户的边缘节点上弹性、安全地运行代码。

目前该功能已公测上线,个人版优惠后仅9.9元/月,最近一段时间用下来,感觉还是方便的,尤其是处理图片缩放和格式转化的时候,使用免费的边缘函数来实现,香飘四野啊~~

套餐信息请查阅产品购买地址。更多优惠信息可打开腾讯云 开发者上云加油站 查看(注:介意CPS者慎入)

实现步骤
官方最佳实践示例代码通过判断浏览器类型来设置转化格式,但是判断逻辑过于简单,容易产生误判导致返回不支持的编码格式。本文通过获取请求头中的 Accept 信息,来识别浏览器支持的图片类型,并使用 fetch API 获取源站图片,根据浏览器支持的图片编码类型对图片进行格式转换,以实现图片自适应格式的效果。

接入 EdgeOne,参见 从零开始快速接入 EdgeOne
启用 站点加速 > 媒体处理 > 图片缩放 功能,参见 EdgeOne 图片处理
创建 Worker,并将以下 边缘函数代码 复制到 代码编辑器 中,参见 边缘函数(EdgeOne Functions)快速指引
设置 Worker 触发规则,匹配类型选择 文件后缀,运算符选择 等于,值输入 png、jpg、jpeg

【图一】


验证函数是否按照预期运行,您可通过在浏览器或 Curl 发起请求测验,查看返回的头信息是否包含Backend-Option,以及其值是否为{"eo":{"image":{"format":"avif"}}}或{"eo":{"image":{"format":"webp"}}}。若包含且值正确,则表示函数已按照预期运行

【图二】


另外还支持调整图片尺寸,使用示例 https://www.rehiy.com/logo.png?100x100,其中 100x100 代表 长x宽,如果其中一个为 0 则表示对应的边自适应
边缘函数代码

  1. /**
  2. * 图片转换 for EdgeOne Worker
  3. * [url=home.php?mod=space&uid=32982]@URL[/url] https://www.rehiy.com/post/505/
  4. * @author Rehiy
  5. */

  6. async function handleEvent(request) {
  7.     const uObj = new URL(request.url);
  8.     const resize = uObj.search.match(/(\d+)x(\d+)/);
  9.     const accept = request.headers.get('Accept');

  10.     const option = {
  11.         eo: {
  12.             image: {},
  13.             cacheKey: request.url,
  14.         }
  15.     };

  16.     if (resize) {
  17.         if (resize[1] > 0) {
  18.             option.eo.image.width = +resize[1];
  19.         }
  20.         if (resize[2] > 0) {
  21.             option.eo.image.height = +resize[2];
  22.         }
  23.     }

  24.     for (const format of ['avif', 'webp', 'jp2', 'jxr', 'heif']) {
  25.         if (accept.includes(format)) {
  26.             option.eo.image.format = format;
  27.             option.eo.cacheKey += '.' + format;
  28.             break;
  29.         }
  30.     }

  31.     const resp = await fetch(request, option);
  32.     resp.headers.set('Backend-Option', JSON.stringify(option));
  33.     resp.headers.set('Vary', 'Accept');

  34.     return resp;
  35. }

  36. // eo listener

  37. addEventListener('fetch', event => {
  38.     event.passThroughOnException();
  39.     event.respondWith(handleEvent(event.request));
  40. });
复制代码

发表于 2023-7-5 16:31:52 | 显示全部楼层
看不懂,学习一波
发表于 2023-7-5 16:45:32 | 显示全部楼层
没有流量使用限制吗
 楼主| 发表于 2023-7-5 16:47:01 | 显示全部楼层
机长 发表于 2023-7-5 16:45
没有流量使用限制吗

有50g带高防
发表于 2023-7-5 16:47:39 | 显示全部楼层
一刷,噶了,这种乱刷的太多了
发表于 2023-7-5 16:54:27 | 显示全部楼层

看了 个人的不够用 企业的太贵 自己转wehp吧
发表于 2023-7-5 18:13:11 | 显示全部楼层
百度的edgejs可以用这个吗
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|全球主机交流论坛

GMT+8, 2024-5-5 10:39 , Processed in 0.061315 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表