尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

短视频系统源码,启动一个node后台服务 - 云豹科技

短视频系统源码,启动一个node后台服务 - 云豹科技
📅 发布时间:2026/6/20 20:53:40

短视频系统源码,启动一个node后台服务

使用koa创建的方式

入口index.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><!-- form的请求 --><form action="/add" method="POST"><input type="text" name="key1"><input type="submit" value="Add"></form><script src="https://cdn.bootcdn.net/ajax/libs/axios/0.21.0/axios.js"></script><script>// axios的请求(async () => {const res2 = await axios.post('/api/users', {key: 'value',});document.writeln(`RES : ${JSON.stringify(res2.data)}`)})()</script>
</body>
</html>

index.js

const Koa = require('koa');
const app = new Koa();
const router = require('koa-router')();const bodyParser = require('koa-bodyparser');     // 用于处理form表达提交的数据格式
app.use(require('koa-static')(__dirname + '/'));  // 引入index.html文件
app.use(bodyParser());router.post('/add', async (ctx, next) => {console.log('body', ctx.request.body)ctx.body='这是post请求';
})
router.get('/add', async (ctx, next) => {console.log('body', ctx.request.body)
})
router.post('/api/users', async (ctx, next) => {console.log('body', ctx.request.body)
})app.use(router.routes())
app.listen(3000)

使用http的方式,创建包含跨域的请求(正向代理、反向代理)

index.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script src="https://cdn.bootcdn.net/ajax/libs/axios/0.21.0/axios.js"></script><script>(async () => {// 跨域请求,客户端正向代理方式(反向代理则不需要这些配置)axios.defaults.baseURL = 'http://localhost:4000';axios.defaults.withCredentials = trueconst res2 = await axios.post('/api/users', {key: 'value',});document.writeln(`RES : ${JSON.stringify(res2.data)}`)})()</script>
</body>
</html>

index.js

const api = require('./api');
const proxy = require('./proxy');
api.listen(4000);
proxy.listen(3000);

proxy.js

const express = require('express');
const app = express();
app.use(express.static(__dirname + '/'));// 跨域请求,服务端反向代理方式(正向代理则不需要这些配置)
const {createProxyMiddleware} = require('http-proxy-middleware');  // 代理插件
app.use('/api', createProxyMiddleware({target: 'http://localhost:4000',changeOrigin: false,
}))module.exports = app;

api.js

const http = require('http');
const fs = require('fs');
const app = http.createServer((req, res) => {const {url, method, headers} = req;// 返回index.htmlif (url === '/' && method === 'GET') {fs.readFile('index.html', (err, data) => {if (err) {res.writeHead(500, {'Content-Type': 'text/plain'});res.end('服务器错误')}res.writeHead(200, {'Content-Type': 'text/html'})res.end(data)})// 处理/api/users} else if ((method === 'GET' || method === 'POST') && url === '/api/users') {// 正向代理需要的配置(反向代理则不需要这些配置)res.setHeader('Access-Control-Allow-Origin', 'http://localhost:3000')res.setHeader('Access-Control-Allow-Credentials', 'true')res.setHeader('Content-Type', 'application/json');res.setHeader('Set-Cookie', 'cookie=val12123')res.end(JSON.stringify([{name: 'tom'}]))} else if (method === 'OPTIONS' && url === '/api/users') {// 正向代理需要的配置(反向代理则不需要这些配置)res.setHeader('Access-Control-Allow-Credentials', 'true')res.writeHead(200, {'Access-Control-Allow-Origin' : 'http://localhost:3000','Access-Control-Allow-Headers' : 'X-Token,Content-Type','Access-Control-Allow-Methods' : 'PUT',})res.end()}
})
module.exports = app;

以上就是短视频系统源码,启动一个node后台服务, 更多内容欢迎关注之后的文章

相关新闻

  • pg 批量数据插入
  • 2025年口碑好的小型台车炉用户口碑最好的厂家榜
  • 2025年哈尔滨汽车隐形车衣品牌与安装店排行榜,信誉好的不错

最新新闻

  • 2026年AI生产力实操地图:四类高鲁棒性工具落地指南
  • 《循序渐进Python案例教程》全套PPT课件
  • uniapp全屏弹窗实战:穿透原生导航与TabBar的全局模态层方案
  • 《商家地址路线导航》三、开通地图服务指南
  • 领航城桶装水瓶装水送水电话多少 - 资讯速览
  • 从关联到重构:经典鬼成像的核心算法演进与实践

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号