在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('服务器返回的字符串');
}
相关推荐
2501_945424807 分钟前
C++编译期矩阵运算
开发语言·c++·算法
yy我不解释11 分钟前
关于comfyui的mmaudio音频生成插件时时间不一致问题(三)
开发语言·python·ai作画·音视频·comfyui
2301_8154829313 分钟前
C++中的类型标签分发
开发语言·c++·算法
SuperEugene13 分钟前
Vue3 模板语法规范实战:v-if/v-for 不混用 + 表达式精简,避坑指南|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
xushichao198918 分钟前
代码生成优化技术
开发语言·c++·算法
Luna-player20 分钟前
Vue 3 + Vue Router 的路由配置,简单示例
前端·javascript·vue.js
leaves falling27 分钟前
C++类和对象(1)
开发语言·c++
敲代码的约德尔人31 分钟前
JavaScript 设计模式完全指南
javascript·设计模式
2401_8732046531 分钟前
模板编译期循环展开
开发语言·c++·算法