从laravel控制器返回JSON响应
问题描述:
我是Javascript的新手。我想在我的表单中做一个ajax更新。一切正常。更新完成后,数据库中的值会更新。发生问题的地方是当我尝试在视图中更新它时。这里是我的控制器从laravel控制器返回JSON响应
public function updatePost(Request $request)
{
$post = $request->all();
$val = \Validator::make($request->all(), [
'client_id' => 'required',
'client_name' => 'required',
'client_business' => 'required',
'client_ref' => 'required',
'gmail_mail' => 'required',
'gmail_pass' => 'required',
'client_dob' => 'required',
'client_addr' => 'required',
'client_no1' => 'required',
'client_ref' => 'required',
'domain_name' => 'required',
'domain_p_date' => 'required',
'domain_reg' => 'required',
'domain_ex_date' => 'required',
'domain_acc_email' => 'required',
'domain_acc_pass' => 'required',
'domain_id' => 'required',
]);
if ($val->fails()) {
return redirect()->back()->withErrors($val->errors());
}
else {
$data = array(
'client_id' => $post['client_id'],
'client_name' => $post['client_name'],
'client_business' => $post['client_business'],
'client_ref' => $post['client_ref'],
'gmail_mail' => $post['gmail_mail'],
'gmail_pass'=> $post['gmail_pass'],
'client_dob'=> $post['client_dob'],
'client_addr'=> $post['client_addr'],
'client_no1'=> $post['client_no1'],
'domain_name' => $post['domain_name'],
'domain_p_date' => $post['domain_p_date'],
'domain_reg' => $post['domain_reg'],
'domain_ex_date' => $post['domain_ex_date'],
'domain_acc_email' => $post['domain_acc_email'],
'domain_acc_pass' => $post['domain_acc_pass'],
'domain_id' => $post['domain_id'],
);
//var_dump($data);
$update_data = domain_details::where('domain_id', $post['domain_id'])
->update($data);
if ($update_data) {
$new_data = domain_details::where('domain_id',$post['domain_id'])->get();
return response()->json(['client_id'=> 'johncena'],200);
}
else
{
return redirect()->back()->withErrors($val->errors());
}
}
这是我从窗体和更新收到的数据。数据库上的更新工作正常。这就是问题的发生
if ($update_data) {
$new_data = domain_details::where('domain_id',$post['domain_id'])->get();
return response()->json(['client_id'=> $new_data->client_id],200);
JSON([ '的client_id'=> $ new_data-> CLIENT_ID],200);如果我只传递一个字符串,就像j son(['client_id'=>'John Doe'],200);。
另一个问题是当我看到控制台。如果我尝试更新表单而不更改任何内容,则会引发500内部服务器错误。这是我处理控制器响应的Javascript代码。有时字符串被改为John Doe,大多数时候我得到500个内部服务器错误。
$('#update-modal').on('click',function(){
$.ajax({
type : "get",
url : updateURL,
data : { client_id : $('#client_id').val(),
client_name : $('#client_name').val(),
client_business : $('#client_business').val(),
client_ref : $('#client_ref').val(),
gmail_mail : $('#gmail_mail').val(),
gmail_pass : $('#gmail_pass').val(),
client_dob : $('#client_dob').val(),
client_addr : $('#client_addr').val(),
client_no1 : $('#client_no1').val(),
domain_name : $('#domain_name').val(),
domain_p_date : $('#domain_p_date').val(),
domain_reg : $('#domain_reg').val(),
domain_ex_date : $('#domain_ex_date').val(),
domain_acc_email : $('#domain_acc_email').val(),
domain_acc_pass : $('#domain_acc_pass').val(),
domain_id : domain_id,
_token : token
}
})
.done(function(msg){
$(client_id_element).text(msg['client_id']);
});
});
我知道我错过了一些东西。我不知道它是什么。在此先感谢
答
那么,我认为,雄辩get()
返回一个集合,而不是某个对象。看起来你只想返回一个具有唯一性的对象domain_id
。尝试使用
$new_data = domain_details::where('domain_id',$post['domain_id'])->first();
改为。
它的工作就像一个魅力,我以为我用JSON数据犯了一些错误。和语法 –
请记住,当使用get()时,访问查询结果的正确方法是使用循环遍历整个集合并使用每个对象或使用像'$ new_data [0] - > client_id'这样的索引符号这不好。如果你确定你试图从你的数据库中获得的对象具有独特的属性,比如'id',你可以简单地使用'first()'来获得一个项目。我很高兴它工作:) – Khallister