eitaa logo
پروژه ASP.Net Core MVC (وب و سی شارپ)
119 دنبال‌کننده
168 عکس
38 ویدیو
376 فایل
❁﷽❁ آموزش 📖 برنامه نویسی ASP.Net Core MVC (وب و سی شارپ) Admin: @alialirezapanahi برنامه نویسی برنامه نویسی سی شارپ eitaa.com/sisharpapp برنامه نویسی وب eitaa.com/aspdatnet ویراستی virasty.com/alialirezapanahi آپارات aparat.com/alialirezapanahi
مشاهده در ایتا
دانلود
🧠 مشکل مرموز ولی رایج: Model Binding شکست می‌خوره چون نام پارامتر اشتباهه! خیلی از برنامه‌نویس‌ها وقتی MVC کار می‌کنن، با این مشکل عجیب روبرو می‌شن: کدی که به نظر درست میاد، ولی اطلاعات فرم ذخیره نمی‌شن، یا ModelState.IsValid == false برمی‌گرده. چرا؟ چون یه اشتباه ساده در نام پارامتر باعث می‌شه مدل‌سازی ناقص انجام بشه. ✅ نمونه‌کد اشتباه public IActionResult Create(FullName name) { if (ModelState.IsValid) { _context.fullNames.Add(name); _context.SaveChanges(); return RedirectToAction("Index"); } return View(name); } فرض کنیم ویوی مرتبط به این کنترلر، این شکلی باشه: @model FullName <form asp-action="Create" method="post"> <input asp-for="Name" /> <input asp-for="Age" /> <button type="submit">ثبت</button> </form> به نظر همه‌چیز درست میاد، اما وقتی فرم ارسال می‌شه، ModelState.IsValid برابر false میشه! چرا؟ چون ASP.NET MVC هنگام Model Binding تلاش می‌کنه داده‌های فرم رو به شی‌ای به نام name وصل کنه، ولی اون انتظار داره شی‌ای به نام fullName باشه. 🎯 راه‌حل ساده ولی طلایی public IActionResult Create(FullName fullName) { if (ModelState.IsValid) { _context.fullNames.Add(fullName); _context.SaveChanges(); return RedirectToAction("Index"); } return View(fullName); } حالا، چون نام پارامتر با نام مدل در ویو هماهنگه (FullName)، بایندینگ بدون مشکل انجام می‌شه و اطلاعات درست ذخیره می‌شن ✅ ✍️ توضیح فنی کوتاه برای مخاطبین کانال Model Binding در ASP.NET MVC یعنی تبدیل داده‌های فرم به شیء مدل. برای این کار، فریم‌ورک از نام پارامتر کنترلر استفاده می‌کنه. اگر نام پارامتر کنترلر با مدل یا داده‌های فرم ناسازگار باشه، Binding ناقص انجام می‌شه و ModelState.IsValid == false خواهد بود! 📌 نکته آموزشی برای کانال 🔻 خیلی از برنامه‌نویس‌ها این خطا رو با مشکلات ویو یا اعتبارسنجی اشتباه می‌گیرن، درحالی‌که فقط باید نام پارامتر رو اصلاح کنن.
StudentManagement.zip
حجم: 24.7M
## 📂 ریپوزیتوری: سازمان‌دهنده‌ی دسترسی به دیتابیس ریپوزیتوری مثل یه لایه‌ی واسطه بین دیتابیس و بقیه‌ی برنامه‌ست. وظیفه‌ش چیه؟ - جدا کردن منطق دسترسی به داده‌ها از بقیه‌ی کدها (مثلاً کوئری‌ها، ذخیره، حذف و ...). - جلوگیری از اینکه کنترلر یا سرویس‌ها مستقیم با دیتابیس کار کنن. - قابل تست‌تر شدن پروژه: به‌راحتی می‌تونی ریپوزیتوری رو در تست‌ها شبیه‌سازی (Mock) کنی. - انعطاف بالا: اگه تصمیم بگیری دیتابیس رو عوض کنی، فقط ریپوزیتوری رو تغییر می‌دی، نه کل پروژه رو. --- ## 🧠 سرویس: محل منطق تجاری و پردازش‌ها سرویس جاییه که "منطق تجاری" برنامه نگهداری می‌شه، یعنی: - عملیات‌ها و قوانین مربوط به پردازش داده‌ها قبل از رفتن به دیتابیس یا نمایش در ویو. - پیاده‌سازی جریان‌هایی مثل "ثبت‌نام با اعتبارسنجی"، "محاسبه نمره از داده‌های دانش‌آموز"، یا "ارسال ایمیل بعد از ثبت". - جلوگیری از درهم‌ریختگی کنترلر: کنترلر فقط وظیفه‌ی دریافت درخواست و ارسال پاسخ داره، نه پردازش‌ها. --- ## 🔗 چرا این دو لایه کنار هم؟ وقتی سرویس و ریپوزیتوری رو با هم داشته باشی: - کدت منظم‌تر، قابل نگهداری‌تر و قابل توسعه‌تر می‌شه. - تست کردن اجزای مختلف خیلی ساده‌تر می‌شه. - پروژه‌ت ساختار حرفه‌ای پیدا می‌کنه و برای پروژه‌های واقعی آمادگی بیشتری داره. - هر بخش از برنامه فقط نقش خودش رو ایفا می‌کنه (اصل Single Responsibility).
جمعه بعدی قراره یه همچین پروژه فروشگاه را بنویسم
ShopProject/ ├── Areas/ │ ├── Account/ │ │ ├── Controllers/ │ │ │ └── AccountController.cs │ │ ├── Models/ │ │ │ ├── RegisterViewModel.cs │ │ │ └── LoginViewModel.cs │ │ └── Views/ │ │ ├── Register.cshtml │ │ └── Login.cshtml │ │ ├── Admin/ │ │ ├── Controllers/ │ │ │ ├── ProductController.cs │ │ │ ├── GroupController.cs │ │ │ └── PurchaseReportController.cs │ │ ├── Models/ │ │ │ ├── Product.cs │ │ │ ├── Category.cs │ │ │ ├── Group.cs │ │ │ └── PurchaseReport.cs │ │ └── Views/ │ │ ├── Product/ │ │ ├── Group/ │ │ └── PurchaseReport/ │ ├── Controllers/ │ ├── HomeController.cs │ ├── ProductController.cs │ ├── GroupController.cs │ ├── SearchController.cs │ └── CartController.cs │ ├── Models/ │ ├── Product.cs │ ├── Category.cs │ ├── CartItem.cs │ ├── Order.cs │ └── Slide.cs │ ├── ViewModels/ │ ├── HomePageViewModel.cs │ ├── ProductDetailsViewModel.cs │ ├── SearchViewModel.cs │ └── CartSummaryViewModel.cs │ ├── Services/ │ ├── Interfaces/ │ │ ├── IProductService.cs │ │ ├── IGroupService.cs │ │ └── ICartService.cs │ └── Implementations/ │ ├── ProductService.cs │ ├── GroupService.cs │ └── CartService.cs │ ├── Repositories/ │ ├── Interfaces/ │ │ ├── IProductRepository.cs │ │ ├── IGroupRepository.cs │ │ └── IOrderRepository.cs │ └── Implementations/ │ ├── ProductRepository.cs │ ├── GroupRepository.cs │ └── OrderRepository.cs │ ├── Views/ │ ├── Shared/ │ │ └── _Layout.cshtml │ ├── Home/ │ │ ├── Index.cshtml │ │ ├── GroupSection.cshtml │ │ ├── Search.cshtml │ ├── Product/ │ │ └── Details.cshtml │ └── Cart/ │ ├── Index.cshtml │ └── Checkout.cshtml │ ├── wwwroot/ │ ├── Images/ │ │ ├── Products/ │ │ ├── Slides/ │ │ └── Banners/ │ ├── css/ │ └── js/ │ ├── Data/ │ └── AppDbContext.cs │ ├── appsettings.json └── Program.cs
🏗️ ساختار معماری پروژه فروشگاه 📦 ساختار مدل‌ها - مدل‌های عمومی مثل User, Product, Order, Category → در پوشه کلی Models/ - مدل‌های فرم‌محور یا اختصاصی (مثل LoginViewModel, SearchFormViewModel) → داخل Area خودشون 📁 ساختار پوشه‌ها (پیشنهادی) - Models/, wwwroot/Images/Products/ - Areas/Account/Controllers, Views, Models ← برای مدیریت حساب کاربری - Areas/Admin/Controllers, Views, Models ← برای مدیریت محصولات و گروه‌ها --- 🔧 بخش‌های عملیاتی پروژه 1. مدیریت حساب کاربری (Account Area) - فرم ثبت‌نام با: - نام، نام کاربری، ایمیل، پسورد - صفحه ورود (Login) - جلوگیری از مشاهده جزئیات محصول قبل از لاگین - انتقال به صفحه جزئیات محصول بعد از ورود --- 2. مدیریت محصول (Product Area) - افزودن محصول با: - نام، قیمت، تخفیف، تصویر اختیاری - ویرایش و حذف محصول - اتصال محصول به گروه‌ها --- 3. مدیریت گروه‌ها - افزودن گروه جدید - حذف گروه - مدیریت محصولات گروهی --- 4. مدیریت صفحه اصلی - افزودن آیتم‌های ویژه و اسلاید - بارگذاری تصویر (اختیاری) - نمایش ۵ محصول اول از کل فروشگاه - دکمه "محصولات بیشتر" → صفحه مجزای لیست کامل محصولات --- 5. نمایش گروه‌ها در صفحه اصلی - نمایش ۵ محصول اول هر گروه - دکمه "محصولات بیشتر" برای هر گروه - صفحه جدا برای مشاهده تمام محصولات آن گروه --- 6. جستجو - فرم جستجو در Layout صفحه اصلی - نمایش نتایج در صفحه جداگانه --- 7. صفحه جزئیات محصول - فقط بعد از ورود قابل مشاهده - نمایش کامل جزئیات محصول مثل قیمت، تصویر، توضیحات --- 8. سبد خرید - دکمه سبد خرید در Layout با: - تعداد محصولات - مجموع قیمت - صفحه جداگانه: - حذف آیتم‌ها - دکمه "تکمیل خرید" - بعد از خرید: - ثبت در لیست خریدهای مدیریت - خالی شدن سبد خرید --- 🧾 لیست ثبت خرید - مشاهده لیست خریدهای انجام‌شده توسط کاربران - با تاریخ، مبلغ و جزئیات آیتم‌ها
سلام دوستان عزیز 👋 هفته گذشته قول داده بودم که فروشگاه برنامه‌نویسی رو تا این هفته بسازم. با اینکه تمام تلاشم رو کردم، ولی واقعیت اینه که بعضی بخش‌ها به زمان بیشتری نیاز دارن تا کامل و بدون نقص آماده بشن. ✅ پروژه در حال پیشرفته و با دقت و جزئیات داره جلو می‌ره ⏳ یکم تأخیر دارم، اما قول می‌دم نتیجه‌ای ارزشمند و کاربردی تحویل بدم از صبوری‌تون ممنونم ❤️ به‌زودی با آپدیت‌های جدید و بخش‌هایی از فرایند طراحی در خدمتتون هستم در ضمن، خوشحال می‌شم نظرات و پیشنهاداتتون رو برای بهتر شدن پروژه دریافت کنم 💬
کوکی_ها در ASP_NET Core MVC.mp3
زمان: حجم: 1.5M
کوکی در ASP.Net Core MVC ساخته شده از هوش مصنوعی 🟢 بخش اول: کوکی چیه؟ کوکی‌ها فایل‌های کوچیکی هستن که مرورگر کاربر ذخیره می‌کنه تا اطلاعاتی مثل نام کاربری، تنظیمات یا وضعیت ورود رو نگه‌داری کنه. مثلاً وقتی وارد یه سایت می‌شی و دفعه‌ی بعد خوش‌آمدگویی می‌بینی، اون اطلاعات از کوکی خونده شده. 🟡 بخش دوم: ساخت کوکی در ASP.NET Core برای ساخت کوکی از کد زیر استفاده می‌کنیم:
csharp
Response.Cookies.Append("username", "Alireza", new CookieOptions {
    Expires = DateTimeOffset.Now.AddDays(7),
    HttpOnly = true,
    Secure = true
});
اینجا یه کوکی به نام username با مقدار Alireza ساخته می‌شه که تا ۷ روز اعتبار داره و فقط از طریق سرور قابل دسترسیه. 🔵 بخش سوم: خواندن کوکی برای خوندن کوکی از این کد استفاده می‌کنیم:
csharp
var username = Request.Cookies["username"];
اگه کوکی وجود داشته باشه، مقدارش برمی‌گرده. اگه نه، باید بررسی کنیم که خطا نداشته باشیم. 🔴 بخش چهارم: امنیت کوکی‌ها کوکی‌ها می‌تونن هدف حملات باشن، پس باید از HttpOnly و Secure استفاده کنیم. همچنین می‌تونیم اطلاعات حساس رو رمزنگاری کنیم یا از توکن استفاده کنیم. 🟣 بخش پنجم: کوکی در احراز هویت در ASP.NET Core، سیستم Identity از کوکی برای نگهداری وضعیت ورود استفاده می‌کنه. وقتی کاربر وارد می‌شه، یه کوکی حاوی اطلاعات رمزنگاری‌شده براش ساخته می‌شه که تا زمان خروج معتبره.
Middleware در ASP_NET Core_ کنترل جریان درخواست_ها.mp3
زمان: حجم: 1.8M
Middleware در ASP_NET Core_ کنترل جریان درخواست_ها ساخته شده از هوش مصنوعی
🎙️ پادکست: Middleware در ASP.NET Core MVC — پشت‌صحنه‌ی کنترل درخواست‌ها سلام! خوش اومدی به قسمت امروز پادکست ما، جایی که می‌خوایم پرده از یکی از مهم‌ترین مفاهیم پشت‌صحنه‌ی اپلیکیشن‌های ASP.NET Core برداریم: Middleware. اگه تا حالا از خودت پرسیدی که وقتی کاربر یه درخواست به سایت می‌فرسته، چه اتفاقی می‌افته قبل از اینکه صفحه‌ای نمایش داده بشه، این قسمت مخصوص توئه! --- 🟢 بخش اول: Middleware یعنی چی؟ Middleware یا «میان‌افزار»، قطعه‌ای از نرم‌افزار در ASP.NET Core هست که در مسیر درخواست و پاسخ قرار می‌گیره. هر درخواست HTTP که وارد اپلیکیشن می‌شه، از یک زنجیره‌ی Middleware عبور می‌کنه تا به مقصد نهایی خودش برسه—مثلاً یه کنترلر یا یه فایل استاتیک. هر Middleware می‌تونه: - قبل از رسیدن درخواست به مرحله بعدی، کاری انجام بده - بعد از برگشت پاسخ، عملیات خاصی انجام بده - تصمیم بگیره که آیا درخواست رو به مرحله‌ی بعدی بفرسته یا نه --- 🟡 بخش دوم: چرا Middleware مهمه؟ Middleware ‌ها مثل نگهبان‌هایی هستن که دروازه‌های مختلف اپلیکیشن رو کنترل می‌کنن. مثلاً: - بررسی احراز هویت کاربر - ثبت لاگ‌ها و خطاها - فشرده‌سازی پاسخ‌ها - مدیریت فایل‌های استاتیک - هندل کردن خطاهای عمومی بدون Middleware، اپلیکیشن نمی‌تونه به‌درستی درخواست‌ها رو مدیریت کنه یا امنیت و کارایی مناسبی داشته باشه. --- 🔵 بخش سوم: ساختار Pipeline در ASP.NET Core در ASP.NET Core، درخواست‌ها از یک pipeline عبور می‌کنن که شامل چند Middleware پشت‌سر‌همه. ترتیب این Middlewareها خیلی مهمه—مثلاً Middleware مربوط به هندل کردن خطا باید اول باشه تا بتونه خطاهای بعدی رو بگیره. مثال ساده:
csharp
app.UseMiddleware<LoggingMiddleware>();
app.UseMiddleware<AuthenticationMiddleware>();
app.UseMiddleware<RoutingMiddleware>();
هر کدوم از این‌ها می‌تونن قبل و بعد از مرحله‌ی بعدی عملیات انجام بدن. --- 🔴 بخش چهارم: ساخت Middleware سفارشی می‌تونی خودت یه Middleware بسازی! مثلاً برای ثبت زمان اجرای درخواست‌ها:
csharp
public class TimerMiddleware {
    private readonly RequestDelegate _next;

