在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('服务器返回的字符串');
}
相关推荐
I'm Jie17 小时前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户904438163246019 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试
暮乘白帝过重山19 小时前
ArkTS ForEach 参数解析:组件与键值生成器
开发语言·数据库
PPPPickup20 小时前
easychat项目复盘---获取联系人列表,联系人详细,删除拉黑联系人
java·前端·javascript
老前端的功夫20 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
LiamTuc20 小时前
Java构造函数
java·开发语言
三途河畔人20 小时前
Pytho基础语法_运算符
开发语言·python·入门
Benmao⁢20 小时前
C语言期末复习笔记
c语言·开发语言·笔记·leetcode·面试·蓝桥杯
adsadswee20 小时前
Qt 样式与 QLinearGradient 渐变详解
开发语言·qt·qt样式表·qlineargradient·qss渐变效果
花月C20 小时前
个性化推荐:基于用户的协同过滤算法
开发语言·后端·算法·近邻算法