一、node-app结构

  创建成功node-app项目后,会自动生成一些文件一般初始的结构如下图

  

  在bin文件夹里面只有一个文件www

       var port = normalizePort(process.env.PORT || '3000');里面这一行里面的3000是运行的端口号,可以修改为随意数字,运行的localhost:xxxx保持一致
      在public存放的是用到的静态文件,包括images、javascript、stylesheets文件夹,也可以自己添加个html文件夹,在测试时候可以使用
 
  在routes里面写你定义的前端调用的接口文件
 
  在views里面是定义的jade模板,一般是用不到的,不用管!
 
  根目录的app.js是项目运行时候首先调用的文件需要做些配置
  二、app.js配置
  为了更好的维护把路由页面写在了routes中所以这个文件里面的indexRouter,usersRouter有关的删除,
  在里面引入routes,把app导入到routes首文件里,因为我在routes中使用index.js文件作为首文件,所以./routes/index.js可以简写。
  
  在routes文件夹里重新导出router,在routes/index.js中引入路由文件users.js。使用module.exports导出
  var users = require('./users.js');
module.exports = function (app) {
app.use('/', users); // 这里我重设置为第一个页面,所以localhost:3000展示文字会变
}
  这样虽然可以使用但是调用api时候会出现跨域,所以还要做跨域处理
  三、处理跨域
    //跨域问题
