Lua Web快速开发指南(4) - 详细了解httpd库的作用
httpd库是基于HTTP 1.1协议实现而来, 内置了高性能的http协议解析器与urldecode解析库.
httpd库默认情况下就能工作的很好, 但是在一些需求较为极端的场景还是需要微调一下参数.
httpd常用的内置方法介绍
1. httpd:timeout(number)
设置每个连接到最大空闲(idle)连接等待时间, 超过这个数值httpd将主动断开连接. (默认值为:30秒)
2. httpd:max_path_size(number)
设置Path的最大长度, 超过这个值httpd将会返回414. (默认值为: 1024)
3. httpd:max_header_size(number)
设置Header最大长度, 超过这个值httpd将会返回431. (默认值为: 65535)
4. httpd:max_body_size(number)
设置Body的最大长度, 超过这个值将会返回413. (默认为 1024 * 1024)
5. httpd:before(function)
before方法决定API与USE路由回调在触发之前的行为, 默认情况下允许所有路由通过.
before方法一般用来设置与修改用户验证路由行为(例如头部验证), 这提供了开发者基于before函数设计中间件的机会.
当开发者设置了function后(即是是一个空函数), 需要利用http库来决定行为.
6. httpd:group(type, prefix, handles)
group方法提供了一种批量注册路由的方式, 为一组同一组路由提供简单便方便在注册方法.
第一个参数type为需要批量注册的路由类型; 初始化httpd对象后, 使用app.USE
或app.API
进行传值;
第二个参数prefix为string类型的头部; 例如:/api
、/admin
;
第三个参数为一组路由处理函数或处理类数组; 类型为: {route = '/login', class = class};
注意: 此方法仅支持批量注册API与USE路由, 不可同时注册不同类型路由;
7. httpd:static(folder, ttl)
listen方法用于告诉httpd对象监听指定端口.
第一个参数ip暂未被httpd使用(但是必须设置), 默认监听所有网卡的'0.0.0.0'地址与指定的端口号;
backlog为用户最大连接等待队列, 合理的设置能减少连接被重置的情况(默认值为128).
8. httpd:run()
在httpd库所有参数与路由设置完毕之后, 调用run方法开启监听模式.
httpd的请求日志
日志格式为: [年/月/日 时:分:秒] - [ip] - [x-real-ip] - [path] - [method] - [http code] - [request handle timeline]
httpd的中间件
httpd库提供了before
方法, 为开发人员自定义'中间件'行为提供了可能. 具体使用方法请参考http库.
http content
每个http请求都会在调用before
与用户注册的路由时为其传入一个content, 这个Content是客户端请求的所有参数.
args : 支持标准get或者post的参数, 对a[1]=1&a[2]=2将会不会解析为数组类型; 支持multipart/form-data
的参数传递方式;
header: 原始header key-value表, 框架层不会进行header进行内容解析. (一般情况下没这个必要);
body : 目前body支持这些类型: multipart/form-data
、application/x-www-form-urlencoded
、application/json
、application/xml
;
json/xml: 在body为json类型的时候, content的json属性为true; 在body为xml类型的时候, content的xml属性为true.
file : 当客户端使用multipart/form-data
传递数据时将会有这个属性; 这个属性是数组类型;
继续学习
一下章我们一起学习如何利用template库构建httpd模板引擎