今天在搞验证这块时,遇到个问题:服务器端的验证和前端的验证表面上不能共存的问题,直接贴代码
这是前端jquery.validate验证
$("#form-member-add").validate({ rules:{ username:{ required:true, minlength:2, maxlength:16 }, realname:{ required:true, }, password: { required: true, minlength: 5 }, password_confirmation: { required: true, equalTo: "#password" }, sex:{ required:true, }, phone:{ required:true, isMobile:true, }, email:{ required:true, email:true, }, }, messages:{ username:{ required:'用户名都不写,想干啥?', minlength: "用户名至少由两个字母组成", maxlength: "写那么多记得住吗?最多16位" }, realname:{ required:'填姓名 啊', }, password:{ required:'密码都不写,想干啥?', minlength: "密码至少由五个字母组成", }, password_confirmation: { required: '必填的', equalTo: "两次密码不一致" }, sex:{ required:'必填', }, phone:{ required:'必填', isMobile:'请输入正确的电话格式', }, email:{ required:'必填', email:'请输入正确的邮箱格式', }, }, onkeyup:false, focusCleanup:true, success:"valid", submitHandler:function(form){ var index = parent.layer.getFrameIndex(window.name); $(form).ajaxSubmit( { success: function (data) { if (data.status === 10001) { parent.$('.btn-refresh').click(); parent.layer.close(index); console.log(data); } }, error: function (data) { alert('添加失败'); console.log(data); // parent.$('.btn-refresh').click(); // parent.layer.close(index); } } ); } });
这是后端laravel的代码及验证
$data1=$this->validate($request,[ 'username'=>'required|unique:users,username', 'realname'=>'required', 'password'=>'required|confirmed', 'email'=>'required', 'phone'=>'phone' ]); $data= $request->except(['_token','password_confirmation']); User::create($data); return response()->json(['data'=>$data1,'status'=>10001]);
当表单提交时,首先会触发前端的验证,前端验证通过后,进行后端验证,疑惑的地方是:前端验证成功,后端基本没啥情况,但username有个重名验证,即唯一验证,比如数据库已经有了username=admin,此时再插入username=admin时,前端验证是通过的,可后端的不会通过,它不通过它也不会将错误信息打印到页面中(我单独验证了前端验证及后端验证,即注释前端,测试后端,或者注释后端,测试前端,都没问题,但他两同时开启时,后端验证的错误信息就不打印到前端页面上了)
如图,只开启后端验证:
重名验证:
注释后端代码,开启前端验证:
这是为什么呢?
我尝试了接收validate的返回值,进行打印,是个对象,对象中有错误信息
如图:
在responseText中的就是错误信息,
The given data was invalid.
给定的数据无效。
到这里,就卡死了,求救大佬!!!
我该如何让它在前端验证通过的时候后端不通过的时候把后端的错误信息打印出来??
时ajax的原因吗?是的话如何解决呢?