使用HTML表单Laravel更新数据库



我正在尝试编辑用户的配置文件,但我会遇到此错误:

ErrorException in editController.php line 144: Creating default object from empty value

这是我的edit.blade.php

                    <blockquote>
                    <p>You could edit your profile here.</p>
                    </blockquote>
                <table width="80%">
                    <tr>
                        <td>Last Name: </td>
                        <td><input type="text" name="lname" value='{{ $user -> lname}}' size="20"><br>
                             {{ ($errors->has('lname')) ? $errors->first('lname') : '' }} <br> </td>
                    </tr>
                    <tr>
                        <td>First Name: </td>
                        <td><input type="text" name="fname" value='{{ $user -> fname}}' size="20"><br>
                             {{ ($errors->has('fname1')) ? $errors->first('fname') : '' }} <br> </td>               
                    </tr>  
                    <tr>
                        <td>Middle Name: </td>
                        <td><input type="text" name="mname" value='{{ $user -> mname}}' size="20"><br>
                             {{ ($errors->has('mname')) ? $errors->first('mname') : '' }} <br> </td>                
                    </tr>             
                    <tr>
                        <td>Email Address: </td>
                        <td><input type="text" name="email" value='{{ $user -> email}}' size="20">
                        <br> {{ ($errors->has('email')) ? $errors->first('email') : '' }} <br> </td>               
                    </tr>
                    <tr>                    
                        <td>
                       <!-- <input type="hidden" name="_method" value="put">-->
                        <input type="hidden" name="_token" value="{{ csrf_token() }}">
                        <input type="submit" value="Update Profile" name = "submit" role="button" class="btn btn-warning" style="margin-top: 25px; margin-bottom: 7px;">
                       <a href="/home" class="btn btn-default" role="button" style="margin-left: 5px; margin-top: 25px; margin-bottom: 7px;">Back</a>
                       </td>
                    </tr>
                </table>
            </form>      

这是我的editcontroller

public function index()
{
     $user = Auth::user();
    return view('user/profile', array('user' => $user));
}
    public function edit(){
        //$user = User::find($id);
         $user = Auth::user();
        // display the article to single page
       return view('user/editProfile', array('user' => $user));
    }
   public function update()
    {
        // Get the status
            $user = Auth::user();
           $userf->fname = Input::get('fname');
           $userm->mname = Input::get('mname');
           $userl->lname = Input::get('lname');
           $usere->email = Input::get('email');
           $sql = "UPDATE users SET fname= ? mname= ? lname = ? email = ? WHERE id= ?";
           DB::update($sql, array($userf, $userm, $userl, $usere , $user));
            return Redirect::to('/home');
    }

这是我的路线

Route::get('/home', 'editController@index');
Route::get('/editProfile', 'editController@edit');
Route::post('/updating', 'editController@update');

您能帮我找出为什么我会遇到这个错误吗?感谢您的帮助

,我可以看到,问题是您使用$ userf,$ userm,$ userl,$ usere作为对象而不先声明这些变量,例如对象,因此当您执行$userf->fname时,获取错误Creating default object from empty value

我认为您只需要使用$用户对象就新属性进行定位并将其保存到数据库。

所以您可以做

$user->fname = Input::get('fname');
$user->mname = Input::get('mname');
$user->lname = Input::get('lname');
$user->email = Input::get('email');

然后您可以使用Laravel Orm保存数据$user->save();

您应该使用$ request-> user()返回身份验证的用户的实例。

我修改了我的控制器,并且有效:这是我所做的:

public function update()
{
    // Get the status
       $user = Auth::user();
       $userf = Input::get('fname');
       $userm = Input::get('mname');
       $userl = Input::get('lname');
       $usere = Input::get('email');
       $save = DB::table('users')
                ->where('id', $user->id)
                ->update(array('fname' => $userf, 'mname'=>$userm, 'lname'=>$userl,'email'=>$usere));
       return redirect('/home');

最新更新