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

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


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

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


اخبار و مقالات در فکر بکر آموزش ساخت صفحه تماس با ما بصورت Ajax در Asp.net MVC5

در این برنامه می خواهیم به آموزش نحوه ارسال اطلاعات بدون لود یا refresh شدن صفحه به سمت سرور در Asp.net MVC بپردازیم. ...


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

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


اخبار و مقالات در فکر بکر آموزش ایجاد breadcrumb با استفاده از sitemap در MVC

در این آموزش با استفاده از نقشه سایت به ایجاد و پیاده سازی breadcrumb می پردازیم. ...


اخبار و مقالات در فکر بکر آموزش ایجاد لینک دانلود در mvc

در این برنامه به آموزش نحوه ایجاد لینک دانلود در برنامه های از نوع Asp.Net MVC می پردازیم. لطفا به ادامه مطلب توجه کنید. ...


اخبار و مقالات در فکر بکر سورس استفاده از کامپوننت Roxy File manager در Asp.net core

در این سورس شما با نحوه استفاده از کامپوننتهای ckeditor و Roxy File manager در Asp.net core اشنا خواهید شد. جهت دانلود بر روی ادا ...


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

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


اخبار و مقالات در فکر بکر آموزش ایجاد Tag Helper سفارشی در Asp.net core

Tag Helper یکی از ویژگیهای جدید در Asp.net Core MVC می باشد.در این آموزش شما میتوانید با استفاده از کلاسهای C# قالب عناصر html ...


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

لطفا به ادامه مطالب توجه فرمایید ...


اخبار و مقالات در فکر بکر آموزش عملیات CRUD با استفاده از Ragor Pages در Asp.net Core2.0

در این مقاله به آموزش عملیات CRUD که همان چهار عملیات اصلی (درج – حذف – بروزرسانی و انتخاب رکوردها ) می باشد را در محیط Asp.net c ...


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

در این برنامه سورس notepad در c# را بصورت رایگان برای شما کاربران عزیز در فکر بکر جهت دانلود قرار دادیم ...


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

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


اخبار و مقالات در فکر بکر آموزش ایجاد custom model binder در Asp.net core

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


اخبار و مقالات در فکر بکر آموزش رمزنگاری فایلها در asp.net core

با توجه به اینکه بسیاری از فایلهای ذخیره شده بر روی سرور از اهمیت بالایی برخوردار هستند ، بنابراین کدنویسی بخش رمزنگاری فایلها جه ...


پیوندها
5 (13)

در این آموزش به پیاده سازی سیستم لاگین کاربران در 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 بصورت خودکار استفاده میشود.
امیدوارم این آموزش مورد توجه شما کاربران عزیز قرار گرفته باشد.

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

1z0kK5

آموزش کار با کوکی ها (Cookie) در Asp.net core -------- آموزش رمزنگاری فایلها در asp.net core -------- مقایسه واحدهای اندازه گیری rem و em در css -------- آشنایی با مفهوم Generic در C#.net -------- نحوه خواندن اطلاعات از فایل appsetting.json در Asp.net Core -------- آموزش استفاده از CQRS و Mediator در Asp.Net Core -------- نحوه ایجاد image checkbox در html css -------- عملیات crud و WebApi در Asp.net 6 -------- آموزش ایجاد custom model binder در Asp.net core -------- آموزش استفاده از Log4net در Asp.net 5 -------- آموزش پیاده سازی UnitOfWork در Asp.net Core قسمت اول -------- پیاده سازی Repository Pattern بصورت Generic Class -------- وارد کردن فقط حروف فارسی و جلوگیری از ورود حروف فارسی در تکست باکس با استفاده از JQuery -------- سورس استفاده از کامپوننت Roxy File manager در Asp.net core -------- آموزش ساخت صفحه 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) --------

ابتدای صفحه