Gau*_*tam 2 php redirect cakephp flash-message cakephp-2.1
使用CakePHP 2.1我有以下代码
public function getForm($id=null){
$this->loadModel('DynamicFormResponse');
/**
* Check if form exists
*/
$this->form_schema= $this->DynamicForm->isValidForm($id);
if($this->form_schema == false){
$this->flash("Invalid form", $this->referer(
array('controller'=>"pages", 'action' => 'display')
));
}
...
...
Run Code Online (Sandbox Code Playgroud)
我面临的问题是,调用$this->flash()渲染flash页面,但也继续执行控制器.
所以,除非我做类似的事情
if($this->form_schema == false){
$this->flash("Invalid form", $this->referer(
array('controller'=>"pages", 'action' => 'display')
));
return;
}
Run Code Online (Sandbox Code Playgroud)
控制器不会终止.
_crsf_error调用方法时会出现主要问题
function _csrf_error() {
$this->flash("csrf Error", $this->referer(
array('controller'=>"pages", 'action' => 'display')
));
}
Run Code Online (Sandbox Code Playgroud)
由于flash方法不重定向它根本不提供csrf保护.在方法中使用return;后不起作用.$this->flash()_crsf_error
PS:这里有完整的代码
小智 6
虽然上面的答案很好地解释了flash()方法的作用,但对我来说,它并没有完全回答这个问题,而是提供了一个很好的选择.
我个人想要使用flash方法,所以我不必使用会话组件,我发现自己也卡在了我的flash消息上.在cake 2.x文档中,它说flash()方法的第二个参数是CakePHP相对URL.这意味着以下内容应显示一条消息,然后重定向到索引操作.
$this->flash(__("Some message for the user here..."), array("action" => "index"));
Run Code Online (Sandbox Code Playgroud)
我的问题,以及它看起来像原始海报的问题,是它向你显示了flash消息,但之后没有进行重定向.
我用我的应用程序彻底测试了这个,罪魁祸首是core.php中的调试设置
Configure::write('debug', 0);
Run Code Online (Sandbox Code Playgroud)
必须将调试值设置为"0"才能进行重定向.我不知道为什么会这样,但是当我的调试设置设置为1或更高时,我测试了大约10次和10/10,我刚收到了flash消息.如果我将它设置为0,一切都很完美.这对我来说并不是什么大问题,因为生产环境无论如何都应该将此设置设置为0.
如果其他人对调试开启时没有发生重定向的原因有所了解,请大家指教.
希望这可以帮助.
flash()它没有重定向,它呈现.它与render()函数非常相似,它将继续执行脚本,与redirect()函数不同.
您只需要相应地组织您的逻辑,以便在它之后不执行任何其他行如果您不想这样做.您可以选择session->setFlash()将其与重定向结合使用.
当处理像无效的csrf令牌这样的严重错误时,我建议抛出异常而不是向攻击者呈现一个好消息.但是,您可以使用错误处理程序来修饰异常呈现.
| 归档时间: |
|
| 查看次数: |
3134 次 |
| 最近记录: |