5

处理我的 ajax 调用上的安全组件并没有按应有的方式进行。

你如何在 cakephp 2.x 中处理它?

应用控制器.php

public function beforeFilter() {
        $this->Security->blackHoleCallback = 'blackhole';
        if ($this->request->is('ajax')) {
            $this->Security->validatePost = false;
        }

似乎不起作用...

4

1 回答 1

3

您仍然可以使用 Cake 提供的表单安全机制进行安全的 ajax 调用。为此,请呈现一个不可见的表单并放置输入以存储 ajax 调用参数。然后,使用 Javascript 在您的表单中设置这些参数并通过序列化来执行 ajax 调用。请记住,如果您启用了 CSRF 检查(并且禁用了每个会话一个令牌),您将必须使用新的有效 CSRF 令牌更新表单(您可以在控制器中使用 读取它$this->request->params['_Token']['key'])。

例子:

<?php
    echo $this->Form->create('AjaxForm');
        echo $this->Form->hidden('value');
    echo $this->Form->end();
?>

<script>    
    function makeAjaxCall()  {
        $.post(
            ajaxUrl,
            $('#AjaxForm').serialize(),
            function(data) {
                $('#AjaxForm [name="data[_Token][key]"]').val(data.newCsrfToken)
            }
        );
    };
</script>

为了进一步参考,我们创建了一个组件,该组件允许在动态修改的客户端表单上保持启用的安全性,并且在进行 ajax 调用时无需解锁字段或操作。您可以在https://github.com/QTSdev/DynamicSecurity找到它。

于 2014-03-24T04:01:02.077 回答