抖音开放平台Logo
开发者文档
控制台
  • API 概览
  • 开放能力
  • 基础
  • 渲染
  • 设备
  • 文件
  • 位置
  • 媒体
  • 网络
  • 发起请求
  • tt.request
  • RequestTask
  • RequestTask.abort
  • 下载
  • 上传
  • Websocket
  • 游戏转发分享
  • 实时语音
  • 数据缓存
  • 系统
  • 广告
  • 界面
  • 支付
  • Worker
  • tt.request
    收藏
    我的收藏

    基础库 1.0.0 开始支持本方法,这是一个异步方法。

    发起一个网络请求。

    前提条件

    网络相关的 API 在使用前需要配置域名白名单,请前往开发者平台「开发 - 开发设置」,添加 request 合法域名

    业务背景
    使用限制
    • header 不支持设置 referer、user-agent 字段。
    • tt.request 目前只支持 HTTPS 协议的请求 。
    注意事项
    相关教程

    语法

    tt.request(options)

    参数说明

    options 为 object 类型,属性如下:

    属性名类型默认值必填说明最低支持版本
    urlstring

    请求地址

    1.0.0
    headerobject{"content-type": "application/json"}

    请求 Header

    1.0.0
    methodenumGET

    网络请求方法

    1.0.0
    dataobject

    请求的参数。object / array / ArrayBuffer 类型

    1.0.0
    dataTypestringjson

    期望返回的数据类型,支持 json、string

    1.0.0
    responseTypestringtext

    期望响应的数据类型,支持 text 或 arraybuffer

    1.0.0
    successfunction
    接口调用成功的回调函数
    1.0.0
    failfunction
    接口调用失败的回调函数
    1.0.0
    completefunction
    接口调用结束的回调函数(调用成功、失败都会执行)
    1.0.0

    header 参数说明

    referer

    网络请求 header 中的 referer 不可设置。 其固定格式为:https://tmaservice.developer.toutiao.com?appid={appid}&version={appVersion},其中 appid为小游戏的 APPID,appVersion为小游戏的版本号。

    user-agent

    网络请求 header 中的 user-agent 不可设置。 其固定格式分为:

    • IOS 系统:[系统user-agent] [宿主标识]/[宿主app版本] ToutiaoMicroApp/[基础库版本] webview/[插件版本]。
    • Android 系统:[系统user-agent] [宿主标识]/[宿主app版本] ToutiaoMicroApp/[基础库版本] PluginVersion/[插件版本]。

    data 参数说明

    传给服务器的数据最终会是 String 类型,如果 data 不是 String 类型,会被转换成 String 。转换规则如下:

    1. 如果数据类型是 string 或者是 arraybuffer,则直接返回该数据;
    2. 如果 header['content-type'] 是 application/x-www-form-urlencoded,会将数据转换成 query string: encodeURIComponent(k)=encodeURIComponent(v)&encodeURIComponent(k)=encodeURIComponent(v)...,然后返回该数据。
    3. 如果 header['content-type'] 是 application/json,则会对数据进行 JSON 序列化,然后返回该数据。
    4. 如果数据类型是 object,则会对数据进行 JSON 序列化,然后返回该数据。
    5. 如果是其他情况,则直接调用数据的 toString(), 然后返回该数据。

    method 的合法值

    说明最低支持版本
    GET

    GET 请求

    1.0.0
    OPTIONS

    OPTIONS 请求

    1.0.0
    HEAD

    HEAD 请求

    1.0.0
    POST

    POST 请求

    1.0.0
    PUT

    PUT 请求

    1.0.0
    DELETE

    DELETE 请求

    1.0.0

    回调成功

    object 类型,属性如下:

    属性名类型说明最低支持版本
    statusCodenumber

    返回的 HTTP 状态码

    1.0.0
    headerobject

    返回的 HTTP Response Header

    1.0.0
    datastring

    返回的数据,类型取决于 dataType 和 responseType 参数

    1.0.0
    errMsgstring

    "request:ok"

    1.0.0

    回调失败

    object 类型,属性如下:

    属性名类型说明最低支持版本
    errMsgstring

    "request:fail " + 详细错误信息

    1.0.0

    返回值

    类型说明最低支持版本
    object

    RequestTask(网络请求任务对象),调用 tt.request 后返回的请求对象。

    1.0.0

    错误码

    errorCodeerrMsgerrorType说明最低支持版本
    999999invalid paramD
    参数错误
    1.0.0
    999991internal errorF
    小游戏框架内部错误,有需要请创建工单咨询
    1.0.0
    999993internal errorF
    小游戏框架内部错误,有需要请创建工单咨询
    1.0.0
    104001url not in domain list, url == %sD
    1.0.0
    999999url is invalid, url == %sD
    1.0.0
    999999url use invalid protocol, url == %s, url support protocol is %sD
    1.0.0
    104004invoke permission deniedD
    1.0.0
    104002no requestTaskIdF
    小游戏框架内部错误,有需要请创建工单咨询
    1.0.0
    104003abortI
    1.0.0
    999999params $paramName is requiredD
    1.0.0
    999999params $paramName type is not $paramType typeD
    1.0.0
    999999$paramName is invalidD
    1.0.0
    999999url is not valid domain, url == $urlD
    可以包含上一种
    1.0.0
    999999method is invalidD
    1.0.0
    999993internal errorF
    小游戏框架内部错误,有需要请创建工单咨询
    1.0.0
    999994app in backgroundU
    1.0.0
    104022abortU
    1.0.0
    104007url is not valid domain, url == $urlD
    1.0.0
    104008url is not valid domain, url == $urlF
    小游戏框架内部错误,有需要请创建工单咨询
    1.0.0
    104001url is not valid domain, url == $urlD
    1.0.0

    扫码体验

    请使用字节宿主APP扫码

    代码示例

    开发者工具中预览

    【代码示例 1】:post 请求返回 dataType 为 json 类型的数据,并且可能会中断请求。

    let task = tt.request({ url: "someurl", data: { user_name: "hello", }, header: { "content-type": "application/json", }, method: "POST", dataType: "JSON", // 指定返回数据的类型为 json responseType: "text", success(res) { console.log("调用成功", res.data) }, fail(res) { console.log("调用失败", res.errMsg) }, }) // 某些条件下中断请求 if (someReason) { task.abort() }

    【代码示例 2】:post 请求返回 dataType 为 string 类型的数据。

    tt.request({ url: "someurl", data: { user_name: "hello", }, header: { "content-type": "application/json", }, method: "POST", dataType: "string", // 指定返回数据的类型为 string responseType: "text", success(res) { console.log("调用成功", res.data) }, fail(res) { console.log("调用失败", res.errMsg) }, })

    【代码示例 3】:post 请求返回 responseType 为 arraybuffer 类型的数据。

    tt.request({ url: "someurl", data: { user_name: "hello", }, header: { "content-type": "application/json", }, method: "POST", dataType: "string", // 在 responseType 为arraybuffer的情况下,不起作用 responseType: "arraybuffer", // 指定返回数据的类型为 arraybuffer success(res) { // 此处返回的res.data类型为 arraybuffer console.log("调用成功", res.data) }, fail(res) { console.log("调用失败", res.errMsg) }, })

    【代码示例 4】:post 请求 header['content-type'] 为 application/x-www-form-urlencoded。

    tt.request({ url: "someurl", data: { user_name: "hello", }, header: { "content-type": "application/x-www-form-urlencoded", // 此处指定content-type类型 }, method: "POST", dataType: "json", responseType: "text", success(res) { console.log("调用成功", res.data) }, fail(res) { console.log("调用失败", res.errMsg) }, })

    【代码示例 5】:post 请求携带 cookie。

    const id = "" tt.request({ url: "someurl", data: { user_name: "hello", }, header: { "content-type": "application/json", cookie: "TOUTIAOID" + id, // 此处添加cookie }, method: "POST", dataType: "json", responseType: "text", success(res) { console.log("调用成功", res.data) }, fail(res) { console.log("调用失败", res.errMsg) }, })

    【代码示例 6】:put 请求。

    tt.request({ url: "someurl", data: { user_name: "hello", }, header: { "content-type": "application/json", }, method: "PUT", // 此处修改请求方法 dataType: "json", responseType: "text", success(res) { console.log("调用成功", res.data) }, fail(res) { console.log("调用失败", res.errMsg) }, })