1.热启动

每次修改app.js文件,都得重新启动项目,十分不方便。这里可以用hotnode插件实现热启动

安装:$ npm install -g hotnode

启动项目:$ hotnode app.js

2.静态文件部署

app.use(express.static(__dirname + '/src/static'));指定了src目录下的static为静态目录,__dirname 是app.js的绝对路径 node自带的

这样可以直接访问到静态文件 http://localhost:8081/aaa.js 其中aaa.js是放在src目录下的static的。

可以指定多个目录为静态文件夹 如:

app.use(express.static(__dirname + '/src/static1'));

app.use(express.static(__dirname + '/src/static2'));

3.跨域

安装:$ npm install express-http-proxy --save

使用:

var proxy = require('express-http-proxy');
var app = require('express')();
app.use('/proxy', proxy('www.google.com'));

4.调试

使用命令$ npm install -g node-inspector 安装。安装后就可以使用了。

启动调试项目 $ supervisor --debug app.js

再打开一个控制面板 启动调试监控 $ node-inspector -p 8081 这时cmd输出的“http://127.0.0.1:8081/?port=5858”就是调试网址

复制到浏览器 打断点跟js一样

付上我的app.js文件

//demo.js 文件
var express = require('express'),
hbs = require('hbs'),
cookieParser = require('cookie-parser'),
session = require('express-session'),
fs = require('fs'),
http = require('http'),
app = express(); app.use(cookieParser());
app.use(session({
secret: '123456',
cookie: {maxAge: 60 * 1000 * 30},
resave: false,
saveUninitialized: true
})); app.use(express.static(__dirname + '/src/static')); app.get('/hello', function (req, res) {
res.send('HELLO');
}); var user = require(__dirname + '/src/server/user.js');
app.get('/login', function (req, res) {
if (req.session.sign) {//检查用户是否登录
res.send('welecome <strong>' + req.session.name + '</strong>, 欢迎你再次登录');
} else {
user.login('王冲', '111qqq',function(userInfo){
req.session.sign = true;
req.session.name = userInfo.userName;
res.send('欢迎登录,' + req.session.name);
});
}
}); //app.get('/index', function (req, res) {
// console.log(__dirname);
// res.sendFile(__dirname + '/src/views/' + 'index.html');
//}); app.get('/process_get', function (req, res) {
var response = {
firstName: req.query.firstName,
lastName: req.query.lastName
}
console.log(response);
res.end(JSON.stringify(response));
}); hbs.registerPartials(__dirname + '/src/views/partials');
app.set('view engine', 'hbs');
app.set('views', __dirname + '/src/views/'); app.get('/news', function (req, res) {
var userInfo = {
userName: req.session.name
}
res.render('index', {title: 'hbs news demo', author: 'qujh',userInfo:userInfo});
}); app.get('/about/ygt', function (req, res) {
res.render('about/test', {title: 'hbs ygt demo', author: 'qujh'});
}); app.get('/about/about', function (req, res) {
res.render('about/about', {title: 'hbs about demos', author: 'qujh'});
}); var server = app.listen(8081, function () {
var host = server.address().address
var port = server.address().port
console.log("应用实例,访问地址为 http://%s:%s", host, port);
});

附上配置文件 package.json

{
"name": "expressgulp",
"version": "1.0.0",
"description": "express nodeJs hbs模板",
"main": "app.js",
"dependencies": {
"amui-hbs-helper": "^2.2.0",
"body-parser": "^1.17.1",
"browser-sync": "^2.18.8",
"cookie-parser": "^1.4.3",
"express": "^4.15.2",
"express-session": "^1.15.2",
"fs": "0.0.1-security",
"gulp": "^3.9.1",
"gulp-clean": "^0.3.2",
"gulp-replace": "^0.5.4",
"gulp-replace-task": "^0.11.0",
"gulp-seajs-concat": "^1.0.5",
"gulp-seajs-transport": "^0.4.0",
"gulp-uglify": "^2.1.2",
"handlebars": "^4.0.8",
"hbs": "^4.0.1",
"jquery": "^3.2.1",
"merge-stream": "^1.0.1",
"multer": "^1.3.0",
"seajs": "^3.0.2",
"session": "^0.1.0",
"yargs": "^7.0.2"
},
"devDependencies": {
"http": "0.0.0"
},
"scripts": {
"注释":"npm run test以debug形式启动,另打开cmd命令node-inspector -p 8081 启动断点调试命令",
"test": "supervisor --debug app.js",
"dev": "node app.js"
},
"keywords": [
"express",
"hbs"
],
"author": "qjh",
"license": "ISC"
}

