`
xf986321
  • 浏览: 164812 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

控制器内部对请求的操作

阅读更多
控制器内部对请求的操作
一Action方法
1调用方式
控制器处理请求时会找到与之名字匹配的action.
调用method_missing(),如果找不到action
调用模版,如果找不到action和method_missing()
调用错误报告Unknown Action如果上述都不符合
2禁止调用
将action声明为protected或private,也可以不改变私有性声明为hidden_action :XXX
3控制器环境
action_name 当前处理的action名称
cookies与请求相关的cookie,相应时对象设置的值将保存到客户机上
headers一个类似于hash的对象,代表HTTP头信息,这些信息用于应答
params一个类似于hash的对象,存放着请求参数
request进入控制器的请求对象,包含属性:
domain 返回请求地址中域名部分的最后两段
remote_ip一字符串形式返回客户端IP,若有代理则包含多个IP地址
env返回客户浏览器设置的环境变量值如:request.env[‘XXX’]
method返回客户端所使用的请求方法:delete,put,get,post….
delete?,get?,head?,post?,put?返回是否为该方法:true or false
xml_http_request?和xhr?,请求来自AJAX则返回true 与method值无关
response代表HTTP应答的对象,在处理时rails填充这个对象
session一个类似与hash的对象,代表当前的session数据
4应答
模版的渲染(render:)
Rails内建支持3中模版:.rhtml格式内嵌ruby代码的HTML代码;构造器XML内容的方式;rjs,用于生成JavaScript
通过定义ActionController::Base.template_root=dir_path改变视图根路径,默认的视图根路径为:app/views
render(:text=>string)将指定字符串发送给客户端
render(:inline=>string,:type=>”rhtml”/”rxml”/”rjs”,:locals=>hash)把string内容作为指定的type模版进行渲染,:locals提供局部模版中的变量
render(:action=>action_name,:locals=>hash)渲染控制器中指定的action对应的模版
render(:file=>path,:use_full_path=>true/false,:locals=>hash)渲染指定路径的模版, 若设置:use_full_path=>true,则变为相对路径的方式寻找
render(:template=>name)  template必须同事包含控制器名和action名
render(:partial=>name)  渲染一个局部模版
render(:js=>”alert(‘xxx’)”) 将返回text/javascript格式
render(:nothing=>true)  什么都不返回---返回一片空白给浏览器
render(:xml=>stuff)  以xml格式渲染,stuff将被强制转换为xml格式
render(:json=>stuff)  以json格式渲染,stuff将被强制转换为json格式
render(:update) do |page| …end以rjs模版渲染 从略
文件下载(send_data,send_file)
send_data(data, options)发送一个二进制数据流给客户端
send_file(path, options)发送一个文件内容给客户端
重定向(redirect_to)
Redirect_to(:action, options)options可以提供params的值
Redirect_to(:back)返回前一个action
5 cookie和session
cookie
cookie的创建:cookie的值必须是字符串
Cookies[:name]={:value=>值,:domain=>”http://www.xxx.com”,:path=>”/store”,: expires =>””,:secure=>”secure”/”空串” }
domain属性用来设置所定义的Cookie变量的域,设置不同变量的域可以防止不同网站之间的Cookie相互冲突
path属性用来设置所定义的Cookie变量的文件路径,请求为此路径时cookie才有效
expires属性来设置它的生命期限。
secure属性为secure或为空,WEB服务器之间就通过HTTPS或者其它安全协议传递数据
session
与cookie不同session是保存在服务器端的。建立会话后应用会为session分配一个session_id,他将保存在cookie中以便用户对session的访问以及修改
Session中可以保存任意可以被序列化的对象。存储ActiveRecord对象需在控制器中加入声明——model : session的键,在声明的控制器引用session便可为模型对象进行序列化和反序列化的操作
1)Session自定义属性:可在config/environment中设置config.action_controller.session.option的hash
:session_domain 用于保存session_id的cookie作用域,默认为当前应用域名
:session_id如果不设置此项,新建session会自动得到一个32字长的id
:session_key用于保存session id的cookie名称
:session_path有效的路径范围。默认值是/,既整个域名内有效
:session_secure如果设为true,则只有当用http://开头的地址访问时session生效
2)Session的存储
在config/environment中设置config.active_record.session_store的值来指定存储机制,这个值由CGI::Session模块中定义,除PStore与默认的cookiestore,其他存储策略直接符号引用
session_store=CGI::Session:PStore方式
数据保存到PStore格式的文件中,2.x后被遗弃的方式
session_store=:active_record_store
数据保存到数据库,通过rake db:sessions:create建立session表迁移任务。2.x后开启此模式若同时需要csrf保护,需要设置csrf密钥
session_store=:drb_store
数据保存到非web应用之外的服务器(而通过服务器这些数据又可以存储到不同的物理位置,google采用了这种水平伸缩的吞吐)
其他存储方式是不推荐作为B/S架构的存储方式。
3)session的过期
人工session过期可以使用reset_session(),是一种主动清除的策略;如果采用非cookiestore可以服务器删除过期session的策略
Flash
Flash有session类似的功能,区别在于flash所记忆的内容只能提供给跳转后的下一个action,所以我经常把flash又叫做小session
Flash的两个方法:
flash.now[:key]=value此flash将能通过跳转传到下个action
成功跳转后在跳转后的action定义:flash.keep[:key]=value将保持传递性,将再传递到下一个action,从而实现了2次跳转仍然保持原数据。
6过滤器与校验
1)前置、后置、环绕过滤
before_filter:     前置
after_filter:  后置
around_filter: 环绕
注:一个controller中有多个前置、后置过滤器时,加入一个前置或后置过滤都将会添加到所有以添加的过滤器后,既先执行其他过滤后在执行 新加入的前置或后置过滤。若希望新加入的先被执行则前置:prepend_before_filter,后置:prepend_after_filter
环绕过滤与上述不同,当controller中有多个环绕过滤时,新加入的环绕则嵌套在其他环绕过滤中,就如同大家见过的嵌套循环的结构一样
2)过滤形式
过滤方法:定义一个过滤方法通过xxx_filter: method引用,注:环绕过滤内部要用yield引入要执行的action
过滤模块:  xxx_filter do |some_params|
some_params为控制器参数
end
注:环绕过滤还要传入另一个参数,该参数的call方法将执行过滤的action
过滤类:定义一个类,并创建类方法filter(some_params),过滤声明为xxx_filter 类,
当过滤器被调用,则类的filter方法被调用,并传入控制器参数。注:环绕过滤需要在filter类方法中定义yield
3)过滤的有效范围
xxx_filter:some_method,:only=>[:one_action,:two_action]指定需要过滤的action
xxx_filter:some_method,:except=>[:one_action,:two_action]指定不需要过滤的action
4)rails提供的内置过滤校验
例:
verify :only=> :some_action  #需要过滤验证的内容
:session=>:some_key  #判断会话中有some_key的键值
:add_flash=>{:note=>”some_noties”} #上个条件不成立flash添加此信息
:redirect=>:some_action #条件不成立跳转的action
有效范围 :only=> :some_action 需要过滤的action
:except=> :some_action 不需要过滤的action
检查条件 :flash=>:key  #flash中是否包含指定的键
:method=>:symbol  #请求方法(get、post、put等)
:params=>:key  #请求参数中包含指定的键
:session=>:key  #session中是否包含指定的键
:xhr=>true or false  #请求是否来自AJAX
动作 :add_flash=>hash  #将指定的hash放入flash
:add_headers=>hash  #应答头信息放入hash的内容
:redirect_to=>url_for,params  #根据条件跳转
:render=>params  #根据条件渲染模版
7缓存处理
三种缓存机制:
页面缓存:将整个渲染后的页面放入缓存,后续调用直接调用缓存
Action缓存:需经过filter后将action放入缓存,后续访问通过过滤后若有此
缓存,则直接调用缓存
片段缓存:后面介绍
1)缓存钩子(控制器中)
caches_page :some_action  #设定某个action的页面缓存
caches_action :some_action  #设定某个action的action缓存
注:缓存只要在生产模式被开启,手动设置为在environement.rb中设置
config.action_controller.perform_caching=true,这里特别要注意,不是所有内容都能缓存,对于可变性很大的内容最好不要缓存,这个需要根据开发经验而定
2)手工清除缓存
缓存的内容被更新后,对于用户缓存的内容没有任何意义,并且没用的缓存会占用大量的资源。
expire_page :some_action  #清除指定action的页面缓存
expire_action :some_action  #清除指定action的页面缓存
3)缓存清扫器
人工清理缓存对于大型项目势必要漏清,这里引入清理器,清扫器应该放在model下
class SomeModelSweeper < ActionController::Caching::Sweeper
observe Article  #设置要监视的模型
#表中添加新数据后执行页面缓存清理
def after_create(article)
expire_public_page
end
#表中数据被更新后执行action缓存清理
def after_update(article)
expire_article_page(article.id)
end
#表中数据被删除一条或多条时同事执行页面、action缓存清理
def after_destroy(article)
expire_public_page
expire_article_page(article.id)
end
private
def expire_public_page
expire_page(:controller => "content" , :action => 'public_content' )
end
def expire_article_page(article_id)
expire_action(:controller => "content" ,
:action => "premium_content" ,
:id => article_id)
end
end
控制器中的清理器钩子(在控制器中)
cache_sweeper :article_sweeper,   #开启Article清理器
:onlye=>:some_action  #监视的控制器
:except=>:some_action  #忽略的控制器
注:若要对可变性较大内容进行缓存需要引入时间缓存失效策略:通过操作系统编写定时删除缓存的进程来控制
8CSRF安全策略
Rails2.x后引入了防止跨域访问攻击的pluging,具体操作如下
在控制器中定义protect_from_forgery钩子,在模版中使用form_for等标签时,服务器会在生成form_for等标签时 建立一个密钥(token),服务器会监视request回来的所有post以及AJAX行为,如果request没有token或者与服务器计算出的不 一致,将返回错误信息。
cookiestore的session存储机制下,token是根据CGI::Session.generate_unique_id生成的随即数并进行编码得到的,所以不需要为protect_from_forgery设置secret的键值
:active_record_store是根据session_id、protect_from_forgery的secret的值以及digest(默认是SHA1)计算得来,所以要为这种session机制设置secret值。
分享到:
评论

相关推荐

    Compellent存储设备控制器管理与操作

    综上所述,对Compellent存储设备控制器的管理和操作需要全面理解其功能、配置选项以及监控方法。熟练掌握这些技能将有助于确保存储系统的稳定性和数据安全性,同时也有利于优化整体IT环境的性能。

    部署额外域控制器

    例如,如果组织内部员工分布在不同城市,而所有的身份验证请求都必须经过中央的域控制器,则会因广域网的速度限制而降低效率。通过在各个地点部署额外域控制器,可以显著提升本地用户的登录速度和体验。 #### 二、...

    电动车控制器源程序。

    这一部分代码主要涉及到对控制器内部状态的检测以及相应的处理逻辑。例如通过`BTFSC 0x39, 04`检测特定位的状态,并根据检测结果跳转到不同的标签继续执行。通过这种方式可以实现对不同状态的响应处理。 5. **中断...

    jmeter接口演示_while控制器.rar

    2. 控制循环内的逻辑:在While控制器内部,可能包含HTTP请求、断言、定时器等元素。每次循环,这些元素都会被执行一次,直到条件不再满足。 3. 结合使用其他控制器:While控制器可以与其他控制器(如If控制器、...

    j2ee控制器及应用

    控制器作为用户请求和应用逻辑之间的桥梁,主要负责接收用户的请求,解析请求参数,调用相应的业务逻辑,然后将结果传递给视图进行展示。在J2EE中,控制器可以是Servlet、Filter或其他实现特定接口的类。 **二、...

    MVC异步控制器加载一个网页的所有内容

    - 只对耗时的操作使用异步控制器,如数据库查询、文件I/O或网络调用。 - 使用`Task`和`async/await`语法糖,简化异步代码的编写和理解,这在ASP.NET MVC 4及以上版本中是可行的。 通过以上分析,我们可以看出...

    S3C2440中断控制器实现

    1. **初始化中断控制器**:在系统启动阶段,需要对中断控制器进行初始化,包括设置中断源的优先级、打开或关闭特定中断,以及设置中断向量表。 2. **编写中断服务程序**:对于每一个可能的中断源,都需要编写相应的...

    微机原理及应用:第十章 DMA控制器8237A.pdf

    DMA 控制器8237A 的内部结构主要由五个部分组成:时序与控制逻辑、优先级编码电路、数据和地址缓冲器组、命令控制逻辑、内部寄存器等。时序与控制逻辑部分接受系统送来的时钟、复位、片选和读/写控制等信号,完成...

    节 控制器组成原理PPT课件.pptx

    首先,控制器的基本功能包括取指令、分析指令、执行指令、管理输入/输出操作以及处理随机事件和特殊请求。取指令是控制器从内存中读取指令到指令寄存器的过程;分析指令则是通过指令译码器将指令的操作码解析,生成...

    电梯控制器VHDL源程序

    这里通过定义信号来跟踪系统状态,例如`STATE`(当前状态)、`FLOOR`(楼层指示灯)、`CURRENT_FLOOR`(当前楼层)、`DOOR_TIME`(门开关时间计数)、`INNER_REQ`(内部请求)等。 #### 4. **状态机设计** 这份...

    php_easybox控制器

    控制器方法内部,可以通过`$_GET`和`$_POST`全局变量来获取请求参数,然后调用模型进行数据操作。 EasyBox控制器还支持路由配置,使得开发者能够灵活地定义URL与控制器方法的映射关系。这增强了应用程序的可维护性...

    SDRAM控制器_Verilog版(下板可用)

    SDRAM控制器是管理SDRAM与CPU之间数据交换的关键组件,它负责控制内存的读写操作、初始化、自刷新等功能。以下是对SDRAM控制器以及相关知识点的详细解释: 1. **SDRAM控制器的基本结构**: SDRAM控制器通常由以下...

    基于CAPL的CAN控制器Bootloader上位机系统设计_蔡营

    软件能够集成数据刷写过程中的所有诊断服务请求,通过直接导人要刷写到控制器内部的数据流文件,完成程序数 据在线更新功能。通过CANoe软件自带的CAPL语言实现刷机刷写上位机程序设计,提供简单明了的用户操作界面,...

    0617请求转发和请求跳转,处理模型数据.zip

    当一个请求到达控制器方法后,如果需要将处理逻辑转移到其他控制器或同一个控制器的另一个方法,就会使用请求转发。在这个过程中,客户端浏览器的URL不会改变,因为整个过程都在服务器端进行。请求转发可以共享请求...

    电梯运行控制器实验报告

    电梯运行控制器实验报告的核心知识点主要涉及电子系统设计、PLD编程和硬件描述语言的应用,以及电梯控制系统的设计原理和实现。 1. **自顶向下的电子系统设计方法**:这是一种系统设计策略,它从系统的整体功能出发...

    rtl8019as以太网控制器电路图

    该控制器具有丰富的功能,包括自动检测接口类型(如AUI或RJ-45)、内置MAC(媒体访问控制)层协议、支持多种操作模式等,使其成为各种网络应用的理想选择。 ### 引脚配置与功能 在电路图中,我们可以看到rtl8019as...

    PLC控制器上位机通信控制.doc

    PLC控制器上位机通信控制 PLC控制器作为一种高性能的控制装置,在控制领域已经得到了广泛应用。在使用PLC的控制方式中,上位监控系统是其中的重要组成部分。目前PLC与上位机PC(计算机)通信方式主要有以下几种:1)...

    控制器原理PPT学习教案.pptx

    控制器是计算机硬件系统的核心组成部分,它的主要职责是管理和协调计算机内部的各种操作,确保整个系统的顺畅运行。在本文中,我们将深入探讨控制器的原理,包括其功能、组成以及在计算机运行过程中的作用。 首先,...

    电梯控制器程序 VHDL

    电梯控制器程序是实现电梯自动化运行的关键,通常使用硬件描述语言如VHDL进行设计。本例中的VHDL程序主要用于创建一个6层楼的电梯控制系统,确保电梯能够根据乘客的需求和状态安全、有效地运行。VHDL代码包含了电梯...

Global site tag (gtag.js) - Google Analytics