laravel 的尝试捕获不适用于重复输入

Try catch for laravel is not working for duplicate entry

我在 laravel 控制器中使用以下代码。并得到 username 的重复错误,但我需要通过 try-catch 来处理它。此代码无效。

<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;
use Response;
use DB;

class StaffController extends Controller
{
    public function saveMember(Request $request){
        $errormsg = "";
        $result = false;
        try{
            $result = DB::table('members')->insert(
                    [
                        'username' => $request->username,
                        'phone' => $request->phone,
                        'status' => 1
                    ]
                );
        }catch(Exception $exception)
        {
            $errormsg = 'Database error! ' . $exception->getCode();
        }
        return Response::json(['success'=>$result,'errormsg'=>$errormsg]);
    }
}

我收到这个错误,我需要通过 try and catch 来处理

SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry 'test1' for key 'username' 

感谢您的帮助。

您需要将 Exception 设为全局,

  1. 要么使用。

    use Exception;
    

然后使用

catch(Exception $exception)
  1. 或使用

    catch(\Exception $exception)
    

而不是这个

catch(Exception $exception)

您可以通过首先根据数据库中所需的列验证用户名的唯一性来轻松避免此 try & catch 块 table。您可以使用 $request 对象或(更好)通过设置自定义 Request class 来执行此操作,该请求将在执行控制器方法之前执行此验证。 https://laravel.com/docs/5.1/validation#rule-unique

根据这个样本:

public function store(ServiceStoreRequest $request, int $id)
{
    $service = new Serviceable();
    $service->package_id = $id;
    $service->fill($request->all());
    try {
        $service->save();
    } catch (\Exception $exception) {
        return response(array(
            "code"=> 409,
            "error"=>"duplicate " . $exception->getMessage()));
    }
    return response($service);
}
   if($request->isMethod('post')){
        $data       = $request->all();
        $user       = Auth::user()->id;
        try {
            DB::beginTransaction();
            Company::Save($data,$user);
            BankBranch::updateBranch($data,$user,$id);
            DB::commit();
            $status = true;
        } catch (\Exception $e) {
            var_dump('Exception Message: '. $e->getMessage());
            var_dump('Exception Code: '. $e->getCode());
            var_dump('Exception String: '. $e->__toString());
            DB::rollback();
            $status = false;
        }
    }