内容简介:sinatra 与 rails 的重大区别,就可以认为 后者有茫茫多的middleware.我们平时用的不多,但是关键时刻需要知道这个,需要读懂代码.下面就是一个简单的middleware 的使用过程. 具体参考:
sinatra 与 rails 的重大区别,就可以认为 后者有茫茫多的middleware.
我们平时用的不多,但是关键时刻需要知道这个,需要读懂代码.
下面就是一个简单的middleware 的使用过程. 具体参考: http://railscasts.com/episodes/151-rack-middleware?autoplay=true 和
1. 新建rails项目
2. 新建一个 middleware . (放到lib 目录下也行, 放到哪里都行)
class MyMiddleware
# app is the rails app
def initialize app
@app = app
end
# env: request env
def call env
request_started_on = Time.now
@status, @headers, @response = @app.call(env)
request_ended_on = Time.now
Rails.logger.debug "=" * 50
Rails.logger.debug "Request delta time: #{request_ended_on - request_started_on} seconds."
Rails.logger.debug "=" * 50
[@status, @headers, @response]
end
end
3. 在 config/application.rb 中,添加:
config.middleware.use "MyMiddleware"
4. 查看是否加载:$ bundle exec rake middleware , 就可以看到我们的middleware已经放上去了.
5. 运行rails, 打开任意一个页面,都可以看到有logger 出来,如下:
Started GET "/assets/application.css?body=1" for 127.0.0.1 at 2018-07-10 17:27:22 +0800 ================================================== Request delta time: 0.002136335 seconds. ==================================================
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Learning Vue.js 2
Olga Filipova / Packt Publishing / 2017-1-5 / USD 41.99
About This Book Learn how to propagate DOM changes across the website without writing extensive jQuery callbacks code.Learn how to achieve reactivity and easily compose views with Vue.js and unders......一起来看看 《Learning Vue.js 2》 这本书的介绍吧!