繁体   English   中英

在 Laravel 验证器中使用之前如何清除 jasny 输入掩码?

[英]How to clear jasny input mask before using in Laravel validator?

我有一个表单字段来获取用户的手机号码:

<input class="form-control" name="mobile" data-mask="0999 999 9999" type="text" id="mobile" />

我使用jasny 输入掩码来引导用户输入数据,但我需要将手机号码以999999999格式保存到数据库中(不含 0 和空格)。

当我使用 ajax 通过 serialize() 函数将数据发送到服务器时,我不想使用客户端脚本来更改输入的值(我有很多这样的表单字段),除非通过更改或向 jasny 输入掩码添加函数或方法用于所有这些领域!

我得到了服务器端输入的值,我想将它分配给 Laravel 5 中的模型属性,因此在用户模型中我声明了一个访问器和一个增变器来设置和获取手机号码:

public function setMobileAttribute($value){
    $value = substr(str_replace(" ","",$value),1);
    $this->attributes['mobile'] = $value;
}

public function getMobileAttribute($value){
    return '0'.substr($value,0,3).' '.substr($value,3,3).' '.substr($value,6,4);
}

它工作得很好,但是当我想使用 Laravel 验证来表明它是一个独特的字段时,它不起作用。 代码和平是这样的:

class UserController extends Controller {

    protected $rules = ['mobile' => 'required|unique:users'];
    public function store(Request $request){
        $validator = Validator::make($request->all(), $this->rules);
        if ($validator->fails()){
            return response()->json([
                'success' => false,
                'errors' => $validator->getMessageBag()->toArray()
            ]);
        }
        // codes to store user...
    }
}

它导致错误: SQLSTATE[23000]:完整性约束违规:1062重复条目

我找到了一种不完美但很好的方法。 我将此函数添加到我的 UserController 类中:

private function sanitize(Request $request){
    $input = $request->all();
    $input['mobile'] = substr(str_replace(" ","",$input['mobile']),1);
    $request->replace($input);
    return $request->all();
}

并像这样使用 Laravel 验证器:

$validator = Validator::make($this->sanitize($request), $this->rules);

我遇到了同样的问题,所以我已经解决了,这是我的代码:

$mobile = str_replace(['(', ')', ' ', '-'], ['', '', '', ''], $request->post('mobile'));
$request->merge(array('mobile' => $mobile));

    $request->validate([
        'name' => ['required', 'string', 'max:255'],
        'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
        'password' => ['required', 'max:50', 'min:8'],
        'phone' => ['required', 'unique:users']
    ]);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM