fekre-bekr,learning,source,سورس,سورس رایگان,آموزش,اخبار,فناوری اطلاعات,mvc,.net,ساری,آموزشگاه,asp.net,c#.net,programing,c++,vb,آموزش برنامه نویسی,دانلود

اشتراک در سایت


مطالب تصادفی
اخبار و مقالات در فکر بکر حل تمرین مسائل برنامه نویسی از بخش دستورات تکرار (حلقه ها) در سی شارپ

جهت مشاهده سوال و دانلود سورس آن لطفا به ادامه مطلب توجه نمایید. ...


اخبار و مقالات در فکر بکر سورس برنامه paint (نقاشی) در سی شارپ

جهت دریافت سورس زیبای برنامه paint در C# به ادامه مطلب توجه نمایید ...


اخبار و مقالات در فکر بکر نتیجه تحقیق جهانی از بیش از 50000 توسعه دهنده برنامه در 173 کشور منتشر شد

به نقل از لنفورماتیسین, Stack Overflow اطلاعات بیش از پنجاه هزار توسعه دهنده برنامه در 173 کشور را گرد اورده و اماری تهیه کرده اس ...


اخبار و مقالات در فکر بکر آموزش اعتبار سنجی غیر همزمان(AsyncValidation) با استفاده از جاوااسکریپت در Asp.net mvc

در این اموزش قصد داریم با استفاده از کدهای جاوااسکریپت نام کاربری که توسط کاربر وارد شده است را به سرور انتقال دهیم و سپس مجاز یا ...


اخبار و مقالات در فکر بکر آشنایی با Asp.net mvc6 بصورت پروژه عملی #1

با سلام در این مقاله میخواهیم mvc6 را با یک پروژه عملی آموزش دهیم بنابراین بدون مقدمه کار را شروع میکنیم لطفا به ادامه مطلب توجه ...


اخبار و مقالات در فکر بکر حل تمرین مسائل برنامه نویسی از بخش طراحی منو (menu) در سی شارپ

در این برنامه سوال 2 و 3 از فصل طراحی منو در یک پروژه حل شده است ، در این برنامه نحوه ایجاد منو ها و کار با تصاویر را خواهیم آموخ ...


اخبار و مقالات در فکر بکر حل تمرین مسائل برنامه نویسی از بخش آرایه ها در سی شارپ

جهت مشاهده سوال و دانلود سورس آن لطفا به ادامه مطلب توجه نمایید. ...


اخبار و مقالات در فکر بکر فایل pdf آموزش کامپوننت Backgroundworker برای برنامه نویسی بصورت همزمان

با استفاده از کامپوننت BackgroundWorker شما میتوانید به برنامه نویسی و اجرای کارهای زمانبر در یک Thread دیگر و بصورت موازی بپرداز ...


اخبار و مقالات در فکر بکر پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش دوم)

در ادامه دیتابیس و مدل برنامه را طراحی میکنیم بگونه ای که کاربران ثبت نام شده و مدیر سیستم بتوانند به صفحات خود باتوجه به نقشی ...


اخبار و مقالات در فکر بکر آموزش استفاده از PersianDateTimePicker (تقویم فارسی) در برنامه های تحت وب

با سلام - در این مقاله به آموزش نحوه استفاده از کنترل PersianDateTimePicker(تقویم فارسی) در برنامه های تحت وب می پردازیم ...


اخبار و مقالات در فکر بکر آموزش ارسال و دریافت فایل در برنامه تحت شبکه با استفاده ار سوکت (Socket)

در این آموزش فایلی را در شبکه با استفاده از سوکت و پروتکل TCP ارسال و سپس دریافت میکنیم.لطفا به ادامه مطلب توجه نمایید. ...


اخبار و مقالات در فکر بکر حل تمرین مسائل برنامه نویسی از بخش فایلها در سی شارپ

در این برنامه به حل مساله کتاب جهت ذخیره در فایل متنی با استفاده از کادر محاوره ای savefileDialog می پردازیم . لطفا به ادامه مطل ...


اخبار و مقالات در فکر بکر آموزش ساخت صفحه Page Not Found (404) در Aspnet core

در این بخش به اموزش نحوه مدیریت خطا و هدایت کاربر به صفحه Page Not Found (404) در Aspnet core می پردازیم. یکی از مشکلات مهمی ک ...


اخبار و مقالات در فکر بکر استفاده از AutoMapper در C #

با سلام – در این مقاله قصد دارم کلاس کاربردی AutoMapper را به شما کاربران فکر بکر معرفی کنم. ...


پیوندها
5 (1)

در این آموزش به پیاده سازی سیستم لاگین کاربران در Asp.net mvc خواهیم پرداخت. نکته ای که در اینجا حائز اهمیت است بدست آوردن نقش کاربران هنگام ورود به صفحاتی است که نیاز به احراز هویت می باشد.جهت مشاهده آموزش به ادامه مطب توجه نمایید.
گروه : Asp.net MVC
تاریخ انتشار: 1395/07/02

فکر بکر

پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش اول)

پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش دوم)

پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش سوم)

در این آموزش به پیاده سازی سیستم لاگین کاربران  در Asp.net mvc خواهیم پرداخت.
نکته ای که در اینجا حائز اهمیت است بدست آوردن نقش کاربران هنگام ورود به صفحاتی است که نیاز به احراز هویت می باشد. ما برای اینکار از کلاس RoleProvider دات نت استفاده خواهیم کرد برای انجام اینکار مراحل زیر را انجام دهید.
درون پوشه Models کلاسی بنام myRoleProvider ایجاد نمایید و سپس کلاس مورد نظر را از از کلاس RoleProvider مشتق بگیرید و کدهای آن را بصورت زیر ویرایش نمایید.


  public class myRoleProvider : RoleProvider
    {
        public override string ApplicationName
        {
            get
            {
                throw new NotImplementedException();
            }

            set
            {
                throw new NotImplementedException();
            }
        }

        public override void AddUsersToRoles(string[] usernames, string[] roleNames)
        {
            throw new NotImplementedException();
        }

        public override void CreateRole(string roleName)
        {
            throw new NotImplementedException();
        }

        public override bool DeleteRole(string roleName, bool throwOnPopulatedRole)
        {
            throw new NotImplementedException();
        }

        public override string[] FindUsersInRole(string roleName, string usernameToMatch)
        {
            throw new NotImplementedException();
        }

        public override string[] GetAllRoles()
        {
            throw new NotImplementedException();
        }

        public override string[] GetRolesForUser(string username)
        {
            using (usermanager.Models.MyCMS2Entities2 db = new MyCMS2Entities2())
            {
                return (from user in db.Users
                        join role in db.Roles
                            on user.RoleID equals role.RoleID
                        where user.UserName == username
                        select role.RoleName).ToArray();
            }
        }

        public override string[] GetUsersInRole(string roleName)
        {
            throw new NotImplementedException();
        }

        public override bool IsUserInRole(string username, string roleName)
        {
            throw new NotImplementedException();
        }

        public override void RemoveUsersFromRoles(string[] usernames, string[] roleNames)
        {
            throw new NotImplementedException();
        }

        public override bool RoleExists(string roleName)
        {
            throw new NotImplementedException();
        }
    }

 

 در کلاس فوق تابع GetRolesForUser را بصورتی که مشاهده میکنید ویرایش نمودیم تا سیستم هر وقت به نقش کاربری نیاز داشته باشد از این تابع استفاده نماید.در این تابع یک آرگومان بنام username وجود دارد که همانطور قبلا در اموزش بخش دوم توضیح داده شد نام کاربری در کوکی ذخیره میشود و سیستم از این طریق به آن دسترسی خواهد داشت.
در این مرحله کدهای زیر را در ابتدای تگ system.web درج نمایید.


<roleManager enabled="true" defaultProvider="myRoleProvider">
      <providers>
        <clear />
        <add name="myRoleProvider" type="mycms2.Models.Provider.myRoleProvider" />
      </providers>
    </roleManager>

 

