在你的 UpdateRequest 试试这个
public function rules()
{
$id = $this->route('user'); //获取当前需要排除的id,这里的 user 是 路由 {} 中的参数
return [
'userName' => "required|unique:users,userName,".$id,
];
}
<?php
namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
use Auth;
class UserRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'name'=>'required|between:3,25|regex:/^[A-Za-z0-9\-\_]+$/|unique:users,name',
'email' => 'required|email',
'introduction' => 'max:80',
];
}
public function messages()
{
return [
'name.unique' => '用户名已被占用,请重新填写',
'name.regex' => '用户名只支持英文、数字、横杆和下划线。',
'name.between' => '用户名必须介于 3 - 25 个字符之间。',
'name.required' => '用户名不能为空。',
];
}
}
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models\User;
use App\Http\Requests\UserRequest;
class UsersController extends Controller
{
public function show(User $user)
{
return view('users.show', compact('user'));
}
public function edit(User $user)
{
return view('users.edit', compact('user'));
}
public function update(UserRequest $request, User $user)
{
$user->update($request->all());
return redirect()->route('users.show', $user->id)->with('success', '个人资料更新成功!');
}
}
@Torankusu 那我大概知道了,你的store
方法估计也是用了UserRequest
,所以创建和更新的时候用了同样的验证规则,所以你在要UserRequest
里面区分是创建还是更新,一般可以通过提交的方法来判断,比如POST方法是创建,PUT方法是更新,通过方法来分配不同的验证规则
栗子?:
public function rules()
{
switch ($this->method()) {
case 'POST':
return [
'name' => 'required|between:3,25|regex:/^[A-Za-z0-9\-\_]+$/|unique:users,name',
'email' => 'required|email',
'introduction' => 'max:80',
];
break;
case 'PUT':
return [
'name' => ['required', 'between:3,25', 'regex:/^[A-Za-z0-9\-\_]+$/', Rule::unique('users')->ignore($this->route('user'))],
'email' => 'required|email',
'introduction' => 'max:80',
];
break;
default:
return [];
}
}
message
方法也同理,通过方法返回不同的提示消息就可以了
教程提没提我不太清楚,因为我没看过,你之前的代码有没有问题我也不知道,因为我也没看过。至于不同方法的验证规则,这个其实有很多方法可以去实现,比如你可以通过判断路由,通过判断参数等等各种方式,这里很灵活,没有什么局限,只要rules方法返回一个规则数组就可以了,至于你是怎么决定这个规则,就要看你自己怎么设计了。
我的这个方法也是参考社区的《laravel项目规范》,你可以看一下,希望你会有其他收获
@Torankusu unique:users,name,'.Auth::id()
注意用户名验证部分这里的代码 因为你漏写了后面的.Auth::id()
所以出错了 Auth::id()
代表了检查重复时要忽略数据库哪条数据
推荐文章: