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

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


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

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


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

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


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

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


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

در این بخش به آموزش چگونگی درج رکوردهای پیشفرض درون جداول در هنگام ایجاد دیتابیس با استفاده از روش code first در محیط Asp.net Cor ...


اخبار و مقالات در فکر بکر آموزش کامل Web Api2 در MVC با عملیات CRUD

با سلام خدمت تمامی کاربران فکر بکر در این مقاله سعی نمودم تا با ارائه مثال عملی به آموزش کامل Web Api بپردازم. قبل از هرچیز باید ...


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

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


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

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


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

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


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

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


اخبار و مقالات در فکر بکر آشنایی با SignalR در Asp.net core

در این آموزش به ساخت یک برنامه real-time با استفاده از SignalR در Asp.net core 2.1 خواهیم پرداخت. ...


اخبار و مقالات در فکر بکر نحوه خواندن اطلاعات از فایل appsetting.json در Asp.net Core

فایل appsetting در نسخه های core معادل فایل webconfig در نسخه های قدیمی تر می باشد که برای پیکر بندی تنظیمات کلی پروژه مانند تنظی ...


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

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


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

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


اخبار و مقالات در فکر بکر آموزش استفاده از Bundler & Minifier در Asp.Net Core

در این آموزش ابتدا چند فایل استاتیک(css-js) به ویوی برنامه ارجاع میدهیم و سپس با استفاده از مفهوم Bundling and Minifying حجم و تر ...


پیوندها
5 (21)

Repository یک مخزن یا انباره ای میباشد که میتواند بعنوان لایه DAL در برنامه نویسی مورد استفاده قرار گیرد.در این مثال قصد داریم برای اطلاعات User با استفاده از Repository عملیات CRUD را انجام دهیم
گروه : Asp.net MVC
تاریخ انتشار: 1395/05/20

فکر بکر

Repository یک مخزن یا انباره ای میباشد که میتواند بعنوان لایه DAL در برنامه نویسی مورد استفاده قرار گیرد.

در این مثال قصد داریم برای اطلاعات User با استفاده از  Repository عملیات CRUD را انجام دهیم.

ابتدا یک پروژه از نوع Empty MVC ایجاد نمایید.
یک کلاس به نام User درون پوشه Models ایجاد نمایید و محتویات آنرا بصورت زیر ویرایش کنید.

 


namespace RepositorySample.Models
{
    public class User
    {
        public int ID { get; set; }
        public string Fname { get; set; }
        public string Lname { get; set; }
        public string Email { get; set; }
        public bool IsActive { get; set; }
        public string UserName { get; set; }
        public string Password { get; set; }
    }
}

 

 روی نام پروژه کلیک راست نمایید و گزینه Manage Nuget Packages ر ا انتخاب نمایید از صفحه باز شده از قسمت Brows عبارت EntityFrameWork را جستجو و سپس نصب نمایید.

entityframework

 

درون پوشه Models کلاسی بنام DBContext ایجاد نمایید و محتویات آنرا بصورت زیر ویرایش نمایید.


namespace RepositorySample.Models
{
    public class DBContext : DbContext
    {
        public DBContext():base("mycon")
        {

        }
         static DBContext()
        {

        }
        public DbSet<User> user
        {
            get; set;
        }
    }
}

 

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

<connectionStrings>
    <add name="mycon" connectionString="data source=.;initial catalog=repositoryDB;integrated security =true;" providerName="System.Data.SqlClient" />
  </connectionStrings>

 

 رشته اتصال فوق را بر اساس سیستم خود تنظیم نمایید.
پوشه ای بنام DAL به روت برنامه اضافه نمایید و کلاسی بنام IUserRepository ایجاد نمایید و سپس اینترفس زیر را درون آن درج نمایید.


namespace RepositorySample.DAL
{
    public interface IUserRepository
    {
       IEnumerable<Models.User> GetUser();
        Models.User GetUserByID(int id);
        void DeleteUser(int userID);
        void InsertUser(Models.User user);
        void UpdateUser(Models.User user);
        void Save();
    }
   
}

 

سپس کلاسی دیگر بنام UserRepository  را درون پوشه DAL اضافه نمایید و محتویات آنرا بصورت زیر ویرایش نمایید.


namespace RepositorySample.DAL
{
    public class UserRepository : IUserRepository,IDisposable
    {
        public UserRepository(Models.DBContext dbcontext)
        {
            db = dbcontext;
        }
        Models.DBContext db = new Models.DBContext();

        IEnumerable<Models.User> IUserRepository.GetUser()
        {
            return db.user.ToList();
        }

        public Models.User GetUserByID(int id)
        {
            return db.user.Find(id);
        }

        public void DeleteUser(int userID)
        {
            User user = db.user.Find(userID);
            db.user.Remove(user);
        }

 

        void IUserRepository.InsertUser(Models.User user)
        {
            db.user.Add(user);
        }

        public void UpdateUser(User user)
        {
            db.Entry(user).State = System.Data.Entity.EntityState.Modified;
        }

        void IUserRepository.Save()
        {
            db.SaveChanges();
        }

        private bool disposed = false;

        protected virtual void Dispose(bool disposing)
        {
            if (!this.disposed)
            {
                if (disposing)
                {
                    db.Dispose();
                }
            }
            this.disposed = true;
        }

        public void Dispose()
        {
            Dispose(true);
            GC.SuppressFinalize(this);
        }
    }

}

 

 

اکنون میتوانید از این کلاس درون کنترلرهای خود استفاده نمایید.
قطعه کد زیر نحوه استفاده از این کلاس در کنترلر Home می باشد.

 

  public class HomeController : Controller

    {

        DAL.IUserRepository userRepository;

        public HomeController() { this.userRepository = new DAL.UserRepository(new Models.DBContext()); }

        public HomeController(DAL.IUserRepository userRepository) { this.userRepository = userRepository; }

        // GET: Home

        public ActionResult Index()

        {

            return View(userRepository.GetUser());

        }

    }

 

JALAL
|
1396/10/18

MERCCC
محمد مهدوی
|
1396/10/30

خواهش میکنم - موفق باشید

حسن
|
1396/11/28

آفرین منم دنبال مفهوم ریپوزوتری بودم سایت شما کمک کرد
محمد مهدوی
|
1396/12/02

موفق باشید

i7crVU

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

ابتدای صفحه