<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های آرش مهرانی</title>
        <link>https://virgool.io/feed/@mehrani</link>
        <description></description>
        <language>fa</language>
        <pubDate>2026-04-14 18:35:02</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/178986/avatar/9zReA9.jpg?height=120&amp;width=120</url>
            <title>آرش مهرانی</title>
            <link>https://virgool.io/@mehrani</link>
        </image>

                    <item>
                <title>بررسی احراز هویت کاربران در فریم ورک لاراول 8</title>
                <link>https://virgool.io/laravel-community/laravel-manual-authentication-exa2j9gswbos</link>
                <description>مقدمه :همانطور که میدونید در نحوه اجرای احراز هویت کاربران &quot;Authentication&quot; در فریم ورک لاراول آقای تیلور اوتول و تیم لاراول هر چند وقت یکبار با یک سری پیکج جدید تغییرات اساسی اعمال می کنند! مثلا پکیج های قدیمی مثل لاراول UI  یا جدیدا جت استریم، فورتیفای، &quot;breeze&quot;. حالا درکنار این پکیج ها هم میان درخواست نصب پکیج های دیگه ای مثل Livewire یا inertia برای ارسال رگوئست های آژاکسی به سرور رو میدن و فریم ورک هایی مثل Tailwind css رو هم برای استایل دهی ویو هاشون رو میخوان که نصب بشه.این پکیج ها امکانات زیادی دارند مثلا همین جت استریم یه صفحه پروفایل کاربری کامل ایجاد میکنه از تایید دومرحله ای تا حتی تا تشخیص دستگاه های دیگه ای که باهاشون احراز هویت شدین رو بهتون تو پروفایل کاربری نشون میده تا اگه به سیستمی دیگه دسترسی ندارین یا رمز رو تغییر دادین تو سیستم خودتون لاگین بمونید و از سایر دیوایس ها خارج بشید، مثل همون امکاناتی که سایت های بزرگ مثلا گوگل و... دارن که از نظر من خیلی باحال و کاربردی هم هست که البته دستی هم میشه خودمون اضافه کنیم! درسته که بسیاری از امکانات رو به بهترین و حرفه ای ترین شکل ممکن به هسته فریم ورک اضافه می کنند اما من به شخصه ترجیح میدم متناسب نیازم سر هر پروژه لاراول رو شلوغ نکنم! مخصوصا اینکه بعضی وقت ها نیاز داریم کامل این بخش رو بازنویسی کنیم مثلا احراز هویت رو ببریم روی OTP ها و از ایمیل بریم روی شماره موبایل کاربر که در روشی که خدمتان عرض میکنم اعمال تغییرات توی سیستم احراز هویت واضح تر هست.لیست مطالبی که تو این مقاله گفته شده:ساخت پروژه جدید لاراول 8ساخت دستی بخش ثبت نامساخت دستی بخش ورودنحوه تشخیص کاربران مسدود شدهساخت بخش &quot;مرا به خاطر بسپار&quot; هنگام ورودسیستم ارسال تایید ایمیل کاربرسیستم بازیابی رمز عبورفارسی سازی پیغام ها و ایمیل هاایجاد پروژه جدید:توی قدم اول اگه installer لاراول در کامپوزر رو هنوز نصب نکردید با وارد کردن دستور زیر در خط فرمان می تونید نصبش کنید:composer global require laravel/installerو بعد از پایان نصب این اینستالر تنها کافیه با دستور زیر یک پروژه جدید لاراول رو ایجاد کنیم که به جای &quot;your_app_name&quot; باید اسم پروژه خودتون رو بنویسید:laravel new your_app_nameدر فایل env موجود در پروژه، اطلاعات پایگاه داده خودتون رو وارد کنید تا به دیتابیس متصل بشیم و الان دیگه همه چیز آماده است همانطور که می بینید مایگریشن جدول کاربران یا همون Users هم آماده اجرا کردنه که کافیه با کد زیر مایگریشن ها رو اجرا کنید:php artisan migrateاگر خطا گرفتید که حتما میگیرید :) باید کد زیر رو برای تعیین مقدار پیشفرض رشته ها در AppServiceProvider.php و در فانکشن boot وارد کنیم: Schema::defaultStringLength(191);و همچنین بالای این پرونده، Facade زیر رو هم فراموش نکنید use کنید:use Illuminate\Support\Facades\Schema;خب حالا دوباره عمل مایگریت رو انجام بدید تا بریم سراغ ادامه کار.ساخت کنترلر هاتا اینجا همش درباره راه اندازی لاراول بود اصل کار ما تازه شروع میشه. اول باید کنترلر های مورد نیازمون رو بسازیم که من عموما در پوشه Controllers\Auth سه تا کنترلر برای بخش احراز هویت می سازم یکی به اسم authController که جنبه عمومی داره و کد های مربوط به نمایش ویو ها و خروج از حساب رو توش می نویسم و دوتا کنترلر دیگه به اسم های loginController و  registerController که از اسم هاشون مشخصه برای عملیات ورود و ثبت نام از اینها استفاده میکنم که خب شما میتونید کلا از یکی فقط استفاده کنید ولی پیشنهاد میدم آینده نگر باشید و همه چیز رو دسته بندی کنید تا وقتی پروژه بزرگ شد توی کد های خودتون گم نشید! با دستورات زیر هر سه کنترلر رو به ترتیب میسازیمphp artisan make:controller Auth\authController php artisan make:controller Auth\loginControllerphp artisan make:controller Auth\registerController روت ها حالا وقتشه روت ها و ویو های مربوط به عمل احراز هویت رو بسازیم مثل login و register و logout همچنین ساخت بخش ویو ها رو فاکتور میگیرم که خارج از بحث ماست! اما برای روت ها، بالای صفحه باید کنترلر هامون رو use کنیم و روت ها رو با توجه به کنترلر و فانکشن های مربوط به خودشون تعریف کنیم:&lt;?php
