如何解决从ajax获取数据库记录错误500
我正在通过 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]);
}
我得到的错误:
你能帮我吗?请
解决方法
看起来响应成功返回到服务器,但正如 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 错误),因为 $cp
为 null,因此无法提取邮政编码来自空对象。
我建议尝试发回邮政编码或失败消息,并在中间进行错误检查以防止服务器错误:
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