tencent cloud

边缘安全加速平台 EO

动态与公告
产品动态
安全公告
产品公告
产品简介
产品概述
产品优势
应用场景
EdgeOne 与 CDN 等产品功能对比
使用限制
购买指南
试用套餐体验权益说明
免费版套餐使用说明
计费概述
计费项目
购买指引
续费指引
欠费与退款说明
套餐选型对比
关于“干净流量”计费说明
DDoS 防护容量说明
快速入门
选择业务场景
快速接入网站安全加速
通过 Pages 快速部署网站
域名服务与源站配置
域名服务
HTTPS 证书
源站配置
站点加速
概述
访问控制
智能加速
缓存配置
文件优化
网络优化
URL 重写
修改头部
修改应答内容
规则引擎
图片与视频处理
单连接下载限速
DDoS 与 Web 防护
概述
DDoS 防护
Web 防护
Bot 管理
API 资产识别(Beta)
边缘函数
概述
快速指引
操作指引
Runtime APIs
示例函数
实践教程
Pages
四层代理
概述
新建四层代理实例
修改四层代理实例配置
停用/删除四层代理实例
批量配置转发规则
获取客户端真实IP
数据分析与日志服务
日志服务
数据分析
告警服务
站点与计费管理
计费管理
站点管理
版本管理
通用策略
通用参考
配置语法
请求与响应行为
国家/地区及对应代码枚举
Terraform
Terraform 简介
安装和配置 Terraform
实践教程
自动预热/清除缓存
防盗刷/盗链实践
HTTPS 相关实践
加速优化
流量调度
数据分析与告警
第三方日志平台集成实践
对象存储类源站(例如:COS)配置实践
跨域响应配置
API 文档
History
Introduction
API Category
Making API Requests
Site APIs
Acceleration Domain Management APIs
Site Acceleration Configuration APIs
Edge Function APIs
Alias Domain APIs
Security Configuration APIs
Layer 4 Application Proxy APIs
Content Management APIs
Data Analysis APIs
Log Service APIs
Billing APIs
Certificate APIs
Origin Protection APIs
Load Balancing APIs
Diagnostic Tool APIs
Custom Response Page APIs
API Security APIs
DNS Record APIs
Content Identifier APIs
Legacy APIs
Ownership APIs
Image and Video Processing APIs
Multi-Channel Security Gateway APIs
Version Management APIs
Data Types
Error Codes
常见问题
产品特性相关问题
DNS 记录相关问题
域名配置相关问题
站点加速相关问题
数据与日志相关问题
安全防护相关问题
源站配置相关问题
排障指南
异常状态码参考
EdgeOne 4XX/5XX 状态码排障指南
520/524状态码排障指南
521/522 状态码排障指南
工具指南
相关协议
Service Level Agreement
源站防护启用特别约定
TEO 政策
隐私协议
数据处理和安全协议
联系我们
词汇表

Encoding

PDF
聚焦模式
字号
最后更新时间: 2024-01-30 16:53:08
基于 Web APIs 标准 TextEncoderTextDecoder 进行设计,实现了编码器与解码器。

TextEncoder

编码器,接受码点流作为输入,并输出 UTF-8 字节流。请参考 MDN 官方文档 TextEncoder

构造函数

// TextEncoder 构造函数,不接受任何参数。
const encoder = new TextEncoder();

属性

// encoder.encoding
readonly encoding: string;
编码器的编码类型,当前值仅为 UTF-8

方法

encode

encoder.encode(input?: string | undefined): Uint8Array
接受码点流作为输入,并输出 UTF-8 字节流。
注意:
input 最大长度为 300M,超出长度会抛出异常。
encoder.encode 参数
参数名称
类型
必填
说明
input
string | undefined
编码器输入值。

encodeInto

encoder.encodeInto(input: string, destination: Uint8Array): EncodeIntoResult;
接受码点流作为输入,输出 UTF-8 字节流,并写入到参数 destination 字节数组中。
参数
参数名称
类型
必填
说明
input
string
编码器输入值。
destination
编码器输出值。
返回值 EncodeIntoResult
属性名
类型
说明
read
number
已转换为 UTF-8 的 UTF-16 单元数。
written
number
目标 Uint8Array 中修改的字节数。

TextDecoder

解码器。将字节流作为输入,并提供码点流作为输出。请参考 MDN 官方文档 TextDecoder

构造方法

const decoder = new TextDecoder(label?: string | undefined, options?: DecoderOptions | undefined): TextEncoder;

参数

注意:
参数 label ,下述的值暂不支持:
iso-8859-16。
hz-gb-2312。
csiso2022kr,iso-2022-kr。
参数名称
类型
必填
说明
label
string | undefined
解码器类型,默认值为 UTF-8。可选的 label 值参考 MDN 官方文档
options
DecoderOptions | undefined
解码器配置项

DecoderOptions

解码器配置项如下所示。
属性名
类型
默认值
说明
fatal
boolean
false
标识解码失败时是否抛出异常
ignoreBOM
boolean
false
标识是否忽略 byte-order marker

属性

encoding

// decoder.encoding
readonly encoding: string;
解码器类型。

fatal

// decoder.fatal
readonly fatal: boolean;
当解码失败,标识是否抛出异常。

ignoreBOM

// decoder.ignoreBOM
readonly ignoreBOM: boolean;
标识是否忽略 byte-order marker

方法

decode

const result = decoder.decode(buffer?: ArrayBuffer | ArrayBufferView | undefined, options?: DecodeOptions | undefined): string;
注意:
参数 buffer 最大长度为 100M,超出长度会抛出异常。
参数名称
类型
必填
说明
buffer
待解码的字节流。
buffer 最大长度为 100M,超出长度会抛出异。
options
执行解码配置项。

DecodeOptions

执行解码配置项如下所示。
属性名
类型
默认值
说明
stream
boolean
false
设置流式解码,默认为 false ,取值说明如下。
true
表示以 chunk 的方式处理数据,即流式解码。
false
表示 chunk 已结束或未使用 chunk 处理数据,即非流式解码。

示例代码

function handleEvent(event) {
// 编码器
const encoder = new TextEncoder();
const encodeText = encoder.encode('hello world');

// 解码器
const decoder = new TextDecoder();
const decodeText = decoder.decode(encodeText);

// 客户端响应内容
const response = new Response(JSON.stringify({
encodeText: encodeText.toString(),
decodeText,
}));

return response;
}

addEventListener('fetch', (event) => {
event.respondWith(handleEvent(event));
});

相关参考

帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