我以application/json
内容类型将数据从客户端发送到服务器。
然后我尝试在服务器端获取此信息,如:
public function register(Request $request)
{
$data = $request->json()->all();
var_dump($data); die();
}
它返回空array()
此外,我尝试使用以下方法验证传入的POST:
$validator = Validator::make($request->json()->all(), []);
如何在Laravel中获取和验证application / json数据?
我得到的POST数据如下:
dd($_POST);
array:1 [▼
"application/json" => "{"id":6,"unique_code":null,"name":"О","secondname":"П","lastname":"Валерьевич","datebirth":"14/10/1991 00:00:00","taxcode":"4545","gender":"1","created_at":null,"file":"C:\\db\\tests\\22-07-2017\\MMM1.TXT","orders":{"profession":"Директор","pacient_id":null,"payment":"1","kind_work":"1,2","factory_name":"FALKO","factory_edrpou":"2020","factory_departament":"IT","status_pass":"1","office_address":"Kiev","unique_code":"0","enterprise_id":"12","status":null},"http_code":null}"
]
答案 0 :(得分:1)
发布的数据最终会出现在请求正文参数包中。您可以通过$request->all()
或$request->request->all()
获取数据。
因此Validator看起来像这样:
$validator = Validator::make($request->all(), []);
深入潜水:
或者您可以在控制器中使用validate()
方法。看起来像这样:
$this->validate($request->all(), []);
在Laravel docs中了解详情。
为了使事情更复杂,您甚至不需要将Request实例注入控制器。您可以使用request()
辅助函数。寄存器方法如下所示:
public function register()
{
$this->validate(request()->all(), [
'email' => 'required|email',
'password' => 'required|min:6|confirmed',
]);
}
答案 1 :(得分:1)
我有一个api我发布了json。我有一个api终点,我发布这个json
{
"email":"youremail@triumworks.com",
"phone": "phone",
"name": "name",
"password": "password"
}
处理请求的相应控制器看起来像
public function create_account(Request $request){
$data = json_decode(file_get_contents('php://input'));
$response = new Responseobject;
$array_data = (array)$data;
$validator = Validator::make($array_data, [
'name' => 'required|string|max:255',
'email' => 'required|string|email|max:255|unique:users',
'password' => 'required|string|min:6',
'phone' => 'required|string|min:12|max:12|unique:users',
]);
if($validator->fails()){
$response->status = $response::status_failed;
$response->code = $response::code_failed;
foreach ($validator->errors()->getMessages() as $item) {
array_push($response->messages, $item);
}
}
else{
$api_token = str_random(60);
$user = new User();
$user->api_token = $api_token;
$user->name = $data->name;
$user->email = $data->email;
$user->phone = $data->phone;
$user->password = bcrypt($data->password);
if($user->save()){
$response->status = $response::status_ok;
$response->code = $response::code_ok;
$response->result = $user;
}
}
return Response::json(
$response
);
}
这与上面的相同。
public function create_account(Request $request){
$response = new Responseobject();
$validator = Validator::make($request->json()->all(), [
'name' => 'required|string|max:255',
'email' => 'required|string|email|max:255|unique:users',
'password' => 'required|string|min:6',
'phone' => 'required|string|min:12|max:12|unique:users',
]);
if($validator->fails()){
$response->status = $response::status_failed;
$response->code = $response::code_failed;
foreach ($validator->errors()->getMessages() as $item) {
array_push($response->messages, $item);
}
}
else{
$api_token = str_random(60);
$user = new User();
$user->api_token = $api_token;
$user->name = $data->name;
$user->email = $data->email;
$user->phone = $data->phone;
$user->password = bcrypt($data->password);
if($user->save()){
$response->status = $response::status_ok;
$response->code = $response::code_ok;
$response->result = $user;
}
}
return Response::json(
$response
);
}