在JavaScript / Node.js / 抖音小游戏中,使用tt.request通信

抖音小游戏中使用tt.request向基于node.js的web应用服务器发送数据,并接收服务器返回的数据。

javascript 复制代码
// 抖音小游戏
let r = tt.request({
    url: "https://www.abcd.com:4321/abc/PostAPI",
    header: { "content-type": "text/plain" },
    method: "POST",
    data: '发送给服务器的字符串', 
    dataType: "text", // 根据服务器返回的实际类型设置为text
    responseType: "text",
    timeout: 5000,
    enableProfile: false,
    redirect: "manual", // 重定向拦截策略。manual 拦截;follow 不拦截。
    enableCache: false,
    success(res) {
        console.log(`tt.request success`); // tt.request 执行成功,查看接收到的数据
        console.log(`    res.statusCode=${res.statusCode}`);
        console.log(`    res.header=${res.header}`);
        console.log(`    res.data=${res.data}`);
        console.log(`    res.errMsg=${res.errMsg}`);
    },
    fail(res) {
        console.log(`tt.request fail`);
        console.log(`    res.errMsg=${res.errMsg}`);
    },
    complete() {
        console.log(`tt.request complete`)
    }
});
javascript 复制代码
const express = require('express');
const rateLimit = require('express-rate-limit');
const path = require('path');
const helmet = require('helmet');
const compression = require('compression');
const morgan = require('morgan');
const https = require('https');
const fs = require('fs');
const bodyParser = require('body-parser');
const app = express();
const port = process.env.PORT || 4321;


// #region 添加中间件。添加顺序很重要,先添加安全相关的中间件,再添加其他中间件,最后添加请求处理中间件(路由)。

// 安全中间件
app.use(helmet());
// 添加HSTS头
app.use(helmet.hsts({
    maxAge: 31536000, // 1年有效期
    includeSubDomains: true, // 包含子域名
    preload: true // 允许预加载到浏览器HSTS列表
}));

// 读取SSL证书文件
const credentials = {
    key: fs.readFileSync('/home/ecs-user/server_crystalsearch/privkey.pem'),
    cert: fs.readFileSync('/home/ecs-user/server_crystalsearch/fullchain.pem')
};

// 使用body-parser中间件解析请求体
app.use(bodyParser.text()); // 解析text/plain类型的请求体
app.use(bodyParser.json()); // 解析application/json类型的请求体
app.use(bodyParser.urlencoded({ extended: true })); // 解析application/x-www-form-urlencoded类型的请求体

// 创建HTTPS服务器
// 按照抖音小游戏的要求,必须是https,不能是http
// 且要在开发者控制台中将服务器的域名加入白名单,或在开发者工具的调试中加入白名单
const server = https.createServer(credentials, app).listen(port, () => {
    console.log(`HTTPS server successfully launched: https://localhost:${port}`);
});

app.post('/XuJingYiYun/PostAPI', PostAPI);
async function PostAPI(req, res) {
    // 记录请求信息
    console.log(`PostAPIGetSave req.body=${req.body}`);
    console.log(`PostAPIGetSave req.headers.content-type=${req.headers['content-type']}`);
    // 返回状态码和字符串
    res.status(200).send('服务器返回的字符串');
}
相关推荐
刘发财4 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
ssshooter11 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
Live0000012 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉12 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
球球pick小樱花12 小时前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
喝水的长颈鹿13 小时前
【大白话前端 02】网页从解析到绘制的全流程
前端·javascript
用户145369814587813 小时前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
codingWhat13 小时前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js
码路飞13 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
Lee川13 小时前
优雅进化的JavaScript:从ES6+新特性看现代前端开发范式
javascript·面试