我正在尝试使用以下字段将数据插入数据库中 除了少数不是强制性的(许可证名称,许可证编号和 文件)。
signup.blade.php
var lic = [];
var licname = [];
var licnum = [];
var licfile = [];
$('#country1').select2();
$('#sign_up1').click(function () {
var lic_group = [];
fname = $("#fname1").val();
lname = $("#lname1").val();
country = $('#country1').select2('data').text;
company = $("#company1").val();
role = "legal";
designation1 = $("#designation1").val();
industry = $("#industry1").val();
dob = $("#dob1_input").val();
email = $("#email1").val();
password = $("#password1").val();
cnf_password = $("#cnf_password1").val();
practices = $("#practices").val();
var data = new FormData();
data.append("fname", fname);
data.append("lname", lname);
data.append("country", country);
data.append("company", company);
data.append("role", role);
data.append("designation", designation1);
data.append("industry", industry);
data.append("dob", dob);
data.append("email", email);
data.append("password", password);
data.append("practices", practices);
var i = 0;
$("[id^=main_lic_]").each(function () {
data.append('licname_' + i, $(this).find('.lic_name').val());
data.append('lic_no_' + i, $(this).find('.lic_no').val());
data.append('lic_file_' + i, $(this).find('.lic_file')[0].files[0]);
i++;
});
if (fname == "" || lname == "" || country == "" || company == "" || designation1 == "" || industry == "" || dob == "" || email == "" || password == "" || practices == "") {
show_notification("error", "Please enter all required fields");
} else {
if (password != cnf_password) {
show_notification("error", "Password and confirm password doesn't match");
}
else {
$.ajax({
url: "reg",
type: "POST",
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
},
data: data,
success: function (data) {
if (data.msg == "Register Successful") {
show_notification("success", "Registered Successfully");
setTimeout(function () {
window.location.href = "/";
}, 1000);
}
},
error: function (result) {
show_notification("error", data.responseJSON.message);
},
contentType: false,
processData: false
});
}
}
});
UserController.php
public function registerLawyer(Request $request)
{
$firstname = $request->get('fname');
$lastname = $request->get('lname');
$country = $request->get('country');
$company = $request->get('company');
$role = $request->get('role');
$desig = $request->get('designation');
$dob = $request->get('dob');
$email = $request->get('email');
$pass = $request->get('password');
$indus_sec = $request->get('industry');
$all_params = $request->keys();
$total_licenses = preg_grep("/^licname_.*/", $all_params);
if($role == 'legal' && ($request->get('licname_0') == null || $request->get('lic_no_0') == null || $request->file('lic_file_0') == null)){
abort(403, 'Institute License is mandatory');
}
$userWithExistingEmail = User::where('email', $email)->first();
if ($userWithExistingEmail) {
abort(403, 'Account already exists with this email');
}
if(!in_array($role, ['legal', 'client'])){
abort(403, 'Invalid role request');
}
$user = new User();
$user->email = $email;
$user->firstname = $firstname;
$user->lastname = $lastname;
$user->country = $country;
$user->company = $company;
$user->role = $role;
$user->designation = $desig;
$user->dob = Carbon::parse($dob)->toDateString();
$user->status = ($request->get('role') == 'legal') ? 0 : 1;
$user->password = bcrypt($pass);
$user->save();
/* foreach (explode(',', $request->get('industry')) as $userIndustry){
$uIndustry = new UserIndustry();
$uIndustry->user_id = $user->id;
$uIndustry->industrysector_id = $userIndustry;
$uIndustry->save();
}*/
if($role == 'legal'){
$lawyer = new Lawyer();
$lawyer->user_id = $user->id;
$lawyer->save();
for ($i = 0; $i < count($total_licenses); $i++) {
$filename = $request->file('lic_file_0' . $i)->store('licenses');
$licenseno1 = $request->get('licname_0' . $i);
$licenseName = $request->get('lic_no_0' . $i);
$license = new License();
if($filename != null && $licenseno1 != null && $licenseName != null){
$license->lawyer_id = $lawyer->id;
$license->file = $filename;
$license->institution = $licenseName;
$license->licenseno = $licenseno1;
$license->save();
}else{
$license->lawyer_id = $lawyer->id;
$license->save();
}
}
foreach(explode(',', $request->get('practices')) as $aop){
$uAop = new UserAOP();
$uAop->user_id = $user->id;
$uAop->aop_id = $aop;
$uAop->save();
}
}
return ['msg' => 'Register Successful'];
}
在这种情况下,我想将$ filename,$ licenseno1和$ licenseName保留为非强制性,这意味着用户可以将此字段保留为空白,我可以在不使该字段为空的情况下实现此目的吗?
答案 0 :(得分:1)
不,您不能在不允许null的情况下在数据库中存储null值。