php - 调用数组 laravel 的成员函数 getClientOriginalName()

标签 php laravel crud one-to-one

我正在尝试从一对多关系发布图像,同时还执行 CRUD(创建部分),但我在执行此操作时遇到了一些麻烦。每当我尝试使用 associate 来定义与 user_info 和 user_image 表的关系时,我一直收到此错误,调用数组上的成员函数 getClientOriginalName()。那我该怎么办呢?

这是我的代码: 创建 Controller :

public function create1(){

    return view('create1');
}

public function store1(Request $request){
     $this->validate($request, [
        'input_img' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
    ]);

 $user_info = Session::get('data');
      $UserImage = new UserImage($request->input()) ;


     if($file = $request->hasFile('input_img')) {
      $file = array();



        $fileName = $file->getClientOriginalName() ;
        $destinationPath = public_path().'/images' ;
        $file->move($destinationPath,$fileName);
        $UserImage->userImage = $fileName ;
        $UserImage = UserImage::create(['file' => $request->file('input_img')]);
        $UserImage->user_infos()->associate($user_info);
    }

    $UserImage->save() ;

    return redirect('/home');
}

HomeController(这是我打印信息的地方)

public function getInfo($id) {

  $data = personal_info::where('id',$id)->get();
      $data3=UserImage::where('user_id',$id)->get();
 return view('test',compact('data','data3'));

blade.php(我如何在 View 中显示图像)

 @foreach ($data3 as $object9)
 <img width="100" height="100" src="{!! $object9->signature !!}">
    @endforeach

UserImage模型(表中我使用二进制格式存入DB)

    class UserImage extends Eloquent
    {
            protected $fillable = array('userImage','user_id');
        public function user_infos() {
            return $this->belongsTo('App\user_info', 'user_id', 'id');
        }

class user_info extends Eloquent
{
    protected $fillable = array('Email', 'Name');
    protected $table = user_infos';
    protected $primaryKey = 'id';
        public function UserImages() {
        return $this->hasOne('App\UserImage','user_id');
    }
}

create1.blade.php(这是我上传图片的方式)

     <form class="form-horizontal" method="post" action="{{ url('/userUpload')}}" enctype="multipart/form-data">

                        {{  csrf_field()  }}


<div class="form-group">
    <label for="imageInput" class="control-label col-sm-3">Upload Image</label>
            <div class="col-sm-9">
            <input data-preview="#preview" name="input_img" type="file" id="imageInput">
            <img class="col-sm-6" id="preview"  src="" ></img>
        </div>
    </div>

 <div class="form-group">
            <div class="col-md-6-offset-2">
              <input type="submit" class="btn btn-primary" value="Save">
            </div>
          </div>
          </form>

最佳答案

我认为您在 store1() 方法中有问题。你不应该重新声明 $file

if($file = $request->hasFile('input_img')) {

    $file = array();

    $fileName = $file->getClientOriginalName();

改为使用 file() 方法获取文件:

if($request->hasFile('input_img')) {

    $file = $request->file('input_img');

    $fileName = $file->getClientOriginalName();

Laravel's requests documentation 上查看更多信息.

关于php - 调用数组 laravel 的成员函数 getClientOriginalName(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46901573/

相关文章:

crud - 写入后ABAP返回初始选择屏幕

python - Python Camelot 是否与 Elixir 相关?

php - 在 php 文件中只有一个 return 语句是否很常见

laravel - Nginx 上历史模式的 Vue 路由器服务器配置不起作用

php - 如何正确运行需要大量处理的查询而不会出错

git - 为什么 sqlite3 不能在我的 homestead/Laravel 设置中工作?

PHP 数据库为 foreach() 提供的参数无效

php - 在 Laravel 中生成随机数

javascript - 将 javascript Canvas 路径保存到数据库中的正确方法

php - 使用 LIKE 为 postgresql 表编写 php sql 查询的问题