在智能社上听了一些关于node.js的视频,总结一小部分内容,都是总结老师讲的知识点,并且也是在不断学习的过程,所以会不断更新。也是为了怕自己遗忘一些知识点,同时现今没有什么项目可以让我去真正实践,这样多次浏览也为以后打基础。接下来就进入正题。

模块

  这里有很多东西都可以去 npm 的官方网站里去找的。同时也可以发布自己的模块。  

  require——引入其他模块
  exports——输出
  module——批量输出

  这些只是一个例子,其他的都可以在上面看到。

  node_modules这个文件夹是用于放模块的

  express框架

  express里,除了write,end,还有一个就是send,就是增强了功能,没有改变原生的功能,所以也算是非侵入式的。

  对于数据传输,GET无需要中间件,直接req.query 就可以了,但是POST不行,必须要一个中间件,就是body-parser,需要先下载这个才可以。

  body-parser参数

    1.extended  //扩展模式true  false普通模式

    2.limit  //限制模式

链式操作:

server.use('/',function(req,res,next){

  console.log('a');

});

server.use('/',function(req,res,next){

  console.log('b');

})

cookie和session

  首先我认为两者最大的区别是一个不安全,一个较安全。cookie是保存在浏览器中的,而且很有限,所以很不安全。session是保存在服务端的,所以较安全。

  但是为什么现在还保存着cookie呢?其实是因为session是基于cookie实现的。

  

  cookie

  发送:

  res.secret='字符串';
  res.cookie(名字, 值, {path: '/', maxAge: 毫秒, signed: true});

  

  签名:

  req.secret='sjdflksdl';

  res.cookie('user','xxx',{singed:true});

  console.log(req.cookies);

  res.send('ok');

  cookie空间很小,全部签名很浪费空间

  读取cookie
    cookie-parser

    server.use(cookieParser('秘钥'));

    server.use(function (){
      req.cookies 未签名版
      req.signedCookies 签名版
    });

  删除cookie

    res.clearCookie(名字);

  

  session

  1.写入   

    server.use(cookieParser());
    server.use(cookieSession({
      keys: ['aaa', 'bbb', 'ccc']
    }));

    server.use('/', function (req, res){
      console.log(req.session);

      res.send('ok');
    });

  2.读取

    server.use(cookieParser());
    server.use(cookieSession({
      name: 'sess',
      keys: ['aaa', 'bbb', 'ccc'],
      maxAge: 2*3600*1000
    }));

    server.use('/', function (req, res){
      if(req.session['count']==null){
        req.session['count']=1;
      }else{
        req.session['count']++;
      }

      console.log(req.session['count']);

      res.send('ok');
    });

  3.删除

    delete req.session

  

模板引擎

  jade

    破坏式的,强依赖。不能和普通的html、css共存

    jade可以渲染内容renderFile,例如在一个jade文件中写

    html

      head

        style

    类似的,会出现如下效果,注意,一个缩进就代表下面的内容是子集,就会包含在上面的文字中,如果想要好看,需要用到{pretty:true}

    <html>

      <head>

        <style>

        </style> 

      </head>

    </html>

    但是,比如我想要在一个div里输入一些内容,比如abc什么之类的,如果还是像刚刚那样的方法,就会输出</abc></abc>,这个也不是我们想要的。所以,用 |abc 来表示,其中 | 表示原样输出。不过,如果子元素非常多,那每一行都写一个 | ,那也太麻烦了。所以有一个更简单的方法。就是在父元素后面加一个“   .   ”,就可以把里面包含的所有的内容全部都原样输出出来。还有一种方法就是在父元素下面写 include 后面跟你写的js文件名,同样也可以实现一样的效果。

    如果要使用变量,比如想要获取js里面的内容,{name},要在大括号外加一个“  #  ”,诸如此类,运算也是可以的。一样的道理,也可以用 = ,就不用加大括号了。

    输入代码可以用 “  -  ”放在前面,类似于刚刚的 |  。

    特殊的是,switch语句中,和以前不一样,叫做case , when 代替了以前的case

  注入式攻击:

    例如我想要在js中加入一个content,内容是

    content: "<h2>这是个啥</h2><p>我也不知道哦!</p>"

    结果会出现下面的情况:

    

    为什么呢?因为这是jade自己的保护措施,将里面的标签全部都破坏了,避免用户不小心的时候写错了。那其实刚开始我的意愿就是想要这些标签呀,所以就可以在jade里面原本的 div = content  改为  div != content 就可以了。

  ejs

    温和,弱依赖。不用变化以前的html文件样式,不过可以添加一些东西。

    写属性是用括号来圈起来。如果想要写属性里的内容,括号外空一格直接写就可以了。

    ejs非常的方便,只要js能写的东西在ejs里全部都能写,比如循环啊之类的,也没有什么变化。

    在之前说jade的时候,当里面加入HTML的东西比如<div></div>,它会保护,写成其他的东西,ejs也是一样的,所以如果我们想要原样输出的话,就要把<%= this%>的“  =  ”改为“  -  ”,就可以了。

  consolidate

    一种适配模板引擎。

    server.set('view engine' , 'html' );   //其中set与平时的use不一样,意思是对这个服务进行的全局的配置。  view engine 是试图引擎.

    server.set('views' , './xxx');        //返回其中模板文件放在哪

    server.engine('html' , consolidate.ejs) //engine是表示使用哪种模板引擎。这句代码的意思就是如果我使用html,则用consolidate下的ejs引擎。

    当需要接受用户请求的时候

    req.send() 和 req.render() 的区别在于send是直接向用户发送内容,而render是相当于编译一个东西并且把编译后的结果发送给用户。

    req.send( 'xxx' )    req.render( 'xxx.ejs' , { name : ' xxx '} )

  router

    路由。简单来说就是把不同的目录对应到不同的模块中去。route是express自带的,因为很重要,所以不像其他中间件那样还需要下载。  

    1.创建router
      var router=express.Router();

    2.把router添加到server
      server.use('/user', router);

    3.router内部
      router.get('/1.html')
      router.post('/2.html')