در قطعه کد بالا دستور clear یعنی ما خودمان به مدیریت نقشها خواهیم پرداخت و مدیریتهای قبلی که توسط دات نت بصورت خودکار ایجاد شده است را در نظر نخواهیم گرفت.
بهتر است مقادیر موجود در گزینه های defaultProvider و name  همنام با کلاس ایجاد شده باشد و مقدار موجود در گزینه type برابر با مسیر کامل فضای نام کلاس مورد نظر بهمراه نام کلاس باشد.
در این مرحله به پیاده سازی سیتم لاگین خواهیم پرداخت.
اکشنهای زیر را در کنترلر Account  ایجاد نمایید.


   public virtual ActionResult Login(string ReturnUrl = "/")
        {
            if (User.Identity.IsAuthenticated)
                return RedirectToAction("Index", "Home");

            ViewBag.ReturnUrl = ReturnUrl;

            return View();
        }

        [HttpPost, ValidateAntiForgeryToken]
        public virtual ActionResult login(LoginViewModel login, string ReturnUrl = "")
        {
            if (ModelState.IsValid)
            {

                var user = db.Users.FirstOrDefault(u => u.UserName == login.username && u.Password == login.pass);
                if (user != null)
                {
                    if (user.IsActive == true)
                    {
                        FormsAuthentication.SetAuthCookie(login.username, login.Remember);
                        if (ReturnUrl != "")
                        {
                            if (Url.IsLocalUrl(ReturnUrl))
                            {
                                return Redirect(ReturnUrl);
                            }
                            else
                            {
                                return RedirectToAction("Index", "Home");
                            }
                        }
                        return Redirect("/");
                    }
                    else
                    {
                        ModelState.AddModelError("username", "حساب کاربری فوق فعال نشده است");
                    }
                }
                else
                {
                    ModelState.AddModelError("username", "کاربری یافت نشد");

                }
            }
            return View(login);
        }

 

 سپس جهت ایجاد ویوی اکشن login بر روی اکشن کلیک راست نمایید و گزینه Add view را انتخاب کنید و جهت ادامه کار از تصویر زیر استفاده نمایید.

login view model

سپس ویوی مورد نظر را بصورت زیر ویرایش نمایید.

@model usermanager.Models.LoginViewModel

 

@{

    ViewBag.Title = "Login";

}

 

 

<div class="panel panel-primary">

 

    <div class="panel-heading">

 

        <h4 class="panel-title">ورود به سیستم</h4>

 

    </div>

 

    <div class="panel-body form-horizontal">

 

        @using (Html.BeginForm("Login", "Account", FormMethod.Post))

        {

            @Html.AntiForgeryToken()

 

            <div class="form-horizontal">

 

                @Html.ValidationSummary(true, "", new { @class = "text-danger" })

                <div class="form-group">

                    @Html.LabelFor(model => model.username, htmlAttributes: new { @class = "control-label col-md-2" })

                    <div class="col-md-10">

                        @Html.EditorFor(model => model.username, new { htmlAttributes = new { @class = "form-control" } })

                        @Html.ValidationMessageFor(model => model.username, "", new { @class = "text-danger" })

                    </div>

                </div>

 

                <div class="form-group">

                    @Html.LabelFor(model => model.pass, htmlAttributes: new { @class = "control-label col-md-2" })

                    <div class="col-md-10">

                        @Html.EditorFor(model => model.pass, new { htmlAttributes = new { @class = "form-control" } })

                        @Html.ValidationMessageFor(model => model.pass, "", new { @class = "text-danger" })

                    </div>

                </div>

 

                <div class="form-group">

                    @Html.LabelFor(model => model.Remember, htmlAttributes: new { @class = "control-label col-md-2" })

                    <div class="col-md-10">

                        <div class="checkbox">

                            @Html.EditorFor(model => model.Remember)

                            @Html.ValidationMessageFor(model => model.Remember, "", new { @class = "text-danger" })

                        </div>

                    </div>

                </div>

 

 

 

             

 

                <div class="form-group">

                    <div class="col-md-offset-2 col-md-10">

                        <input type="submit" value="ورود به سیستم" class="btn btn-default" />

                    </div>

                </div>

            </div>

        }

    </div>

 

    <div class="panel-footer">

        <a href="#">کلمه عبور را فراموش کردهام</a>

        |

        <a href="#">ثبت نام</a>|

        <a href="~/">بازگشت به صفحه اصلی</a>

 

    </div>

 

