ORM/express/sequelize

2017-11-08  本文已影响189人  Gopal

数据库ORM的学习

什么是ORM?

对象-关系映射(Object-Relational- Mapping),面向对象的开发方法,关系数据库(主流的数据库存储系统)
对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。在内存中对象之间存在关联和继承的关系,而在数据库中,关系数据库,关系数据无法表达多对多关联和继承的关系
因此,对象-关系映射(ORM)系统一般以中间件的形式存在,主要实现对象到关系数据库的映射

对象-关系映射的解释

对象-关系映射的解释

为什么要使用ORM?

当我们实现一个应用程序的时候(不适用ORM的话),可能需要写很多特别多的数据访问层的代码,从数据库保存、删除、读取对象信息,而这些代码都是重复的。使用ORM可以大大减少代码的重复性

什么是中间件

中间件的理解

中间件:
将具体的业务和底层逻辑解耦的组件

jwt——json web token

base64之间的转码和解码(以下中jwt中的三个部分都是base64的编码方式)

传统的session认证

基于token的鉴权机制

基于token的鉴权机制类似于http协议也是无状态的,他不需要在服务端去保留用户的认证信息或者回话信息。
大概的流程如下:

基于token的鉴权机制 流程示意图

这个token每次的请求中传递给服务器,它应该保留在请求头中,另外,服务端要支持CORS(跨来源资源共享)策略,一般我们在服务器端Access-Control-Allow-Origin:*即可

JWT的构成:
第一部分为它的头部(header)
第二部分我们称它为载荷(payload)
第三部分是签证(signatrue)

jwt的第三部分是一个签证信息,这个签证信息由三部分组成:

1、header (base64后的)
2、payload (base64后的)
3、secret
这个部分需要base64加密后的header和base64加密后的payload使用.连接组成的字符串,然后通过header中声明的加密方式进行加盐secret组合加密,然后就构成了jwt的第三部分。

编码技巧

觉得exports出去的是一个数组OR对象,然后通过for循环遍历,这样的好处在于,不用一个个的暴露出去,也不用一个个的引用进来

express学习

express框架中app.use是什么作用?
就是引入一个中间件,其实就是用来在请求发送之前对req和res对象实现一些功能

404找不到指定的资源,是因为自己使用localhost去请求服务器,然后服务器,根本没有客户端请求的内容,这样就会返回404错误

安装node.js模块时候,如果制定了--save参数,那么这个模块将被添加到package.json文件中的dependencies依赖列表中

可是这个dependencies列表有什么用??

dependencies

利用Express托管静态文件
通过内置的express.static可以方便地托管静态文件
将静态资源文件所在的目录作为参数传递给express.static中间件就可以提供静态资源的访问了

如何设置一个错误处理器?
错误处理器中间件的定义和其他中间件是一样的,唯一的区别是4个参数而不是3个参数,即(err,req,res,next)

app.METHOD(path,callback)

路由路径和请求方法一起定义了请求的端点,它可以是字符串、字符串模式或者正则表达式

路由句柄
可以为请求处理提供多个回调函数,其行为类似中间件。唯一的区别是这些回调函数有可能调用next('route')方法而略过其他路由回调函数。

多种形式,可以是一个函数,一个函数数组,或者是两者混合

响应方法

响应方法

app.route()
可以使用app.route()创建路由路径的链式路由句柄。由于路径在一个地方指定,这样有利于创建模块化的路由,而且减少了代码的冗余和拼写错误

express.Router类创建模块化、可挂载的路由句柄。

中间件(Middleware)是一个函数,它可以访问请求对象(req),响应对象(res)和web应用中处于请求-响应循环流程中的中间件,一般被命名为next的变量。

中间件的内容包括:
1、执行任何代码
2、修改请求和响应对象
3、终结请求-响应循环
4、调用堆栈中的下一个中间件

如果当前中间件没有终结请求-响应循环,则必须调用next()方法将控制权交给下一个中间件,否则请求就会挂起

如果需要在中间件栈中跳过剩余中间件,调用next('route')方法将控制权交给下一个路由

在Express中使用模板引擎
需要在应用中进行如下设置才能让Express渲染模板文件
views,放置模板文件的目录
view engine,模板引擎

sequelize的学习

首先是实例化sequelize数据库连接
实例化sequelize

实例化sequelize

定义Model,通俗来讲就是将你的表结构定义出来
define里面的第一个参数是表名,第二个参数是定义字段,第三个参数不填写的话会使用默认定义选项提供给sequelize构造函数

git的操作

git pull将远程的项目拉取下来(进入之前的项目里面)

git status 查看工作目录和index区域的状态

git add命令主要用于把我们要提交的文件的信息添加到索引库中,当我们使用git commit时候,git将依据索引库中的内容来进行文件的提交

上一篇下一篇

猜你喜欢

热点阅读