1

有时我会收到 403 禁止错误,我看不出有什么问题。
这是我的 jQuery 代码:

    $.ajax({
        type: 'POST',
        url: './ajax-conf-editc.php',
        data: { conf_id: Id, conf_contenido: data },
        async: false,
        success: function(msg){
            if ( msg == '1' || msg == 1){
                var confname = $('#nameConf').val();
                $.cookie('SUCCESS', 'Se ha guardado el contenido de la configuración "' + confname + '".', { expires : 1, path : '/' });
                $(window.location).attr('href', 'index.php');
            } else {
                $('#conf-editc-form').removeAlertBoxes();
                $('#conf-editc-form').alertBox(msg, {type: 'error'});
            }
        }
    });

使用此数据可以正常工作:

conf_id=11&conf_contenido=%2523tabs-0%253CtabContent%253E%253Cp%253EContenido%253C%2Fp%253E%253CtabTitle

但是当我发送这个时,失败并返回一个 403 Forbidden

conf_id=11&conf_contenido=%2523tabs-0%253CtabContent%253E%253Cp%253E%253Ca%2520onclick%253D%2522javascript%253A%2524%2528%2520%2527%2523tabs%2527%2520%2529.tabs%2528%2529.tabs%2528%2 %257D%2529%253Bscroll%25280%252C0%2529%2522%2520href%253D%2522javascript%253Avoid%25280%2529%253B%2522%253EContenido%253C%2Fa%253E%253C%2Fp%253E%253Ctab3Titletab%253E%253Ctab33 %253E%2523tabs-1%253CtabContent%253E%253Cp%253EContenido%25201%253C%2Fp%253E%253CtabTitle%253Edos

我希望有人可以帮助我并告诉我为什么会这样?

这是我失败时收到的消息:

禁止的

您无权访问此服务器上的 /kidspc2/configuraciones/ajax-conf-editc.php。

此外,在尝试使用 ErrorDocument 处理请求时遇到 404 Not Found 错误。

编辑: mod_security 可以这样做吗?我怎么查不到?

编辑:我解决了这个问题,在 Base64 中编码 conf_content 值。

4

2 回答 2

1

我猜您的 $.ajax 在很短的时间内被多次请求,这就是您收到此 404 错误的原因。您可以通过取消所有以前的 ajax 调用并为最新的 ajax 调用请求进行新的 ajax 调用来修复它。希望这可以帮助。

像下面的代码:

    if( this.ajax ){
            this.ajax.abort();
        }
        this.ajax=$.ajax({
        type: 'POST',
        url: './ajax-conf-editc.php',
        data: { conf_id: Id, conf_contenido: data },
        async: false,
        success: function(msg){
        if ( msg == '1' || msg == 1){
            var confname = $('#nameConf').val();
            $.cookie('SUCCESS', 'Se ha guardado el contenido de la configuración "' + confname +        '".', { expires : 1, path : '/' });
            $(window.location).attr('href', 'index.php');
        } else {
            $('#conf-editc-form').removeAlertBoxes();
            $('#conf-editc-form').alertBox(msg, {type: 'error'});
        }
    }
});    
于 2015-01-02T18:24:43.430 回答
1

尝试删除网址中的点和斜杠

./ajax-conf-editc.php 把这个改成这个,ajax-conf-editc.php然后告诉我你得到了什么。

于 2012-07-31T23:08:24.050 回答