    public TimerMiddleware(RequestDelegate next) {
        _next = next;
    }

    public async Task InvokeAsync(HttpContext context) {
        var start = DateTime.Now;
        await _next(context);
        var end = DateTime.Now;
        Console.WriteLine($"Request took: {(end - start).TotalMilliseconds} ms");
    }
}
و در Startup.cs یا Program:
csharp
app.UseMiddleware<TimerMiddleware>();
--- 🟣 بخش پنجم: Middleware‌های معروف در ASP.NET Core - UseStaticFiles – برای ارائه فایل‌های CSS، JS، تصاویر - UseRouting – برای تعیین مسیر کنترلرها - UseAuthentication – برای بررسی ورود کاربر - UseAuthorization – برای بررسی سطح دسترسی - UseEndpoints – برای اتصال مسیرها به کنترلرها --- 🟠 بخش ششم: تفاوت Use، Run و Map - Use: می‌تونه قبل و بعد از مرحله‌ی بعدی عملیات انجام بده - Run: آخرین مرحله‌ست و بعدش چیزی اجرا نمی‌شه (Terminal Middleware) - Map: برای مسیرهای خاص استفاده می‌شه، مثل app.Map("/admin", ...) --- 🎯 جمع‌بندی Middleware قلب تپنده‌ی ASP.NET Core MVC هست. با درک درستش، می‌تونی اپلیکیشن‌هایی بسازی که هم امن باشن، هم سریع، هم قابل نگهداری. حالا که فهمیدی هر درخواست از چه مسیری عبور می‌کنه، می‌تونی کنترل بیشتری روی رفتار اپلیکیشن داشته باشی.
مدیریت خطا و گزارش_گیری در ASP_NET Core .mp3
زمان: حجم: 2.1M
مدیریت خطا و گزارش گیری در ASP.Net Core ساخته شده از هوش مصنوعی
پروژه ASP.Net Core MVC (وب و سی شارپ)
مدیریت خطا و گزارش گیری در ASP.Net Core ساخته شده از هوش مصنوعی
پادکست «در دل خطاها: مدیریت و گزارش در ASP.NET Core» رو برات آماده کردم. هر قسمت طوری طراحی شده که هم آموزشی باشه و هم شنونده رو با داستان‌پردازی و مثال‌های واقعی جذب کنه: --- 🎙️ قسمت اول: مقدمه‌ای بر خطاها و اهمیت مدیریت آن‌ها > «وقتی صحبت از برنامه‌نویسی می‌شه، خطاها جزو جدانشدنی ماجرا هستن. ولی خطاهایی که کنترل نمی‌شن، مثل سیاه‌چاله‌ای هستن که پروژه رو می‌بلعه!» - تعریف خطا، هشدار و وضعیت سیستم - تأثیر خطاهای مدیریت‌نشده روی تجربه‌ی کاربر و امنیت - تفاوت بین Exception، Warning و وضعیت‌های منطقی مثل Timeout - مقدمه‌ای بر Error Handling در ASP.NET Core --- ⚙️ قسمت دوم: روش‌های مدیریت خطا در ASP.NET Core > «ASP.NET Core به‌طور ذاتی ابزارهای هوشمندی برای مقابله با خطاها داره. فقط باید بلد باشیم چطور ازشون استفاده کنیم.» - معرفی Middleware مدیریت خطا با UseExceptionHandler - استفاده از Exception Filters در کنترلرها - صفحات خطای سفارشی با UseStatusCodePages - معرفی الگوهایی مثل Try-Catch در متدها و سرویس‌ها --- 🧾 قسمت سوم: لاگ‌گیری و گزارش‌گیری > «وقتی برنامه به‌درستی لاگ‌گیری بشه، مثل اینه که یه جعبه‌ی سیاه توی هواپیما داریم. همه‌چی رو می‌تونیم ردیابی کنیم.» - معرفی ابزارهای لاگ مثل Serilog، NLog و Log4Net - ساختار لاگ‌ها: اطلاعات، زمان، خطا، Stack Trace - نوشتن لاگ به فایل، دیتابیس یا سرویس ابری - تفاوت لاگ‌های Debug، Info، Warning و Error --- 🚨 قسمت چهارم: هشداردهی و مانیتورینگ > «وقتی یه خطا رخ می‌ده، باید کسی باخبر بشه. چه بهتر که خود سیستم اطلاع بده، نه اینکه کاربر با عصبانیت تماس بگیره!» - مفهوم نظارت بر عملکرد و منابع - ابزارهایی مثل Application Insights، Prometheus، Grafana - تعریف Alert برای CPU، Memory، خطاهای ۵۰۰ یا Timeout - ارسال هشدار با ایمیل، SMS یا پیام در چت کاری --- 🔐 قسمت پنجم: گزارش‌های امنیتی و لاگ‌های ممیزی > «امنیت فقط درباره‌ی رمز عبور نیست؛ بلکه درباره‌ی ثبت تمام اقدامات حساسه.» - مفهوم Audit Log و اهمیتش در پروژه‌های سازمانی - ثبت فعالیت‌های حیاتی: ورود/خروج، تغییر رمز، حذف داده - بررسی دسترسی‌های مشکوک و فعالیت‌های خطرناک - حفظ حریم خصوصی در کنار ثبت داده‌ها --- 🧪 قسمت ششم: تست و شبیه‌سازی خطاها > «اگه فقط تو حالت عادی تست کنیم، با اولین خطای واقعی ممکنه همه‌چی بپاشه. پس باید با خطاها آشنا بشیم قبل از اینکه اتفاق بیفتن.» - استفاده از Unit Test برای بررسی Exceptions در متدها - Integration Test برای تست سناریوهای واقعی مثل خراب شدن دیتابیس - شبیه‌سازی Timeout، قطع ارتباط، و خطاهای API - ابزارهای تست مثل xUnit، Moq و Postman برای شبیه‌سازی خطاها
820.6K حجم رسانه بالاست
مشاهده در ایتا
شرمنده من پروژه بزرگ برداشتم و نتوانستم با کمک هوش مصنوعی پروژه را تکمیل کنم من را ببخشید پروژه ناقص ماند و کار که می روم سرم شلوغه وقت نمیکنم تکمل کنم