0

我正在尝试让 jQuery ajaxPrefilter 与以下 JS 代码一起使用。这是我用来调用 ajax 函数的代码。

var $setallow = $(".show");
$setallow.click(function() {
    var $allow = $(this).closest("form");
    var formData = $allow.serialize();
    submitForm(formData);
});
function submitForm(formData) {

     $.ajax({
        type: "POST",
        url: "/schedule_update.php",
        data: formData,
        dataType: "json",
        cache: false,
        timeout: 8000,
        success: function(data, textStatus, jqXHR) {

            },
        error: function(data, textStatus, errorThrown) {

            }
    });
};

这是我要使用的前置过滤器代码。此代码由Expression Engine提供。

$.ajaxPrefilter(function(options, originalOptions, jqXHR) {
     var old_xid = EE.XID;

     jqXHR.setRequestHeader("X-EEXID", old_xid);

     jqXHR.complete(function(xhr) {
        var new_xid = xhr.getResponseHeader('X-EEXID');

        if (new_xid) {
           EE.XID = new_xid;
           $('input[name="XID"]').filter('[value="'+old_xid+'"]').val(new_xid);
        }
     });
});

这是带有表单的 HTML 代码。

<form>
  <input type="hidden" name="XID" value="{XID_HASH}" />
  <input type="hidden" name="id" value="1" />
  <input type="checkbox" name="allow" value="yes" class="show" />
</form>

如何使此预过滤器与我的代码一起使用?一旦我将预过滤器添加到我的 JS 代码的任何部分,表单就不再提交到我的 php 页面来更新数据库。谢谢你提供的所有帮助。

4

1 回答 1

0

我也遇到了这个问题,无法弄清楚。如果计划是创建一个新的 XID 代码,为什么不通过 php 脚本中的 ajax 调用返回它。只需在 json_encode 函数中添加“XID_SECURE_HASH”,如下所示:

<?php
    public function get_new_xid_hash() {
        $data = array('XID' => XID_SECURE_HASH, 'otherData' => 'Show this text');

        echo json_encode($data);
        die();
    }
?>

ajax 调用的返回可能是这样的:

success: function(data) {
    EE.XID = data.XID;
}

所以下次你用 ajax 发出请求时,它会包含更新后的 XID 代码。

希望这可以帮助。

于 2013-10-16T16:22:14.140 回答