</div>

 جهت خروج از سیستم (sign out) از اکشن زیر استفاده نمایید.

  public virtual ActionResult Signout()

        {

            FormsAuthentication.SignOut();

            return Redirect("/");

        }

 قبل از اجرای برنامه ابتدا نقش یکی از کاربران ایجاد شده در دیتابیس را با قرار دادن مقدار roleID به عدد یک  بصورت دستی به مدیر سیستم تبدیل نمایید.
اکنون برنامه را اجرا کنید و به ادرس Admin/myadmin بروید.از آنجاییکه عملیات لاگین انجام نشده سیستم شمارا به صفحه لاگین هدایت میکند در این قسمت به مقدار پارامتر return url در قسمت ادرس مرورگر دقت نمایید. پس از موفقیت آمیز بودن عمل لاگین و مجاز بودن نقش کاربر به صفحه مقصد هدایت میشوید.

admin page

 

login page

 

admin page 2

در این قسمت جهت بررسی نقش کاربر از کلاس myRoleProvider بصورت خودکار استفاده میشود.
امیدوارم این آموزش مورد توجه شما کاربران عزیز قرار گرفته باشد.

شما اولین نفری باشید که نظر میدهید

GbyOfm

آموزش ساخت صفحه Page Not Found (404) در Aspnet core -------- آموزش ایجاد Tag Helper سفارشی در Asp.net core -------- آموزش نحوه ایجاد Model برای دیتابیس موجود در Entity Framework Core -------- آموزش نحوه Upload و Download در Asp.net core 2 -------- آموزش dependency injection در Asp.net core 2 -------- آموزش تحت شبکه کردن برنامه های مبتنی بر c# در sql server -------- آموزش استفاده از Bundler & Minifier در Asp.Net Core -------- مروری بر Identity در Asp.net core2.1 (بخش دوم) -------- مروری بر Identity در Asp.net core2.1 (بخش اول) -------- آموزش مبحث Single Responsibility Principle (SRP) از بخش اصول طراحی شی گرا (SOLID) -------- آموزش publish کردن برنامه های Asp.net core بر روی سرور iis -------- پیاده سازی مسیریابی با استفاده از الگوریتم پیمایش اول سطح یا جستجوی اول سطح (BFS) در سی شارپ -------- آشنایی با SignalR در Asp.net core -------- آموزش استفاده از کلاس SeedData در Asp.net Core -------- قالب سایت فروشگاهی -------- آموزش ایجاد برنامه نصب (setup) قسمت سوم -------- آموزش ایجاد برنامه نصب (setup) قسمت دوم -------- آموزش ایجاد برنامه نصب (setup) قسمت اول -------- آموزش عملیات CRUD با استفاده از Ragor Pages در Asp.net Core2.0 -------- آموزش ثبت تصویر توسط دوربین در برنامه نویسی اندروید به زبان c#.net -------- حل مساله n وزیر با استفاده از الگوریتم ژنتیک و بصورت گرافیکی -------- آموزش نمایش تصویر loading در سمت client جهت بارگزاری صفحات با حجم زیاد از سرور در asp.net mvc -------- آموزش اعتبار سنجی غیر همزمان(AsyncValidation) با استفاده از جاوااسکریپت در Asp.net mvc -------- آموزش ایجاد breadcrumb با استفاده از sitemap در MVC -------- آموزش ایجاد برنامه چت دوطرفه با استفاده از Socket در سی شارپ -------- آموزش ارسال و دریافت فایل در برنامه تحت شبکه با استفاده ار سوکت (Socket) -------- آموزش رسم نمودار در Asp.net -------- آموزش ایجاد مگا منو -------- آموزش استفاده از Grid mvc در Asp.net mvc -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش چهارم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش سوم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش دوم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش اول) -------- بررسی نکات امنیتی در آپلود تصاویر -------- آموزش async - await در یک مثال عملی -------- قالب پنل ادمین -------- آموزش Repository pattern در Asp.net MVC -------- آموزش Serialize و Deserialize اطلاعات در قالب Json به زبان C#.net -------- آموزش ویرایش مطالب با استفاده از x-editable در Asp.net MVC -------- آموزش ایجاد آدرسهای کاربرپسند(user friendly URLs) در Asp.net MVC --------

ابتدای صفحه