Node.js记录的更多相关文章

  1. 在腾讯云centos7.2上安装配置Node.js记录

    应为爱好前端所以打算在腾讯云服务器上安装JavaScript引擎Node.js,下面是安装步骤: 安装准备: 下载node.js的.tar.xz安装包:https://nodejs.org/dist/ ...

  2. 关于node.js和npm,cnpm的安装记录以及gulp自动构建工具的使用

    关于node.js和npm,cnpm的安装记录以及gulp自动构建工具的使用   工作环境:window下 在一切的最开始,安装node.js (中文站,更新比较慢http://nodejs.cn/) ...

  3. Node.js log4js日志记录

    这次需要给之前弄的文件服务器添加日志记录,一般每天产生的日志会特别多所以安装日期来划分是最好的,这里我用了express框架,为了适应express框架这里在log.js文件中写了use方法. //日 ...

  4. Node.js权威指南学习记录

    学习nodeJS权威指南的学习记录 导航: 1.console模块 2.全局变量 3.Buffer对象 4.事件对象 5.网络请求 6.文件操作对象 一. COMMON.js的学习.(commonJS ...

  5. 记录一次用宝塔部署微信小程序Node.js后端接口代码的详细过程

    一直忙着写毕设,上一次写博客还是元旦,大半年过去了.... 后面会不断分享各种新项目的源码与技术.欢迎关注一起学习哈! 记录一次部署微信小程序Node.js后端接口代码的详细过程,使用宝塔来部署. 我 ...

  6. Node.js学习记录

    一.NPM 使用介绍 NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种: 允许用户从NPM服务器下载别人编写的第三方包到本地使用. 允许用 ...

  7. e2e 自动化集成测试 架构 实例 WebStorm Node.js Mocha WebDriverIO Selenium Step by step (五) 如何让窗体记录登录状态Session

    在写自动化测试的Node.js脚本时, 时常需要测试所写的case, 可能都需要去重新登录一遍,这将相当的耗时, 好在Selenium都借了Session的机制, 如果在最初的浏览器没有关闭的情况下, ...

  8. node.js使用经验记录

    MongoDB使用经验: 有时不知道MongoDB的错误码代表什么,那有这个链接: https://github.com/mongodb/mongo/blob/master/src/mongo/bas ...

  9. 学习用Node.js和Elasticsearch构建搜索引擎(6):实际项目中常用命令使用记录

    1.检测集群是否健康. curl -XGET 'localhost:9200/_cat/health?v' #后面加一个v表示让输出内容表格显示表头 绿色表示一切正常,黄色表示所有的数据可用但是部分副 ...

随机推荐

  1. C语言常用知识点

    C语言条件预处理命令 /* 格式: #ifdef 标识符 程序1 #else 程序2 #endif 标识符已经定义时,程序段1才参加编译 应用:如调试版本,发行版本,便于调试 */ #include ...

  2. C语言第四次实验

    这次实验共计7道题目 以下代码亲测无误 1.用选择排序法,键盘输入10个整数,对10个整数进行排序(升序) 1.第一种思路就是常规思路,输入--排序--输出 源代码如下: //常规思路,输入,排序,输 ...

  3. c++ 创建二叉树

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <ctype.h> ...

  4. Direct3D中 SetStreamSource 函数与数据流

    Microsoft? DirectX? 8.0引入了数据流的概念,用来把数据绑定到着色器使用的输入寄存器.一个数据流是一个成员数据的数组,每个成员由一个或多个元素构成,这些元素代表单个实体,如位置.法 ...

  5. HBase数据访问的一些常用方式

    类型 特点 场合 优缺点分析 Native Java API 最常规和高效的访问方式 适合MapReduce作业并行批处理HBase表数据 Hbase Shell HBase的命令行工具,最简单的访问 ...

  6. sso(single sign on)介绍

    1. 浏览器 > 2. 系统A(www.a.com) > 3. 系统B(www.b.com) > 4. 认证中心(www.sso.com) #### ** (1)首次访问** > ...

  7. Kafka系列三 java API操作

    使用java API操作kafka 1.pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xs ...

  8. Python中re模块详细介绍

    正则的介绍及应用实例详解 """ 1.什么是正则 正则就是用一系列具有特殊含义的字符组成一套规则,该规则用来描述具有某一特征的字符串, 正则就是用来去一个大的字符串中匹配 ...

  9. Python码农福音,GitHub增加Python语言安全漏洞告警

    在 2017 年 GitHub 开始对托管在其网站的代码仓库和依赖库开始提供安全漏洞检查和告警,开始时候只支持 Ruby 和 JavaScript 语言的项目.根据 GitHub 官方数据显示截止目前 ...

  10. Restful和WeBAPI学习笔记

    1.restful是基于无状态的,所谓无状态就是说客户端和服务端的每次通话都是独立的,不存在session和cookie之类的保存状态的机制,基于该协议可实现简单的curd操作, 其操作分为get\p ...