نگار
2 سال پیش توسط نگار مطرح شد
3 پاسخ

اجرای دوباره کوئری

سلام
من یه فرم ثبتنام دارم که با vuejs نوشته شده ( چندان به vuejs وارد نیستم)، که گاهی خطای ایمیل تکراری mysql توی لاگ لاراول ثبت میکنه در صورتی که حتی اگر دوبار درخواست ارسال بشه هم نباید خطا بده. من validate دارم توی تابع ثبتنام.
ساعتی که یوزر اضافه شده تنها یه ثانیه با ساعت خطا تفاوت داره.

<script>

export default {
    data() {
        return {
            errors: [],
            form: {},
            showPassword: false,
            disabledValidating: false,
        }
    },

    mounted() {
    },

    methods: {
        register() {
            this.errors = []
            axios
                .post('/register', this.form)
                .then(response => {
                    Swal.fire({
                        icon: 'success',
                        title: 'ثبت‌نام شما با موفقیت انجام شد.',
                        showConfirmButton: false,
                        showClass: {
                            popup: 'animate__animated animate__fadeInDown'
                        },
                        hideClass: {
                            popup: 'animate__animated animate__fadeOutUp'
                        },
                        timer: 2000,
                    }).then((result) => {
                        window.location.replace('/verify-username')
                    })
                })
                .catch(error => {
                    if (error.response.status === 422)
                        this.errors = error.response.data.errors
                    else {
                        Swal.fire({
                            icon: 'warning',
                            text: 'سیستم با اختلال مواجه شد. دوباره امتحان کنید.',
                            showConfirmButton: false,
                            showClass: {
                                popup: 'animate__animated animate__fadeInDown'
                            },
                            hideClass: {
                                popup: 'animate__animated animate__fadeOutUp'
                            },
                            timer: 2000,
                        }).then((result) => {
                            window.location.reload();
                        })
                    }
                });
        }
    }
}
</script>

<template>
    <div class="row justify-content-center">
        <div class="col-md-9 col-lg-7">
            <div class="card">
                <div class="card-header d-flex justify-content-between">
                    <h5> ایجاد حساب کاربری</h5>
                    <div><small>قبلاً ثبت‌نام کرده‌ام! <a href="/login">ورود به حساب کاربری </a></small></div>
                </div>
                <div class="card-body px-md-5">
                    <div class="form-group">
                        <div class="form-row">
                            <div class="form-group col-md-6 col-sm-12">
                                <label for="name" class="col-form-label text-md-right">نام با حروف فارسی</label>
                                <input id="name" type="text" class="form-control" name="name" required v-model="form.name"
                                    :class="errors.name ? 'is-invalid' : ''" autofocus autocomplete="name">

                                <div v-if="errors.name">
                                    <ul class="mt-3 list-disc list-inside text-sm text-danger">
                                        <li style="font-size: 14px;">{{ errors.name[0] }}</li>
                                    </ul>
                                </div>
                            </div>

                            <div class="form-group col-md-6 col-sm-12">
                                <label for="last_name" class="col-form-label text-md-right">نام‌خانوادگی با حروف فارسی</label>

                                <input id="last_name" type="text" class="form-control" name="last_name" required
                                    v-model="form.last_name" :class="errors.last_name ? 'is-invalid' : ''" autofocus autocomplete="last_name">

                                <div v-if="errors.last_name">
                                    <ul class="mt-3 list-disc list-inside text-sm text-danger">
                                        <li style="font-size: 14px;">{{ errors.last_name[0] }}</li>
                                    </ul>
                                </div>
                            </div>
                        </div>

                        <div class="form-row">
                            <div class="form-group col-md-6 col-sm-12">
                                <label for="email" class="col-form-label text-md-right">آدرس ایمیل</label>
                                <input id="email" type="text" dir="ltr" class="form-control" name="email" required
                                    v-model="form.email" :class="errors.email ? 'is-invalid' : ''" autofocus autocomplete="email">

                                <div v-if="errors.email">
                                    <ul class="mt-3 list-disc list-inside text-sm text-danger">
                                        <li style="font-size: 14px;">{{ errors.email[0] }}</li>
                                    </ul>
                                </div>
                            </div>

                            <div class="form-group col-md-6 col-sm-12">
                                <label for="phone" class="col-form-label text-md-right">شماره موبایل</label>
                                <input id="phone" type="text" dir="ltr" class="form-control" name="phone" required v-model="form.phone"
                                    :class="errors.phone ? 'is-invalid' : ''" autofocus autocomplete="phone" placeholder="09...">

                                <div v-if="errors.phone">
                                    <ul class="mt-3 list-disc list-inside text-sm text-danger">
                                        <li style="font-size: 14px;">{{ errors.phone[0] }}</li>
                                    </ul>
                                </div>
                            </div>
                        </div>

                        <div class="form-row">
                            <div class="form-group col-md-6 col-sm-12">
                                <label for="password" class="col-form-label text-md-right">رمز عبور</label>
                                <span class="mx-1" @click="showPassword = !showPassword" role="button">
                                    <i class="text-primary" :class="showPassword ? 'fa fa-eye' : 'fa fa-eye-slash'"></i>
                                </span>

                                <input id="password" dir="ltr" :type="showPassword ? 'text' : 'password'"
                                    class="form-control" name="password" required v-model="form.password"
                                    :class="errors.password ? 'is-invalid' : ''" autocomplete="new-password" />

                            </div>

                            <div class="form-group col-md-6 col-sm-12">
                                <label for="password-confirm" class="col-form-label text-md-right">تکرار رمز عبور</label>

                                <input id="password-confirm" dir="ltr" :type="showPassword ? 'text' : 'password'"
                                    class="form-control" v-model="form.password_confirmation" name="password_confirmation"
                                    required autocomplete="new-password">
                            </div>

                            <small>
                                رمز عبور باید حداقل 8 کاراکتر و به زبان انگلیسی و تنها شامل حروف، اعداد و علائم نگارشی @$!%*#?& باشد.
                            </small>
                            <div v-if="errors.password">
                                <ul class="mt-3 list-disc list-inside text-sm text-danger">
                                    <li style="font-size: 14px;">{{ errors.password[0] }}</li>
                                </ul>
                            </div>
                        </div>

                    </div>

                    <div class="form-row mt-2">
                        <button class="btn btn-primary btn-block" @click="register">تأیید</button>
                    </div>
               </div>
                <div class="card-footer">
                    <div class="row justify-content-center">
                        <div>
                            <span class="small">ثبت‌نام از طریق حساب کاربری گوگل</span>
                            <div class="d-flex justify-content-center mt-2">
                                <a title="Google" class="border rounded px-4 py-2" href="/auth/google/redirect">
                                    <img class="d-block" height="24" src="/logos/google.svg">
                                </a>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</template>
    public function store(Request $request)
    {
        $request->validate([
            'name' => ['required', 'string', 'min:2', 'max:50', 'persian_alpha', 'not_regex:/[\x{6F0}-\x{6F9}]+/u'],
            'last_name' => ['required', 'string', 'min:2', 'max:50', 'persian_alpha', 'not_regex:/[\x{6F0}-\x{6F9}]+/u'],
            'password' => ['required', 'regex:/^[a-zA-Z0-9@$!%*#?&]{8,}$/', 'confirmed'],
            'email' => ['required','string','email','max:191','unique:users'],
            'phone' => ['required','regex:/^(09){1}[0-9]{9}+$/', 'unique:users'],
        ]);

        $user = User::create([
            'name' => $request->name,
            'last_name' => $request->last_name,
            'password' => Hash::make($request->password),
            'email' => $request->email,
            'phone' => $request->phone
        ]);

        $user->roles()->attach(3);

        Auth::login($user);

        return new JsonResponse([], 204);
    }
