Я изучаю красноречивые отношения и хочу создать пост для конкретного пользователя. Я хочу добавить User_Id в форму создания
Ниже приведены мои фрагменты кода:
@extends('layouts.app')
@section('content')
<div class = "container">
<form method = "post" action = "{{route('articles.store')}}">
@csrf
<input type = "hidden" name = "user_id" value = "{{ Auth::user()->id }}">
<div class = "form-group">
<label>Başlık</label>
<input class = "form-control" name = "title" placeholder = "Başlık">
</div>
@if ($errors->has('title'))
<span class = "text-danger">
{{$errors->first('title')}}
</span>
@endif
<div class = "form-group">
<label>Post İçeriği</label>
<textarea class = "form-control" name = "body" placeholder = "İçerik" rows = "3"></textarea>
</div>
@if ($errors->has('body'))
<span class = "text-danger">
{{$errors->first('body')}}
</span>
@endif
<button type = "submit" class = "btn btn-primary">Kaydet</button>
</form>
</div>
@endsection
и моя модель статьи такая;
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Article extends Model
{
protected $fillable=[
'title','body','user_id'
];
public function user()
{
return $this->belongsTo('App\User');
}
}
А вот и мой контроллер;
public function store(ArticleRequest $request)
{
Auth::user();
$article = new Article();
$article -> title=$request->get('title');
$article -> body=$request->get('body');
$article->save();
return redirect()->route('articles.index');
}
Но в конце я получаю ошибку ниже:
SQLSTATE[HY000]: General error: 1364 Field 'user_id' doesn't have a
default value (SQL: insert into `articles` (`title`, `body`, `updated_at`,
`created_at`) values (Merhaba, Bu post id değeri 1 olan user tarafından
yazıldı., 2018-05-03 06:55:45, 2018-05-03 06:55:45))






public function store(ArticleRequest $request)
{
Auth::user();
$article = new Article();
$article -> title=$request->get('title');
$article -> body=$request->get('body');
$article ->user_id=$request->get('user_id'); // add this line
$article->save();
return redirect()->route('articles.index');
}
Да @Tuim, ты прав. Я опубликовал этот ответ в соответствии с шаблоном лезвия, имеющим содержимое. В противном случае лучше взять идентификатор пользователя из Auth :: user ();
Вы получаете пользователя в
$user = Auth::user();
используйте этот идентификатор
$article -> user_id = $user->id;
public function store(ArticleRequest $request)
{
$user = Auth::user();
$article = new Article();
$article -> title=$request->get('title');
$article -> body=$request->get('body');
$article -> user_id = $user->id;
$article->save();
return redirect()->route('articles.index');
}
Или же
иначе вы можете получить user_id в почтовом запросе из формы (для этого вы можете использовать скрытое поле для user_id в своей форме) и просто передать его
$article -> user_id=$request->get('user_id');
Вы можете получить текущий идентификатор пользователя, вошедшего в систему, из процедуры аутентификации пользователя в магазине.
public function store(ArticleRequest $request)
{
Auth::user();
$article = new Article();
$article -> user_id=Auth::user()->id;
$article -> title=$request->get('title');
$article -> body=$request->get('body');
$article->save();
return redirect()->route('articles.index');
}
Вы можете отправить идентификатор пользователя вместе с другими данными публикации, как это делали другие ответы. Но раз уж вы изучаете, как работают красноречивые отношения, почему бы не использовать их для сохранения модели статьи.
Создайте взаимосвязь статей внутри модели User:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
.........
.........
// Since user can have many articles, then i assumed you need
// hasMany relationship here, otherwise please change accordingly.
public function articles()
{
return $this->hasMany(Article::class);
}
}
И в вашем контроллере (он автоматически добавит внешний ключ к модели Article):
public function store(ArticleRequest $request)
{
$user = Auth::user();
$user->articles()->create($request->only(
'title',
'body'
));
return redirect()->route('articles.index');
}
И, наконец, удалите поле ввода user_id из формы (больше не нужно, так как статья будет сохранена отношениями аутентифицированной модели User):
<!-- remove this -->
<input type = "hidden" name = "user_id" value = "{{ Auth::user()->id }}">
Это небезопасно, люди могут публиковать сообщения от имени других пользователей, изменяя скрытое входное значение. Посмотрите на ответ @Tanvir ниже, который предлагает лучшее решение.