在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('服务器返回的字符串');
}
相关推荐
程序 代码狂人19 小时前
CentOS7初始化配置操作
linux·运维·开发语言·php
从此不归路19 小时前
Qt5 进阶【13】桌面 Qt 项目架构设计:从 MVC/MVVM 到模块划分
开发语言·c++·qt·架构·mvc
zhangx1234_19 小时前
C语言 数据在内存中的存储
c语言·开发语言
星空露珠19 小时前
速算24点检测生成核心lua
开发语言·数据库·算法·游戏·lua
老蒋每日coding19 小时前
Python3基础练习题详解,从入门到熟练的 50 个实例(一)
开发语言·python
历程里程碑20 小时前
Linux15 进程二
linux·运维·服务器·开发语言·数据结构·c++·笔记
lly20240620 小时前
网站主机提供商:如何选择最适合您的服务
开发语言
HAPPY酷20 小时前
构建即自由:一份为创造者设计的 Windows C++ 自动化构建指南
开发语言·c++·ide·windows·python·策略模式·visual studio
工一木子20 小时前
Java 的前世今生:从 Oak 到现代企业级语言
java·开发语言
css趣多多20 小时前
this.$watch
前端·javascript·vue.js