use Illuminate\Support\Facades\Route;

use App\Http\Controllers\Auth\authController;
use App\Http\Controllers\Auth\loginController;
use App\Http\Controllers\Auth\registerController;

Route::get(&#039;/&#039;, [authController::class, &#039;loginView&#039;])-&gt;name(&#039;index&#039;); //روت نمایش صفحه اصلی که ارجاع دادم به صفحه ورود
Route::get(&#039;/login&#039;, [authController::class, &#039;loginView&#039;])-&gt;name(&#039;login&#039;); //روت نمایش ویو صفحه ورود
Route::get(&#039;/register&#039;, [authController::class, &#039;registerView&#039;])-&gt;name(&#039;register&#039;); //روت نمایش ویو صفحه ثبت نام
Route::get(&#039;/logout&#039;, [authController::class, &#039;logout&#039;])-&gt;name(&#039;logout&#039;); //روت خروج از حساب
Route::post(&#039;/login&#039;, [loginController::class, &#039;login&#039;]); //روت پست اطلاعات فرم ورود
Route::post(&#039;/register&#039;, [registerController::class, &#039;register&#039;]); //روت پست اطلاعات فرم ثبت نام
Route::prefix(&#039;dashboard&#039;)-&gt;middleware([&#039;auth&#039;])-&gt;group(function () { //گروه روت های داشبورد که با میدلور خود لاراول جلوی ورود کاربر وارد نشده رو گرفتم
    Route::get(&#039;/&#039;, function () {
    });
});کنار هر خط کد بالا کامنت گذاشتم که ابهامی نمونه بعد از تعریف روت ها کافیه در کنترلر های مربوطه و فانکشن مورد نظر روت هامون، کد های خودمون رو بنویسیم. ثبت نام کاربر جدیدبرای ثبت نام کاربر جدید کار بسیار ساده هست تنها کافیه از الکوئنت کمک بگیریم و یک رکورد جدید در دیتابیس ثبت کنیم که میشه همون کاربرمون، پس در کنترلر registerController و در فانکش register اش که داده هامون از ویو بهش post شده است رو میگیرم و بعد از اعتبار سنجی به پایگاه داده اضافه می کنیم:public function register(Request $request) //رگوئست ارسالی کاربر از صفحه ثبت نام رو دریافت می کنیم
{
    $validated = $request-&gt;validate([ //داده ها را اعتبار سنجی می کنیم
        &#039;email&#039; =&gt; &#039;required|email|unique:users|max:255&#039;,
        &#039;password&#039; =&gt; &#039;required|max:255|min:6&#039;,
    ]);
    $user = new User(); //یک شی جدید از روی مدل یوزر میسازیم
    $user-&gt;password = Hash::make($request-&gt;password); //پسورد را ابتدا با روش بی کریپت هش میکنیم
    $user-&gt;email = $request-&gt;email; //ایمیل ارسالی را دریافت می کنیم
    $user-&gt;save(); //اطلاعات را پایگاه داده ثبت می کنیم
    return redirect()-&gt;intended(&#039;index&#039;); //کاربر را به صفحه مورد نظر هدایت میکنیم
}کنار تمام کد های بالا هم کامنت گذاشتم که ابهامی نباشه. تا اینجا تونستیم یک کاربر جدید رو ثبت کنیم البته آخرش هم میتونیم یک سشن برای پیغام ثبت نام موفقیت آمیز یا حتی عملیات ارسال ایمیل تایید به کاربر رو انجام بدیم.احراز هویت و ورود به سیستمبرای بخش اصلی کار یعنی احراز هویت و ورود به سیستم بعد از اینکه کاربران توی بخش ویو اطلاعاتشون مثل ایمیل و پسورد رو وارد کردن و داده ها به کنترلر پست شد طبق روال بالا در کنترلر loginController و فانکشن login کد های زیر رو وارد می کنیم :use Illuminate\Support\Facades\Auth; //یوز کردن فساد احراز هویت رو بالای پرونده فراموش نکنید 

public function login(Request $request) //دریافت رگوئست ارسالی کاربر در صفحه ورود
{
    $validated = $request-&gt;validate([ //داده ها رو اعتبار سنجی میکنیم
        &#039;email&#039; =&gt; &#039;required|email&#039;,
        &#039;password&#039; =&gt; &#039;required&#039;,
    ]);
    $credentials = $request-&gt;only(&#039;email&#039;, &#039;password&#039;); //فیلد های مورد نظر رو داخل متغیر میریزیم
    if (Auth::attempt($credentials)) { //اگر کاربری با مشخصات داده شده موجود باشد نتیجه صحیح باز میگردد
        $request-&gt;session()-&gt;regenerate(); //سشن را بازسازی می کنیم
        return redirect()-&gt;intended(&#039;dashboard&#039;); //کاربر احراز هویت شده را با داشبورد منتقل می کنیم
    }
return back()-&gt;withErrors([ //کاربر پیدا نشد و هنگام بازگشت به صفحه ورود خطا را نشان میدهیم
            &#039;email&#039; =&gt; &#039;کاربری با این مشخصات وجود ندارد&#039;,
        ]);
}
کنار کدهای بالا هم کامنت گذاشتم اما لازمه یه توضیح مختصر برای بعضی از دستورات بدم. اول دستور زیر که در کد بالا کار اصلی رو انجام میده :$credentials = $request-&gt;only(&#039;email&#039;, &#039;password&#039;);اینجا دوتا ورودی از ما گرفته، اول ایمیل کاربر که در بعضی موارد، ما میتونیم بجای ایمیل از نام کاربری یا موبایل برای احراز هویت کاربران استفاده کنیم، و دوم پسورد کاربر! بجای این دستور میتونیم از همان متغیر ولیدیشن validated که بالا نوشتیم استفاده کنیم اما به این دلیل که این دستور قابل توسعه است و میتونه ورودی های بیشتری بگیره که در ادامه مقاله خواهم گفت اینکار رو کردیم که قاطی نشه.نکته مهم:پسورد توی دستور بالا خودش هش و ارسال میشه پس نباید شما خودتون دستی اون رو هش کنید و بعد ارسال کنید. اگه اینکار رو بکنید پسورد هش شده دوباره هش میشه و کلا یه رشته دیگه تحویل میده که طبیعتا با پسورد ذخیره شده در دیتابیس متفاوت خواهد بود و هیچ کاربری نمیتونه دیگه لاگین کنه :)مورد بعدی دستور زیره که کوئری اصلی رو برای دیتابیس میسازه و نتیجه احراز هویت رو برمیگردونه :Auth::attempt($credentials)کد بالا هم یک ورودی گرفته که داخل اون متغیری با دو پارامتر ایمیل و پسورد کاربر که قبلا به صورت آرایه توش ریخته بودیم رو برای ساخت کوئری ارسال میکنه. اگه کاربری با این رمز و ایمیل پیدا بشه خروجی این دستور True هست که ما ازش استفاده کردیم برای تکمیل احراز هویت کاربرمون.بعد از اینکه کاربر اطلاعاتش درست بود اولین دستوری که بعد از عملیات احراز نوشتیم دستور زیر بود :$request-&gt;session()-&gt;regenerate();این دستور میاد و یک سشن آی دی جدید برای کاربرمون میسازه تا از خطر Session fixation جلوگیری بشه!البته توی دستورات بخش ورود به سایت ما میتونیم بجای دستور زیر که بالا نوشته بودیم:$credentials = $request-&gt;only(&#039;email&#039;, &#039;password&#039;);یکباره از همون دستورات مربوط به validate رگوئست ارسالی هم استفاده کنیم مثلا :$credentials = $request-&gt;validate([
            &#039;email&#039; =&gt; [&#039;required&#039;, &#039;email&#039;],
            &#039;password&#039; =&gt; [&#039;required&#039;],
        ]);که از همون اول ایمیل و پسورد رو داخل متغیر credentials گذاشتیم و بعد هم که در بخش Auth::attempt میره برای چک شدن اطلاعات، اما من پیشنهاد نمیدم چون با روش قبلی که نوشته بودیم همانطور که در ادامه توضیح میدم امکانات جالبی در انتظارمونه.اگر بخواییم بجز ایمیل و پسورد موارد دیگری رو هم بررسی کنیم چی؟یه نکته جالب اینجا هست که مثلا شاید جدول کاربران شما بخوایید شامل یه فیلد باشه برای امکان مسدود کردن یک کاربر و شما نخوایید کاربر مسدود شده حتی با صحیح بودن رمز و ایمیل هم بتونه به سایت ورود کنه! اینجا میتونیم بجای این دستور زیر که بالا توی کد اصلیمون استفاده کرده بودیم:$credentials = $request-&gt;only(&#039;email&#039;, &#039;password&#039;); از این دستور زیر توی همون بخش Auth::attempt استفاده کنیم :if (Auth::attempt([&#039;email&#039; =&gt; $email, &#039;password&#039; =&gt; $password, &#039;active&#039; =&gt; 1])) {
    // کاربر احراز هویت شده و ادامه دستورات
}که همانطوری که میبینید در یک آرایه ابتدا ایمیل و بعد پسورد و در آخر گزینه active رو قرار دادیم که اگه کاربرمون فعال بود و ستون active این کاربر برابر True یا 1 بود عملیات ورود انجام بشه یا به اصطلاح کاربرمون احراز هویتش کامل بشه. که اینجا active مثاله شما میتونید هرچیزی که لازم دارید رو بزارید.چطوری بخش &quot;مرا به خاطر بسپار&quot; رو ایجاد کنیم؟حتما توی خیلی از سایت ها این قابلیت رو دیدید و همچنین پکیج های احراز هویت خود لاراول هم این امکان رو راه اندازی می کنن! مثلا زمانی که کاربر تیک گزینه &quot;مرا به خاطر بسپار&quot; رو زده بود، تا وقتی که دکمه خروج رو نزده روی سیستم لاگین بمونه. برای اینکار اول لازمه که فیلد remember_token رو از جدول پیشفرض کاربران دیتابیس که با مایگریشن ها ایجاد شده رو حذف نکرده باشید. و بعد تنها کافیه در صورت نیاز به بخاطر سپرده شدن مقدار True رو به آرگومان دوم متد attempt پاس بدیم، مثل دستور زیر:if (Auth::attempt([&#039;email&#039; =&gt; $email, &#039;password&#039; =&gt; $password], $remember)) {
    // کاربر احراز هویت شده و تا خروج رو نزده باشد در این حالت می ماند
}همانطور که در کد بالا مشخص هست در آرگومان دوم از متغیر remember استفاده کردم که در صورت True بودن مقدار این متغیر کاربر تا زدن دکمه خروج در این سیستم لاگین می ماند.خروج کاربر از سیستموقتی بخواییم کاربر از سیستم خارج بشه یا به اصطلاح عمل logout انجا بشه کافیه در کنترلر و فانکشن مربوط به روت logout خودمون از دستور زیر برای خروج از حساب کاربری استفاده کنیم :use Illuminate\Support\Facades\Auth; //یوز کردن فساد احراز رو فراموش نکنید

public function logout(Request $request)
{
    Auth::logout(); //باطل کردن احراز هویت فعلی

    $request-&gt;session()-&gt;invalidate(); //نامعتبر سازی سشن های فعلی

    $request-&gt;session()-&gt;regenerateToken(); //تولید مجدد توکن

    return redirect(&#039;/&#039;); //ریدایرکت کاربر به صفحه اصلی
}همانطوری که توی کامنت های کنار دستورات بالا مشخص کردم ابتدا با دستور Auth::logout احراز هویت فعلی کاربر رو باطل میکنیم که همین کار به تنهایی برای خروج کاربر از حساب کاربریش کافیه اما پیشنهاد میشه که حتما مطابق دستور خط بعدی سشن های فعلی رو نامعتبر کنیم و مجددا توکن رو برای امنیت بیشتر و جلوگیری از همزمانی ارسال دستورات مشابه، باز تولید کنیم.ارسال ایمیل تایید ثبت نامیکی از بخش های کاربردی هر سیستم احراز هویتی همین بخشه که بعد از ثبت نام کاربر جدید، یک ایمیل تایید برای کاربر ارسال بشه تا با کلیک روی لینک تایید آدرس ایمیلش تایید بشه و مطمئن بشیم کاربر ایمیل واقعی برای ثبت نام استفاده کرده و بات یا اسپم نیست.برای پیاده سازی این بخش اول باید یه سرویس ارسال کننده ایمیل برای پروژه تعریف کنیم. فعلا که تو مرحله توسعه هستیم من از میل ترپ برای سرویس ارسال کننده ایمیل هام استفاده می کنم شما بعدا میتونید از جیمیل یا سرور خودتون استفاده کنید. خب در ادامه تنظیماتش رو توی فایل env وارد میکنم، دریایی از آموزش برای این تنظیمات mailtrap در لاراول هست کاری هم نداره 30 ثانیه است :)اول باید مطمئن بشیم که کانترکت MustVerifyEmail در بالای مدل User فراخوانی شده باشه که پیشفرض هم همینطوره و البته MustVerifyEmail در کلاس کاربر مدلمون باید مطابق کد زیر implements هم بشه:use Illuminate\Contracts\Auth\MustVerifyEmail;

class User extends Authenticatable implements MustVerifyEmail
{
    use Notifiable;
    // ...
}بعد از اینکار باید برگردیم به کنترلری که دستورات ثبت کاربر جدید رو توش نوشته بودیم (برای ما اینجا registerController است) و اول بالای کنترلر ایونت زیر رو فراخوانی کنیم:use Illuminate\Auth\Events\Registered;و دقیقا بعد از ذخیره کاربر جدید در دیتابیس با استفاده از دستور زیر ارسال ایمیل تایید رو که در هسته لاراول از قبل آماده هست رو هم انجام بدیم:event(new Registered($user));حتما توجه داشته باشید که فیلد پیشفرض email_verified_at در جدول کاربران رو پاک نکرده باشید! اگه پاک کردید دوباره بسازید. این فیلد تاریخ تایید ایمیل توسط کاربر رو ذخیره میکنه و میشه کلید اصلی اینکه کاربر ایمیلش رو تایید کرده یا نه.برای ادامه کار ما به 3 روت دیگه نیاز داریم، اول برای اینکه صفحه ای داشته باشیم تا در صورت لاگین کاربری که تایید ایمیل انجام نداده بود بفرستیمش اونجا و بهش این قضیه تایید ایمیل رو اطلاع بدیم.دوم روتی هست که برای هندل رگوئست دکمه تایید ایمیلی که به کاربر ایمیل شده لازمش داریم.و سوم روتی برای ارسال مجدد ایمیل تایید به کاربر، برای مواقعی که به هر دلیلی ایمیل بهش نرسیده.با استفاده از میدلور verified روت هایی که کاربر برای دسترسی بهشون نیاز داره تا اول تایید ایمیل رو انجام بده مشخص میکنیم. و بعد روت اولی که بالا گفتم رو مطابق زیر ایجاد میکنیم:Route::get(&#039;/email/verify&#039;, function () {
    return view(&#039;auth.verify-email&#039;);
})-&gt;middleware(&#039;auth&#039;)-&gt;name(&#039;verification.notice&#039;);دوستان توجه داشته باشید که اسم این روت حتما باید verification.notice باشه و این از پیش تعریف شده در هسته لاراول است. حتما هم به این روت میدلور auth رو بدید تا کاربرای مهمان نتونن این صفحه رو ببینند. الان وقتی کاربری ثبت نام کرده باشه و قبل از تایید ایمیل لاگین کنه به کمک میدلور verified تشخیص داده میشه و به این روت بالا ریدایرکت میشه.روت دوم مربوط به بخشی است که قراره کاربر بعد از کلیک روی لینک تایید توی ایمیل خودش اون رو باز کنه. این بخش میاد و عمل تایید ایمیل رو برامون انجام میده:use Illuminate\Foundation\Auth\EmailVerificationRequest; //فراموش نکنید بالای صفحه باید این فایل رو فراخونی کنید

Route::get(&#039;/email/verify/{id}/{hash}&#039;, function (EmailVerificationRequest $request) {
    $request-&gt;fulfill();
    return redirect(&#039;/home&#039;); //صفحه ای که قراره بعد از تایید ایمیل بهش ریدایرکت بشه
})-&gt;middleware([&#039;auth&#039;, &#039;signed&#039;])-&gt;name(&#039;verification.verify&#039;);روت بالا اسمش verification.verify هست که این هم از پیش تعریف شده و نباید عوض بشه. دو میدلور auth و signed هم به این روت نسبت داده شده تا جلوی ریگوئست های فیک گرفته بشه.میرسیم به روت سوم که برای ارسال مجدد لینک تایید به ایمیل ازش استفاده میشه :use Illuminate\Http\Request;

Route::post(&#039;/email/verification-notification&#039;, function (Request $request) {
    $request-&gt;user()-&gt;sendEmailVerificationNotification();
    return back()-&gt;with(&#039;message&#039;, &#039;لینک تایید مجددا ارسال شد&#039;);
})-&gt;middleware([&#039;auth&#039;, &#039;throttle:6,1&#039;])-&gt;name(&#039;verification.send&#039;);همانطور که میبینید این روت از نوع post هست با اسم از پیش تعریف شده verification.send و میدلور auth براش ست شده تا کاربری که قراره ایمیل براش ارسال بشه مشخص باشه. همچنین اینجا از میدلور throttle استفاده شده که باهاش میشه مشخص کرد کاربر مثلا در هر دقیقه چندبار بتونه این درخواست رو ارسال کنه تا فشار روی سرور نیاد و ریگوئست اسپم به سرور ارسال نشه.بازیابی رمز عبورلاراول برای بخش بازیابی رمز عبور به این صورت عمل میکنه که ابتدا کاربر درخواست خودش رو با وارد کردن ایمیلی که باهاش ثبت نام کرده رو به سیستم میده و بعد یک ایمیل هاوی لینک مخصوص به خودش رو دریافت میکنه که باهاش میتونه رمز عبور جدید رو تنظیم کنه.برای اینکار ابتدا در بالای مدل User خودمون کانترکت و نوتفیکشن زیر باید use شده باشه :use Illuminate\Contracts\Auth\CanResetPassword;
use Illuminate\Notifications\Notifiable;بعد ما نیاز داریم که روتی برای نماش فرم درخواست رمز عبور مطابق کد زیر تعریف کنیم:Route::get(&#039;/forgot-password&#039;, function () {
    return view(&#039;auth.forgot-password&#039;);
})-&gt;middleware(&#039;guest&#039;)-&gt;name(&#039;password.request&#039;);در کد بالا تنها یه ویو به کاربر نشون میدیم که داخلش باید ایمیل email کاربر رو دریافت کنیم و به روت بعدی پست کنیم. همچنین از میدلور guest استفاده شده تا کاربرانی که لاگین هستن دیگه نتونن این صفحه رو ببینند. اسم روت هم که طبق روال از پیش تعیین شده.use Illuminate\Http\Request;
use Illuminate\Support\Facades\Password;

Route::post(&#039;/forgot-password&#039;, function (Request $request) {
    $request-&gt;validate([&#039;email&#039; =&gt; &#039;required|email&#039;]); //اعتبار سنجی ایمیل

    $status = Password::sendResetLink(
        $request-&gt;only(&#039;email&#039;)
    ); //پیدا کردن کاربری با ایمیل وارد شده و ارسال ایمیل بازیابی رمز

    return $status === Password::RESET_LINK_SENT //تنظیم سشن برای نمایش نتیجه درخواست
                ? back()-&gt;with([&#039;status&#039; =&gt; __($status)])
                : back()-&gt;withErrors([&#039;email&#039; =&gt; __($status)]);
})-&gt;middleware(&#039;guest&#039;)-&gt;name(&#039;password.email&#039;);همانطور که تو کامنت های دستورات بالا مشخص کردم وضعیت ارسال ایمیل توی سشن status ریخته میشه که میتونیم توی صفحه درخواست ایمیل بازیابی اون رو به کاربر نشون بدیم اون هم مربوط به ویو میشه ولی به هر حال مطابق کد های زیر میشه این کار رو تو ویو کرد:@if (Session::has(&#039;status&#039;)) //اگر همچین سشنی ست شده بود
    &lt;div class=&amp;quotalert alert-success&amp;quot role=&amp;quotalert&amp;quot&gt;
        {{ Session::get(&#039;status&#039;) }} //پیغامشو نمایش بده
    &lt;/div&gt;
@endifحالا دیگه باید ایمیل حاوی لینک بازیابی رمز هم برای کاربر فرستاده شده باشه و در ویو هم پیغام ارسال موفقیت آمیز ایمیل رو ببینه. حالا باید بریم سراغ روتی که کاربر بعد از کلیک روی لینک ایمیل شده بهش، واردش میشه:Route::get(&#039;/reset-password/{token}&#039;, function ($token) {
    return view(&#039;auth.reset-password&#039;, [&#039;token&#039; =&gt; $token]);
})-&gt;middleware(&#039;guest&#039;)-&gt;name(&#039;password.reset&#039;);همانطوری که در کدهای بالا میبینید روت ما توکن ارسال شده رو دریافت میکنه و داخل متغیر token میریزه بعد یه ویو به کاربر نشون میدیم که توکن دریافتی هم بهش ارسال میشه. توی این ویو ما یک فرمی خواهیم داشت با یک input مخفی که value اش میشه مقدار token و یک فیلد برای ایمیل کاربر &quot;email&quot; و فیلد های رمز عبور جدید &quot;password&quot; و تکرار رمز عبور جدید &quot;password_confirmation&quot; که این داده ها پست میشن به روت بعدی تا رمز عبور عوض بشه:use Illuminate\Auth\Events\PasswordReset;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Password;
use Illuminate\Support\Str;

Route::post(&#039;/reset-password&#039;, function (Request $request) {
    $request-&gt;validate([ //اهتبار سنجی داده ها
        &#039;token&#039; =&gt; &#039;required&#039;,
        &#039;email&#039; =&gt; &#039;required|email&#039;,
        &#039;password&#039; =&gt; &#039;required|min:8|confirmed&#039;,
    ]);
    $status = Password::reset( //ساخت کوئری و واکشی کاربر مورد نظر
        $request-&gt;only(&#039;email&#039;, &#039;password&#039;, &#039;password_confirmation&#039;, &#039;token&#039;),
        function ($user, $password) {
            $user-&gt;forceFill([
                &#039;password&#039; =&gt; Hash::make($password) //تغییر رمز عبور
            ])-&gt;setRememberToken(Str::random(60)); //تغییر توکن کاربر

            $user-&gt;save(); //ذخیره کاربر

            event(new PasswordReset($user));
        }
    );

    return $status === Password::PASSWORD_RESET //تنظیم سشن برای نمایش وضعیت درخواست
                ? redirect()-&gt;route(&#039;login&#039;)-&gt;with(&#039;status&#039;, __($status))
                : back()-&gt;withErrors([&#039;email&#039; =&gt; [__($status)]]);
})-&gt;middleware(&#039;guest&#039;)-&gt;name(&#039;password.update&#039;);خب دوستان اینم از بخش بازیابی رمز عبور که تا اینجا کامل امکانات مورد نیاز احراز هویت کاربران توی لاراول رو پیاده سازی کردیم :)فارسی سازی پیغام هاپیغام های اعتبار سنجی لاراول به صورت پیش فرض انگلیسی هستند، همچنین ایمیل تایید ای که ما در بالا برای کاربر فرستادیم هم به صورت انگلیسی ارسال میشه. اگر میخواید این پیغام ها فارسی بشن می تونید در صفحه گیت هاب من پکیجی که برای این کار آماده شده رو دانلود و پیغام های لاراول رو فارسی کنید. توضیحات پکیج هم همونجا داده شده.آدرس پروژه در گیت هاب: https://github.com/arashmehrani/laravel-persian-langخب دوستان، تونستیم بدون استفاده از پکیج های جانبی و به صورت دستی بخش های ثبت نام، ورود و خروج رو با استاندارد های خود هسته لاراول پیاده سازی کنیم. امیدوارم از این مقاله استفاده لازم رو برده باشید.</description>
                <category>آرش مهرانی</category>
                <author>آرش مهرانی</author>
                <pubDate>Fri, 22 Oct 2021 01:49:15 +0330</pubDate>
            </item>
                    <item>
                <title>تاثیر ورژن کنترل Git در زندگی کاری برنامه نویس ها</title>
                <link>https://virgool.io/cheyab-blog/%DA%86%D8%B7%D9%88%D8%B1%DB%8C-git-%D9%85%DB%8C%D8%AA%D9%88%D9%86%D9%87-%D8%B2%D9%86%D8%AF%DA%AF%DB%8C-%DA%A9%D8%A7%D8%B1%DB%8C-%D8%A8%D8%B1%D9%86%D8%A7%D9%85%D9%87-%D9%86%D9%88%DB%8C%D8%B3-%D9%87%D8%A7-%D8%B1%D9%88-%D9%84%D8%B0%D8%AA-%D8%A8%D8%AE%D8%B4-%D8%AA%D8%B1-%DA%A9%D9%86%D9%87-ov5iqmjjfrkn</link>
                <description>گیت &quot;GIT&quot; چیستبا جستجوی عبارت &quot;گیت چیست&quot; تعداد زیادی مقاله فارسی و انگلیسی درباره اینکه گیت چیه و چیکار میکنه به شما نشان داده خواهد شد. که البته خیلی کامل تر از این یک پاراگرافی که من برای عبارت (گیت چیست) در نظر گرفتم. اما هدف من توی این مقاله توضیح کامل دستورات و آرگومان های گیت نیست، الان خیلی ساده میخوایم ببینیم چطوری میتونیم باهاش کارمون رو راحتتر کنیم بدون اینکه درگیر همه جزئیاتش بشیم. ولی کلی بگم که وجود ورژن کنترل گیت توی دنیای برنامه نویسی مثل صنعتی شدن پلاستیک توی سال 1930 میلادیه، بدون پلاستیک و گیت، دنیا به آخر نمی رسه ولی با وجودشون زندگی کلی آسون تر میشه پس پیشنهاد میدم اگه برنامه نویس هستید قورباغه تون رو قورت بدید شروع به تستش کنید.آقای لینوس توروالدز (خالق گیت و لینوکس)از اونجایی که حدس میزنم به دنیای کامپیوتر و دیجیتال علاقه مند اید که دارید این مقاله رو میخونید احتمالا با لینوس توروالدز هم آشنا هستید! کسی که هسته سیستم عامل محبوب لینوکس رو طراحی کرده و در سال 2005 میلادی، ورژن کنترل گیت رو بهمون هدیه داد. بعید میدونم الان بتونید شرکت نرم افزاریه به روز و درست حسابی پیدا بکنید که سورس برنامه هاشون رو با ورژن کنترل &quot;VCS&quot; هایی مثل گیت مدیریت نکنند!البته این هم بگم در کنار راحتی که گیت میاره، بسیار هم استرس زاست! استرسش هم از اینه که وقتی همه چیز ثبت و ضبط بشه راحت میشه مقصر رو پیدا کرد :) اینکه کی کد اشتباه زده، کی کم کاری کرده! کی باگه رو به وجود آوره و... و خب همیشه احتمال اینکه خودمون اون شخص باشیم هست! اما میرسیم به اصل مطلب :)ممکنه همه توسعه دهنده هایی که دارن این مقاله رو میخونن شاغل در شرکت های تولید و پشتیبانی نرم افزار نباشن و فکر کنن نیازی به یادگیری گیت ندارن! اما گیت حتی برای یک توسعه دهنده شخصی هم لازمه. فرض کنید بعد ساعت کاری توی منزل دارید یک پروژه شخصی رو توسعه میدید و فردا که به سرکار برگشتید قصد دارید توی زمان های استراحتی که واحد مدیریت HR برای کارمنداشون مشخص کرده بجای قدم زدن توی محوطه و چرخیدن توی شبکه های مجازی! کدهای شب قبلی که توی خونه نوشتید رو کامل کنید! برای انجام این کار بدون گیت باید یه فلش یا هاردی چیزی همراهتون باشه هی سورس آپدیت شده رو باهاش اینور اونور کنید :| اما با گیت ...1- اول فایل نصبی خود گیت رو  دانلود و روی سیستم خونه و  سیستم های دیگه ای که میخوایید باهاشون کار کنید نصب کنید.2- برید داخل سایت گیت هاب و ثبت نام کنید. ( گیت هاب چند روز پیش تحریم های ساخت مخازن خصوصی &quot;Private Repository&quot; رو برای ما ایرانی ها که چند سال بود اعمال شده بود رو برداشت).3- از ترمینال یا اگه از سیستم عامل ویندوز استفاده میکنید توی CMD باید با دستورات زیر نام کاربری و ایمیل خودتون رو ست کنید ( بهتره از همون نام کاربری و ایمیلی استفاده کنید که توی گیت هاب باهاش ثبت نام کردید، وگرنه میاد هر نام کاربری رو یه کاربر جدا در نظر میگیره توی کامیت ها &quot;Commit&quot; یا همون ثبت تغییرات کد ها).ست کردن نام کاربری کلی برای سیستم : ( توجه: بین &quot; &quot; نام دلخواه خودتون رو وارد کنید )git config --global user.name &amp;quotJohn Doe&amp;quotست کردن ایمیل کلی برای سیستم : (البته اینم بگم برای هر پروژه میتونید جدا کاربر تعریف کنید و نیازی به کاربر کلی ندارید)git config --global user.email johndoe@example.com4- باید برید توی حساب کاربری خودتون در گیت هاب وارد بشید و یک مخزن یا همون ( ریپازیتوری Repository ) جدید بسازید! اگه یک پروژه خصوصی هست و قرار نیست عموم مردم اون رو ببیند، تیک گزینه Private رو بزنید تا فقط شما و کسایی که شما مشخص می کنید بتونند مخزن رو مشاهده و ویرایش کنند. در غیر اینصورت تیک Public رو بزنید تا برنامه نویس های دنیا بتونن کار شما رو مشاهده و درصورت علاقه شون به پروژه شما بهتون توی توسعه اش کمک کنند.5- باید سورس خودمون رو به مخزن گیت هابی که ساختیم متصل کنیم! برای این کار ترمینال یا CMD رو باز میکنیم و وارد مسیر پوشه سورس پروژه مون میشیم.-- قدم اول میایم با دستور زیر ورژن کنترل گیت رو برای پروژه مون استارت میکنیم :git initخوب حالا میتونیم تمام فایل های جدید در پروژه رو با دستور زیر وارد این مخزن کنیم :git add .نکته : شما میتونید با ساخت یک فایل بی نام و با پسوند .gitignore در مسیر روت سورس مخزن خودتون، پوشه ها و فایل هایی که نمی خواهید داخل گیت قرار بگیرن رو داخلش مشخص کنید.از این به بعد هر تغییراتی که در سورس خودمون اعمال کردیم رو ثبت می کنیم که در اصطلاح بهش کامیت &quot;Commit&quot; کردن میگن! با دستور زیر میتونیم این کار رو انجام بدیم :git commit -m &amp;quotfirst commit&amp;quot-- در قدم دوم باید سورس خودمون رو به مخزنی که داخل گیت هاب ساختیم متصل کنیم. (در انتهای دستور زیر یک آدرس وب گیت هاب هست که شما باید اون رو با آدرس وب مخزن خودتون که در گیت هاب ساختید عوض کنید)git remote add origin https://github.com/yourUserName/Name.gitو در مرحله آخر تغییرات انجام شده مون رو با دستور زیر وارد مخزن پروژه مون در گیت هاب میکنیم یا به اصطلاح پوش &quot;Push&quot; می کنیم و صبر میکنیم تا کار آپلود فایل ها تموم بشه :git push origin masterبه همین آسونی ! البته اینم بگم دستورات بالا همه شون آرگومنت &quot;Argument&quot; های مخصوص دیگه ای دارن مثل مشخص کردن شاخه ها &quot;Branch&quot; و... که من خواستم ساده ترین حالتش رو بگم. بزارید یه کوچولو درباره این شاخه ها یا برنچ ها هم بگم دیگه تا اینجا اومدیم :) فرض کنید ما یه شاخه اصلی داریم از سورس مون به نام Main یا اصلی و یک شاخه دیگه به اسم &quot;Test&quot; یا همون آزمایشی مثلا! که کد های ریسکی و آزمایشی مون برای یک قابلیت جدید رو اول به اون شاخه پوش &quot;Push&quot; میکنیم، بعد اگه اوکی بودیم باهاش و خواستیم به بدنه پروژه اصلیمون اضافه بشه اون شاخه آزمایشی رو با شاخه اصلی یکی میکنیم با به اصطلاح مرج &quot;Merge&quot; میکنیم.کپی پروژه گیت هاب به یک سیستم دیگر :حالا تو هر سیستم دیگه ای بجز سیستم خودمون که میخواییم باهاش روی پروژه کار کنیم کافیه یکبار پروژه رو با دستور زیر از گیت هاب کپی &quot;Clone&quot; کنیم روی سیستم جدید: ( آدرس گیتهاب پروژه خودتون رو بزارید انتهای دستور زیر و در CMD واردش کنید تا پروژه رو توی سیستم جدید دانلود کنه! )git clone https://github.com/USERNAME/REPOSITORY.gitحالا میتونید توی این سیستم هم همون سورس کد رو داشته باشید و تغییرات خودتون رو اعمال کنید. و کامیت و پوش :)و بعد سورس کدی رو که توی سیستم دوم تغییر داده بودید رو با دستور زیر بروز کنید و تغییراتش رو دریافت کنید :git pullتمام! حالا هی قهوه بخورید هی پوش &quot;Push&quot; کنید هی پول &quot;Pull&quot; کنید :)</description>
                <category>آرش مهرانی</category>
                <author>آرش مهرانی</author>
                <pubDate>Sun, 24 Jan 2021 17:14:36 +0330</pubDate>
            </item>
            </channel>
</rss>