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

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


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

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


اخبار و مقالات در فکر بکر آموزش ارسال ایمیل توسط اکانت گوگل به زبان C#.net

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


اخبار و مقالات در فکر بکر آموزش async - await در یک مثال عملی

در این آموزش قصد داریم نحوه اجرای چندین فرایند با استفاده از برنامه نویسی بصورت Asynchronous را برای شما ارائه دهیم لطفا به ادامه ...


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

با سلام - در این قسمت به ادامه مبحث قبلی و آشنایی بیشتر با net core1 و mvc6 می پردازیم . لطفا به ادامه مطلب توجه نمایید. ...


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

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


اخبار و مقالات در فکر بکر آموزش dependency injection در Asp.net core 2

تزریق وابستگی یکی از مباحث مبهم برای برنامه نویسانی که به تازگی با این عنوان آشنا شده اند می باشد.اما باید در نظر داشته باشید که ...


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

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


اخبار و مقالات در فکر بکر آموزش استفاده از Grid mvc در Asp.net mvc

در این مقاله به آموزش نمایش داده ها با استفاده از Grid MVC با قابلیت مرتب سازی داده ها خواهیم پرداخت. ...


اخبار و مقالات در فکر بکر سورس برنامه shutdown - restart - lock - sleep در سی شارپ

سورس بسیار زیبای برنامه shutdown - restart - lock - sleep در سی شارپ را از فکر بکر دانلود نمایید. لطفا به ادامه مطالب توجه نمایید ...


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

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


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

در این ساعت از فکر بکر بازی زیبای Minesweeper که از بازیهای پرطرفدار در سیستم عامل ویندوز هست را میتوانید از فکر بکر دانلود نمایی ...


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

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


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

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


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

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


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

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

bK0c56

عملیات 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) -------- آموزش رسم نمودار در Asp.net -------- آموزش ایجاد مگا منو -------- آموزش استفاده از Grid mvc در Asp.net mvc -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش چهارم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش سوم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش دوم) -------- پیاده سازی سیستم احراز هویت کاربران در Asp.net MVC (بخش اول) --------

ابتدای صفحه