express 热启动 静态文件部署 跨域解决 调试的更多相关文章

  1. Nginx配置服务器静态文件支持跨域访问

    在server中配置 add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Reque ...

  2. nginx 静态文件支持跨域访问权限

    一.原生态 location ^~ /repurchase-web/ {          alias /var/www/webapps/repurchase-web/;        } 二.支持跨 ...

  3. Springboot静态文件不更新的解决办法,以及Springboot实现热部署

    Springboot静态文件不更新的解决办法,以及Springboot实现热部署 原文链接:https://www.cnblogs.com/blog5277/p/9271882.html 原文作者:博 ...

  4. spring mvc 图片上传,图片压缩、跨域解决、 按天生成文件夹 ,删除,限制为图片代码等相关配置

    spring mvc 图片上传,跨域解决 按天生成文件夹 ,删除,限制为图片代码,等相关配置 fs.root=data/ #fs.root=/home/dev/fs/ #fs.root=D:/fs/ ...

  5. 访问本地json文件因跨域导致的问题

    我使用jquery的getJSON的方法获取本地的json文件,并进行操作,获取json 数据代码如下: $.getJSON("invite_panel.json",functio ...

  6. [转]vue跨域解决方法

      vue跨域解决方法 vue项目中,前端与后台进行数据请求或者提交的时候,如果后台没有设置跨域,前端本地调试代码的时候就会报“No 'Access-Control-Allow-Origin' hea ...

  7. JavaScript跨域解决方法大全

    跨域的定义:JavaScript出于安全性考虑,同源策略机制对跨域访问做了限制.域仅仅是通过“URL的首部”字符串进行识别,“URL的首部”指window.location.protocol +win ...

  8. Nginx反向代理node,实现让静态文件在同一域

    Nginx反向代理node,实现让静态文件在同一域 原文https://github.com/zhuangZhou/Blog/issues/4 不管是Vue还是React,还是传统的网站,与node服 ...

  9. form上传文件以及跨域异步上传

    要设置了enctype属性才能上传,需要使用上传的jar包,这里使用的是cos-26Dec2008.jar, 而且后台获取值的时候,getfile要放在第一位 一次设置好上传格式后没有上传文件,也就没 ...

随机推荐

  1. 如何查找BAPI SD_SALESDOCUMENT_CHANGE里的字段对应的数据库存储表

    BAPI函数SD_SALESDOCUMENT_CHANGE可以让我们很方便地通过ABAP代码来修改Sales Order. 其输入参数ORDER_HEADER_IN的类型是BAPISDHD1, 里面包 ...

  2. 使用Axure管理团队项目图文教程 团队协作操作步骤

    Axure RP团队版和企业版都支持团队协作,可以创建和管理团队项目,即多人共同创作一个原型.本文通过图文教程的形式,讲解了如何基于Axure Share服务创建和管理团队项目.因为Axure Sha ...

  3. 2019.03.16 ZJOI2019模拟赛 解题报告

    得分: \(100+27+20=147\)(\(T1\)巨水,\(T2,T3\)只能写暴力分) \(T1\):深邃 比较套路的一眼题,显然是一个二分+贪心,感觉就是\(NOIP2018Day1T3\) ...

  4. DOM节点(二):操作节点

    appendChild() 用于向childNodes列表的末尾添加一个节点. var returnedNode = someNode.appendChild(newNode); 如果传入的节点已经是 ...

  5. RHEL/CentOS 6.x使用EPEL6与remi的yum源安装MySQL 5.5.x

    PS:如果既想获得 RHEL 的高质量.高性能.高可靠性,又需要方便易用(关键是免费)的软件包更新功能,那么 FedoraProject 推出的 EPEL(Extra Packages for Ent ...

  6. Spring Security 实现记住我

    开篇一张图,道理全靠悟. 示例如下: 1.    新建Maven项目  remember_me 2.   pom.xml <project xmlns="http://maven.ap ...

  7. acc_set_device_num && acc_get_device_num例程

    void acc_set_device_num( int, acc_device_t ); 描述在指定类型的所有设备中, acc_set_device_num 告诉运行时库环境用哪一个设备.如果 de ...

  8. 第50章 读写内部FLASH—零死角玩转STM32-F429系列

    第50章     读写内部FLASH 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fire ...

  9. Server_Tomcat

    1 Tomcat概述 Tomcat服务器由Apache提供,开源免费.由于Sun和其他公司参与到了Tomcat的开发中,所以最新的JSP/Servlet规范总是能在Tomcat中体现出来.当前最新版本 ...

  10. ssm整合-错误2

    1 警告: No mapping found for HTTP request with URI [/management] in DispatcherServlet with name 'dispa ...