Java中的Filter 并不是一个标准的Servlet ,它不能处理用户请求,也不能对客户端生成响应。 主要用于对HttpServletRequest 进行预处理,也可以对HttpServletResponse 进行后处理,是个典型的处理链。
过滤链的好处是,执行过程中任何时候都可以打断,只要不执行chain.doFilter()就不会再执行后面的过滤器和请求的内容。而在实际使用时,就要特别注意过滤链的执行顺序问题。
过滤器的作用描述:
- 在HttpServletRequest 到达Servlet 之前,拦截客户的HttpServletRequest 。
- 根据需要检查HttpServletRequest ,也可以修改HttpServletRequest 头和数据。
- 在HttpServletResponse 到达客户端之前,拦截HttpServletResponse 。
- 根据需要检查HttpServletResponse ,可以修改HttpServletResponse 头和数据。
Session:在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。
Async:Async函数定义:
async 函数就是 Generator 函数的语法糖。
前文有一个 Generator 函数,依次读取两个文件。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
var fs = require( 'fs' ); var readFile = function (fileName){ return new Promise( function (resolve, reject){ fs.readFile(fileName, function (error, data){ if (error) reject(error); resolve(data); }); }); }; var gen = function * (){ var f1 = yield readFile( '/etc/fstab' ); var f2 = yield readFile( '/etc/shells' ); console.log(f1.toString()); console.log(f2.toString()); }; |
写成 async 函数,就是下面这样。
1
2
3
4
5
6
|
var asyncReadFile = async function (){ var f1 = await readFile( '/etc/fstab' ); var f2 = await readFile( '/etc/shells' ); console.log(f1.toString()); console.log(f2.toString()); }; |
优点:1.内置执行器。 Generator 函数的执行必须靠执行器,所以才有了 co 函数库,而 async 函数自带执行器。也就是说,async 函数的执行,与普通函数一模一样,只要一行。
2.更好的语义。 async 和 await,比起星号和 yield,语义更清楚了。async 表示函数里有异步操作,await 表示紧跟在后面的表达式需要等待结果。
3.更广的适用性。 co 函数库约定,yield 命令后面只能是 Thunk 函数或 Promise 对象,而 async 函数的 await 命令后面,可以跟 Promise 对象和原始类型的值(数值、字符串和布尔值,但这时等同于同步操作)