从ajax获取数据库记录(错误500)

时间:2021-03-29 14:46:20

标签: jquery ajax laravel laravel-blade

我正在通过 GET 执行 AJAX 请求,以从视图中的数据库接收数据。

我的 HTML:

<form method="POST" action="{{ route('myaccount.facturacion.guardar') }}">
@csrf

...

<div class="col-lg-3">
        <div class="form-group mb-3">
            <label>Código postal</label>
            <input type="text" name="codigo_postal" class="form-control" id="codigo_postal" maxlength="5" required>
        </div>
    </div>

        <div class="col-lg-3">
            <div class="form-group mb-3">
                <label>Localidad</label>
                <input type="text" name="localidad" id="localidad" class="form-control" required>
            </div>
        </div>

        <div class="col-lg-3">
            <div class="form-group mb-3">
                <label>Provincia</label>
                <input type="text" name="provincia" id="provincia" class="form-control" required>
            </div>
        </div>

</form>

我正在尝试执行的 AJAX 请求:注意:我将原始 url 替换为:...

$(document).ready(function () {
    var codigo_postal = $('#codigo_postal');
    codigo_postal.keyup(function () {
        var value = codigo_postal.val();
        if (value.length == 5) {

            $.ajax({
                url: '.../postal/' + value,
                method:'GET'
            }).done(function(res){
                alert(res)
            });
        }
    })
});

我尝试向其发出请求的路线:

Route::get('postal/{codigo_postal}', 'MyAccountController@obtenerCodigoPostal')->name('postal_code.get');

附加到路由的控制器方法:

public function obtenerCodigoPostal($codigo_postal) {
        $cp = Categoria::where('codigo_postal', $codigo_postal)->first();
        $postal_code = $cp->codigo_postal;
        return response(['postal_code' => $postal_code]);
    }

我得到的错误:

enter image description here

你能帮我吗?请

1 个答案:

答案 0 :(得分:1)

看起来响应成功返回到服务器,但正如 Rory 所说,这是服务器端代码的错误。这里:

public function obtenerCodigoPostal($codigo_postal) {
    $cp = Categoria::where('codigo_postal', $codigo_postal)->first();
    $postal_code = $cp->codigo_postal;
    return response(['postal_code' => $postal_code]);
}

如果您试图返回 Categoria 是否存在,这有点不同。现在,您将返回与进入方法完全相同的内容,codigo_postal。但是,如果具有该邮政编码的 Categoria 不存在,它将在服务器上失败(500 错误),因为 $cpnull,因此无法提取邮政编码来自空对象。

我建议尝试发回邮政编码或失败消息,并在中间进行错误检查以防止服务器错误:

public function obtenerCodigoPostal($codigo_postal) {
    $cp = Categoria::where('codigo_postal', $codigo_postal)->first();
    if($cp === null){
        return response('Fail', 200);
    }
    else{
        $postal_code = $cp->codigo_postal;
        return response('Pass', 200);
    }
}

您可以稍后调整响应 - 这只是为您提供一种测试成功的方法。

HTH

相关问题