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

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


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

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


اخبار و مقالات در فکر بکر آموزش نحوه ایجاد Extention method در C#

در این بخش با ارائه مثال عملی تبدیل تاریخ میلادی به شمسی به آموزش Extention method می پردازیم. ...


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

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


اخبار و مقالات در فکر بکر آموزش دستورات کاربردی در SQL

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


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

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


اخبار و مقالات در فکر بکر طراحی سایت با HTML 6

ورژن 6HTML نسخه ی توسعه یافته HTML ها است که دارای NameSpaces با ساختار XML می باشد. از ویژگی های مهم NameSpaces این است که با ا ...


اخبار و مقالات در فکر بکر آموزش ایجاد برنامه چت دوطرفه با استفاده از Socket در سی شارپ

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


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

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


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

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


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

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


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

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


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

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


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

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


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

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


پیوندها
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

موفق باشید

6TDA5k

آموزش پیاده سازی 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 (بخش اول) -------- بررسی نکات امنیتی در آپلود تصاویر -------- آموزش async - await در یک مثال عملی -------- قالب پنل ادمین --------

ابتدای صفحه