使用express来代理服务的方法
nodejs和nginx都可以反向代理,解决跨域问题。
本地服务
const express = require('express') const app = express() //如果它在最前面,后面的/开头的都会被拦截 app.get('/', (req, res) => res.send('Hello World!')) app.use(express.static('public'));//静态资源 app.use('/dist', express.static(path.join(__dirname, 'public')));//静态资源 //404 app.use('/test', function (req, res, next) { res.status(404).send("Sorry can't find that!"); }); app.use(function (req, res, next) { //TODO 中间件,每个请求都会经过 next(); }); app.use(function (err, req, res, next) { //TODO 失败中间件,请求错误后都会经过 console.error(err.stack); res.status(500).send('Something broke!'); next(); }); app.listen(4000, () => console.log('Example app listening on port 4000!'))
与request配合使用
这样就将其它服务器的请求代理过来了
const request = require('request'); app.use('/base/', function (req, res) { let url = 'http://localhost:3000/base' + req.url; req.pipe(request(url)).pipe(res); });
使用http-proxy-middleware
const http_proxy = require('http-proxy-middleware'); const proxy = { '/tarsier-dcv/': { target: 'http://192.168.1.190:1661' }, '/base/': { target: 'http://localhost:8088', pathRewrite: {'^/base': '/debug/base'} } }; for (let key in proxy) { app.use(key, http_proxy(proxy[key])); }
监听本地文件变化
使用nodemon插件。
--watch test
指监听根目录下test文件夹的所有文件,有变化就会重启服务。
"scripts": { "server": "nodemon --watch build --watch test src/server.js" }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
相关推荐
-
8 行 Node.js 代码实现代理服务器
接触 Node.js 已有多年,一直喜欢它的单线程模型和异步IO特性,以及 JavaScript 语言本身的灵活性.同时,JavaScript 前后端通吃,在全栈开发领域具有独特的优势.今天就来看看作为服务端语言的 JavaScript,完成一个简单的代理服务器功能是多么容易. 简单地说,代理服务器就是代理用户访问目标站点的中介服务器.作为前端开发人员,代理的常见用途是跨域访问后台 API.当然,还可以用来科学上网.今天要分享的代码,就是跟科学上网有关. 话不多说,先上 code: var ex
-
详解node.js搭建代理服务器请求数据
1.引入node.js中的模块 var http = require("http"); var url = require("url"); var qs = require("querystring"); 2.创建服务器 //用node中的http创建服务器 并传入两个形参 http.createServer(function(req , res) { //设置请求头 允许所有域名访问 解决跨域 res.setHeader("Acces
-
腾讯云(ubuntu)下安装 nodejs + 实现 Nginx 反向代理服务器
本文将介绍如何给腾讯云上的 Ubuntu Server 12.04 LTS 64位主机安装 node 及 nginx,并简单配置反向代理. 笔者在整个安装过程中遇到不少麻烦(不赘述),如果你希望少踩坑,可以按本文的步骤进行安装部署. 一. 新版 nodejs 安装 这里强烈推荐使用 nvm (Node版本管理器),其它方式的安装或多或少都有些问题. 具体步骤如下: 1. 通过 git 指令下载nvm 执行指令如下,我们把nvm下载到 /root/git/ 中去(记得要先安装 git): [roo
-
node实现简单的反向代理服务器
每当提起反向代理器,人们通常一想到的就是 Nginx,但是今天我们暂时忽略大名鼎鼎的 Nginx,采用同样也是使用单线程.事件循环的服务端小弟--Node 来达成 跨域问题是前端开发很常见的问题 解决方案有很多种 jsonp返回 Access-Control-Allow-Origin:'*' (需要注意的是 对于post请求会变成option请求需求后端支持) 前端添加代理 前端添加代理 以vue-cli为例,前端添加代理 dev: { env: require('./dev.env'), po
-
教你如何使用node.js制作代理服务器
下面代码实现的功能是这样的: 首先创建一个HTTP服务器,当服务器接收到客户端的请求后,向"www.taobao.com"网站请求数据,当从该网站接受到的响应数据后,将响应数据发送给客户端. 复制代码 代码如下: var http=require("http"); var url=require("url"); var server=http.createServer(function(sreq,sres){ var url_parts=
-
抛弃Nginx使用nodejs做反向代理服务器
时下不少场景,都是申请一个 VPS 主机来托管运行 Web 项目的,小弟我也不例外,购买了一个小型的 Win 03 VPS 使用着.在使用的过程中,面临一个问题,就是同一类型的服务端环境还好--但如果是一个 PHP.一个 ASP. 一个 JSP 的三种类型的服务端项目并存着,该怎么分配唯一的 80 端口呢?因为商业 WWW 网站的话,往往只能占用 80 端口,--当然,如果只是做服务的话,如接口之类的,使用其他端口就不会与 80 端口冲突了.许多开发者都会面临到 80 端口这个问题,并且实际情
-
使用express来代理服务的方法
nodejs和nginx都可以反向代理,解决跨域问题. 本地服务 const express = require('express') const app = express() //如果它在最前面,后面的/开头的都会被拦截 app.get('/', (req, res) => res.send('Hello World!')) app.use(express.static('public'));//静态资源 app.use('/dist', express.static(path.join(_
-
vue 打包后的文件部署到express服务器上的方法
vue 简介 Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的渐进式框架. Vue 只关注视图层, 采用自底向上增量开发的设计. Vue 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件. vue是目前最流行的前端框架,今天要介绍的是如何利用vue+webpack+express的方式进行前后端分离的开发. 1.首先用vue-cli初始化项目目录 vue init webpack pro-name cd pro-name && npm ins
-
NodeJs中express框架的send()方法简介
express框架的send方法 ①send方法用的还挺多的,因此需要明确其作用: ②原型是: res.send([body|status], [body]) 即既可以直接发送内容,也可以第一个参数状态,第二个参数内容. 如果直接发送内容的话,状态会被自动补全: ③发送的内容: 示例: res.send(newBuffer('whoop')); res.send({ some: 'json' }); res.send('some html'); res.send(404, 'Sorry, we
-
node.js基于express使用websocket的方法
本文实例讲述了node.js基于express使用websocket的方法.分享给大家供大家参考,具体如下: 这个效果我也是翻了好长时间的资料,测试才成功的,反正成功,大家看看吧 首先你需要安装socket.io模块 npm install socket.io --save 然后打开express的app.js将模块引入,在12行左右的 var app = express(); 下面添加两行 var server = require('http').Server(app); var io = r
-
Express与NodeJs创建服务器的两种方法
目录 NodeJs创建Web服务器 Express创建Web服务器 NodeJs创建Web服务器 var http = require('http'); var server = http.createServer(function(req, res) { res.writeHead(200, { 'Content-Type': 'text/plain' }); res.write('hello world!'); res.end(); }).listen(80); 这是一个原生式的创建一个we
-
使用express搭建一个简单的查询服务器的方法
本文介绍了使用express搭建一个简单的查询服务器的方法,分享给大家,具体如下: 使用到的技术栈有express.mysql. 项目结构: service --node_modules --app.js --query.js app.js支持调用服务,使用body-parser对request进行处理. query.js实现链接数据库以及查询数据库的功能. app.js代码如下: var express = require('express'); var query = require('./
-
把vue-router和express项目部署到服务器的方法
- 首先确定此项目在本地能够运行成功 在本地命令行中输入npm run start,无报错,且打开127.0.0.1:3000 有写的路由为/的页面,如图 此为文件层级关系 front为前端文件 xk3为后台express与数据库mysql链接的文件 用命令行进入后台并且运行,启动成功 这是路径为/的页面 在浏览器中输入路径http://localhost:3000/ 浏览器中显示WelCome to express 至此此项目在本地运行成功,我们现在就要放到服务器上. - 准备工作 此前服务器
-
nodeJS express路由学习req.body与req.query方法实例详解
目录 引言 前端路由 后端路由 Express路由教学 GET/POST路由演示 详解req处理数据的方法 引言 所谓 路由 就是根据不同的 url 地址展示不同的内容或页面 形象点 举个栗子: 电话的拨号界面咱们都见过都使用过 你输入一串号码,就可以拨号给指定的联系人 路由也是这个道理,你请求不同的 url 地址,服务器给你展示不同的内容或页面. 假如我们有一台提供 Web 服务的服务器的网络地址是192.168.1.66:8080 然后我们的服务器下挂载有如下一个资源 192.168.1.6
-
Nodejs的express使用教程
Express 是一个简洁.灵活的 node.js Web 应用开发框架, 它提供一系列强大的特性,帮助你创建各种 Web 和移动设备应用. 1.express组织结构 app demo |---node_modules------用于安装本地模块. |---public------------用于存放用户可以下载到的文件,比如图片.脚本.样式表等. |---routes------------用于存放路由文件. |---views-------------用于存放网页的
-
Express实现前端后端通信上传图片之存储数据库(mysql)傻瓜式教程(一)
在前端这个坑里摸爬滚打已经一年多了,终于下定决心写下自己第一篇博客(虽然内容原创居少,算是个整合内容),开始使用express的原因是因为自己想测试接收下前端上传图片并返回,实现图片上传.后端各位大大们又都比较忙,没办法了,只能自己上了(哎,都是逼出来的). 此教程适合没有接触过node的web前端开发,快速构建自己的框架,基于express4.x. 首先安装express ,http://www.expressjs.com.cn/starter/installing.html,安装过程中一直回
随机推荐
- 浅谈Java中Unicode的编码和实现
- redis字符串类型_动力节点Java学院整理
- Python的内存泄漏及gc模块的使用分析
- Angular指令封装jQuery日期时间插件datetimepicker实现双向绑定示例
- VBS Runas 自动输入密码, 明文
- java正则表达式的应用 java读取文件并获取电话号码
- 使用BootStrap进行轮播图的制作
- JS动态添加的div点击跳转到另一页面实现代码
- PHP+Javascript实现在线拍照功能实例
- javascript关于运动的各种问题经典总结
- js封装成插件_Canvas统计图插件编写实例
- SQL 判断字段类型语句
- 基于JQuery的Pager分页器实现代码
- 批量建立文件夹,为Serv_U批量创建用户
- 详解Bucket Sort桶排序算法及C++代码实现示例
- 一波神奇的Python语句、函数与方法的使用技巧总结
- Python中的单继承与多继承实例分析
- PostgreSQL实现一个通用标签系统
- Django外键(ForeignKey)操作以及related_name的作用详解
- layui实现图片虚拟路径上传,预览和删除的例子