本篇文章给大家带来的内容是关于nodejs搭建web服务器的方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
前端获取数据时经常会遇到跨域问题,用 nginx 做反向代理就可以解决此问题。但是 nginx 属于中间件代理,不同开发者布署的 web 服务器地址可能不一样,这样 nginx 的配置就不能做到通用了。
如果能有一个客户端代理,随着项目源代码提交,这样就可以免去不同开发者的代理配置。webpack-dev-server 就是这样的一个客户端代理,但是如果项目没有用到 webpack,那就没办法用了。那能不能仿照写了一个简单的 web 服务器,用于非 webpack 的项目呢。下面是代码,望大佬们批评指正。
const request = require('request');const express = require('express');const path = require('path');const app = express();// 代理配置const proxytable = { '/api': { target: 'http://localhost/api' }};app.use(function(req, res,next) { const url = req.url; if (req.method == 'options') { console.log('options_url: ', url); // 设置cors 跨域 // res.header(access-control-allow-origin, req.headers.origin || '*'); // res.header(access-control-allow-headers, content-type, authorization, x-requested-with); // res.header(access-control-allow-methods, put,post,get,delete,options); // 设置 cookie // res.header(access-control-allow-credentials, true); res.status(200).send('ok'); return; } // console.log('req_url: ', url); next();});// 设置静态目录app.use(express.static(path.join(__dirname, 'static')));app.use('/', function(req, res) { const url = req.url; const proxy = object.keys(proxytable); let not_found = true; for (let index = 0; index < proxy.length; index++) { const k = proxy[index]; const i = url.indexof(k); if (i >= 0) { not_found = false; const element = proxytable[k]; const newurl = element.target + url.slice(i+k.length); req.pipe(request({url: newurl, timeout: 60000},(err)=>{ if(err){ console.log('error_url: ', err.code,url); res.status(500).send(''); } })).pipe(res); break; } } if(not_found) { console.log('not_found_url: ', url); res.status(404).send('not found'); } else { console.log('proxy_url: ', url); }});// 监听端口 const port = 8080;app.listen(port, () => { console.log('http server is running on: http://localhost:%s', port);});
ps:static 放静态页面
以上就是nodejs搭建web服务器的方法的详细内容。