app.all('*',function (req, res, next) {
res.header('Access-Control-Allow-Origin', req.headers.origin);
res.header('Access-Control-Allow-Headers', 'Content-Type, Content-Length,
Authorization, Accept, X-Requested-With , yourHeaderFeild');
res.header('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE,
OPTIONS');
res.header('Access-Control-Allow-Credentials', true) if (req.method == 'OPTIONS') {
res.send(200); /让options请求快速返回/
} else {
next();
}
});

  这样才算配置结束(根据需要可以添加其他配置)结果如下图

 
  重启npm start 运行localhost:3000看是否还能正常调用
 
  四、package-lock.json、package.json是配置文件,要是npm配置插件时候才会变化
 
  五、导入数据库,短信
        使用mysql ,要安装后才能用 npm install mysql --save(mysql怎么安装,有空我在写一篇文章,怎么在node使用mysql和短信在下一篇文章中)
        这里在根目录新建一个config.json文件,统一把需要配置的特殊内容放在一起,(如果使用redis也写在一起)
   短信这里使用的阿里云的短信,(阿里云短信需要申请账号才能使用)阿里云的文档上面有详细的使用方法(阿里云短信文档
   {
"mysql": {
"host": "120.xx.xxx.xx", // mysql的主机地址
"user": "root", // 用户名
"port": 3306, // 渡口
"password": "xxxx", // 密码
"database": "xxx", // 调用的数据库名称
"charset": "UTF8MB4_GENERAL_CI" // 字符编码
},
"redis": { // 不使用的话不写
"RDS_PORT": "",
"RDS_HOST": "",
"RDS_PWD": ""
},
"duanxin": {
"SignName": "xxxxxx", // :短信签名
"TemplateCode": "xxxxxx",// 短信模板
"key": "xxxxxx",//用户
"secret": "xxxxxxx"//用来验证用户的密钥
}
}

  

  

node后台初始配置(2)的更多相关文章

  1. 手把手教你webpack、react和node.js环境配置(上篇)

    很多人刚学习react的时候,往往因为繁琐的配置而头疼,这里我将手把手教大家怎么用webpack配置react和redux的环境,这篇教程包括前端react和后台node整个网站的环境配置,对node ...

  2. 手把手教你webpack、react和node.js环境配置(下篇)

    上篇我介绍了前端下webpack和react.redux等环境的配置,这篇将继续重点介绍后台node.js的配置. 这里是上篇链接:手把手教你webpack.react和node.js环境配置(上篇) ...

  3. node开发环境配置

    node开发环境配置 用处 NodeJS——后台 JavaScript-前台 后台其他语言 1.PHP 2.Java 3.Pythonnode优势 1.性能高 nodejs php 86 1s 1分半 ...

  4. Node后台使用mysql并开启事务

    如题:node后台使用mysql数据库,并使用事务来管理数据库操作. 这里主要讲一个事务的封装并写了一个INSERT 插入操作. code: 基础code: db.config.js const my ...

  5. node后台fetch请求数据-Hostname/IP doesn't match certificate's altnames解决方法

    一.问题背景 基于express框架,node后台fetch请求数据,报错Hostname/IP doesn't match certificate's altnames..... require(' ...

  6. vue使用elementUI组件提交表单(带图片)到node后台

    1.方法一(图片与表单分开,请求2次) 1.1 前台代码 // elementUI表单 <el-form ref="form" class="forms" ...

  7. Git 笔记二-Git安装与初始配置

    git 笔记二-Git安装与初始配置 Git的安装 由于我日常生活和工作基本上都是在Windows上,因此此处只说windows上的安装.Windows上的安装和其他程序一样,只需要到http://g ...

  8. Node.js 安装配置介绍

    Node.js 安装配置 本章节我们将向大家介绍在window和Linux上安装Node.js的方法. 本安装教程以Node.js v6.10.1 LTS(长期支持版本)版本为例. Node.js安装 ...

  9. node学习笔记(二)(ajax方式向node后台提交数据)

    通过ajax向node后台提交数据过程(附手写前后台代码),并总结post与get的区别 POST 前台代码 //CSS简单给点样式 <style> form{ width: 200px; ...

随机推荐

  1. java类在何时被加载

    我们接着上一章的代码继续来了解一下java类是在什么时候加载的.在开始验证之前,我们现在IDEA做如下配置. -XX:+TraceClassLoading 监控类的加载 我们新建了一个TestCont ...

  2. day07整理(内置方法\循环判断)

    目录 一.上节课回顾 (一)if判断 1.单分支结构 2.双分支结构 3.多分支结构 (二)for循环 1.for + break 2.for + continue 3.for循环嵌套 (三)robu ...

  3. 如何使用git上传代码

    首先在github 上创建好远程仓库,并拷贝仓库地址,接下来按照以下步骤:   1.打开命令行进入要上传的文件目录,初始化 git init  2. 建立远程仓库,git remote add ori ...

  4. (JavaScript) 时间转为几天前、几小时前、几分钟前

    // 时间戳转多少分钟之前 getDateDiff(dateTimeStamp) { // 时间字符串转时间戳 var timestamp = new Date(dateTimeStamp).getT ...

  5. Jenkins 结合 ANT 发送测试报告

    全局变量配置 点击 ManageJenkins进入Jenkins 管理 点击 Global Tool Configuration 进入全局变量配置 配置 Ant ,Name 自己定义一个比较好理解的名 ...

  6. 熊海cms v1.0 完全代码审计

    很久以前写的,写这个东西更多的是为了说明我自己的一个思路,即按照程序功能点进行代码审计, 这样经过一段时间训练,熟悉了某种功能的正确和错误实现方法,遇到类似的代码就可以很快看出是否有问题了 --- 0 ...

  7. CSPS模拟 85

    WWB大佬的bitset映射真是太强了! %%% T1 观察样例,猜规律. T2 对题目的翻译工作用了很长时间 翻译错了好几次.. 观察到奇环没法染色,选的边必须把奇环弄断 如果在偶环上,偶环就变得没 ...

  8. CSPS模拟 61

    T1 模拟 T2 ?? T3 哈希

  9. Vue+element UI实现分页组件

    介绍 这是一个是基于element-UI的分页组件基础上,进行了二次封装的分页组件,在展示数据时,该分页组件采用了每显示一页数据,只请求当前页面的数据的请求策略,从而避免了一次性将数据全部请求所造成的 ...

  10. TCP协议--TCP三次握手和四次挥手

    TCP三次握手和四次挥手 TCP有6种标示:SYN(建立联机) ACK(确认) PSH(传送) FIN(结束) RST(重置) URG(紧急) 一.TCP三次握手   第一次握手 客户端向服务器发出连 ...