production.ERROR: SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry 'example@gmail.com' for key 'users_email_unique' (SQL: insert into `users` (`name`, `last_name`, `password`, `email`, `phone`, `updated_at`, `created_at`) values

چند تا کامپوننت دیگه vuejs هم همین مشکل رو دارم که فقط گاهی اتفاق میافتند.


ثبت پرسش جدید
حسین شیری نژاد
تخصص : programmer
@hosseinshirinegad98 2 سال پیش مطرح شد
0

سلام برنامتونوتست کردم هیچ مشکلی نداشت و به درستی کاربر ثبت میشد
تنها اروری که دریافت کردم وجود این persian_alpha کلمه بود که برنامم نمیشناختش
اجرای مجدد کوئری هم به هیچ عنوان من ندیدم
اعتبار سنجی هم به درستی کار کرد و مانع ثبت ایمیل تکراری شد


نگار
تخصص : توسعه دهنده بک اند
@Negaram 2 سال پیش مطرح شد
1

ممنون
منم توی لوکال ندیدم کوئری دوبار اجرا بشه. فقط رو سرور هست اونم گاهی. شاید از بیست تا ثبتنام یه دونش تکرار میشه. چند جای دیگه هم همین مشکل رو داره.
@hosseinshirinegad98


نگار
تخصص : توسعه دهنده بک اند
@Negaram 1 سال پیش آپدیت شد
1

متد register و دکمه تأیید رو به این صورت تغییر دادم مشکل حل شد.

        register() {
            this.errors = []
            this.disabledRegistering = true
            axios
                .post('/register', this.form)
                .then(response => {
                    Swal.fire({
                        icon: 'success',
                        title: 'ثبت‌نام شما با موفقیت انجام شد.',
                        showConfirmButton: false,
                        showClass: {
                            popup: 'animate__animated animate__fadeInDown'
                        },
                        hideClass: {
                            popup: 'animate__animated animate__fadeOutUp'
                        },
                        timer: 2000,
                    }).then((result) => {
                        window.location.replace('/verify-username')
                    })

                    this.disabledRegistering = false
                })
                .catch(error => {
                    if (error.response.status === 422)
                        this.errors = error.response.data.errors
                    else {
                        Swal.fire({
                            icon: 'warning',
                            text: 'سیستم با اختلال مواجه شد. دوباره امتحان کنید.',
                            showConfirmButton: false,
                            showClass: {
                                popup: 'animate__animated animate__fadeInDown'
                            },
                            hideClass: {
                                popup: 'animate__animated animate__fadeOutUp'
                            },
                            timer: 2000,
                        }).then((result) => {
                            window.location.reload();
                        })
                    }
                    this.disabledRegistering = false
                });
        }

         <div class="form-row mt-2">
              <button class="btn btn-primary btn-block" @click="register" :disabled="disabledRegistering">تأیید</button>
         </div>

باز اگر که دوستان راه حل بهتر یا توضیح مفیدتری دارند استقبال میکنم.😊


برای ارسال پاسخ لازم است وارد شده یا ثبت‌نام کنید

ورود یا ثبت‌نام