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

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


مطالب تصادفی
اخبار و مقالات در فکر بکر آموزش ویرایش مطالب با استفاده از x-editable در Asp.net MVC

کتابخانه جاوااسکریپتی x-editable دارای قابلیتهای بسیار خوبی برای برنامه نویسان میباشد و همچنین با قابلیتی که دارد شما میتوانید ب ...


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

در این آموزش به نحوه ثبت تصویر و ذخیره آن در حافظه گوشی با سیستم عامل اندروید با زبان برنامه نویسی سی شارپ (C#.net)خواهیم پرداخت. ...


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

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


اخبار و مقالات در فکر بکر آموزش Serialize و Deserialize اطلاعات در قالب Json به زبان C#.net

JSON مخفف عبارت «Javascript Object Notation» به معنی «نشان‌گذاری شیء جاوااسکریپت» است. و با استفاده از آن میتوان اطلاعات مورد نظر ...


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

جهت دانلود بازی جذاب ماشین به زبان C# از فکر بکر به ادامه مطالب توجه نمایید ...


اخبار و مقالات در فکر بکر آموزش کار با کوکی ها (Cookie) در Asp.net core

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


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

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


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

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


اخبار و مقالات در فکر بکر آموزش نحوه ایجاد Model برای دیتابیس موجود در Entity Framework Core

در این آموزش به نحوه ایجاد کلاسهای context و entity برای دیتابیس موجود در Entity Framework Core خواهیم پرداخت. ...


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

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


اخبار و مقالات در فکر بکر بررسی نکات امنیتی در آپلود تصاویر

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


اخبار و مقالات در فکر بکر آموزش نمایش تصویر loading در سمت client جهت بارگزاری صفحات با حجم زیاد از سرور در asp.net mvc

وبسایتهایی زیادی به این موضوع که با هر بار کلیک کاربر بر روی چیزی بدلیل سنگین بودن فایهای ارسالی از سرور و یا پردازش آن تصویر loa ...


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

با سلام – در این مقاله به آموزش ایجاد آدرسهای کاربر پسند در برنامه های Asp.net خواهم پرداخت User friendly بودن URLs فقط برای کا ...


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

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


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

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

z83mr9

آموزش کار با کوکی ها (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) --------

ابتدای صفحه