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
مشاهده در ایتا
دانلود
🎙️ پادکست: 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 حجم رسانه بالاست
مشاهده در ایتا
شرمنده من پروژه بزرگ برداشتم و نتوانستم با کمک هوش مصنوعی پروژه را تکمیل کنم من را ببخشید پروژه ناقص ماند و کار که می روم سرم شلوغه وقت نمیکنم تکمل کنم
MyStore.zip
حجم: 25M
پروژه کوچک فروشگاه سبد خرید دارد
ساخت_اتصال_به_SQL_Server_در_ASP.mp3
زمان: حجم: 7M
ساخت اتصال به SQL Server در ASP.Net Core MVC ساخته شده از هوش مصنوعی
شاید بعضی شما بدونید ولی این آموزش برای همه است. این آموزش، در همه جا وقتی نیاز با دیتابیس داری استفاده میشود و به صورت زنجیر یا ساعت که دقیقه و ساعت و ثانیه باهم باشد و نمیتوان یکیش را فراموش یا جا انداخت
NameApp.zip
حجم: 24.7M
این پروژه ساده را دادم برای کسی که تازه میخواهد یاد بگیرد
پروژه ASP.Net Core MVC (وب و سی شارپ)
ساخت اتصال به SQL Server در ASP.Net Core MVC ساخته شده از هوش مصنوعی
رشته اتصال، تنظیم اتصال، کانتکس، و مایگریشن در ASP.NET Core MVC --- 🎓 بخش اول: تنظیم اتصال در appsettings.json در فایل appsettings.json، رشته اتصال به دیتابیس SQL Server رو تعریف می‌کنیم: "ConnectionStrings": { "DefaultConnection": "Server=.\\SQLEXPRESS;Database=NameDb;Trusted_Connection=True;TrustServerCertificate=True" } 🔍 توضیح خط به خط: - "ConnectionStrings": بخشی برای تعریف رشته‌های اتصال به دیتابیس. - "DefaultConnection": نام دلخواه برای رشته اتصال. در کدهای بعدی از همین نام استفاده می‌کنیم. - "Server=.\\SQLEXPRESS": یعنی از SQL Server محلی (Local) با نام SQLEXPRESS استفاده کن. - "Database=NameDb": نام دیتابیسی که قراره ساخته بشه یا بهش وصل بشیم. - "Trusted_Connection=True": یعنی از اعتبار ویندوز برای اتصال استفاده کن (بدون نام کاربری و رمز). - "TrustServerCertificate=True": گواهی امنیتی سرور رو بدون بررسی دقیق قبول کن (برای راحتی در محیط توسعه). --- 🧠 بخش دوم: تعریف کانتکس (DbContext) کانتکس نماینده‌ی دیتابیس در پروژه است. در پوشه Models، کلاس زیر رو می‌سازیم: using Microsoft.EntityFrameworkCore; public class AppDbContext : DbContext { public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { } public DbSet<Person> People { get; set; } } 🔍 توضیح خط به خط: - using Microsoft.EntityFrameworkCore;: اضافه کردن کتابخانه EF Core برای کار با دیتابیس. - AppDbContext: اسم کلاس کانتکس که می‌تونه هر اسمی داشته باشه. - DbContext: کلاس پایه‌ای که EF Core برای ارتباط با دیتابیس استفاده می‌کنه. - AppDbContext(options) : base(options): سازنده‌ای که تنظیمات اتصال رو از بیرون دریافت می‌کنه. - DbSet<Person> People: جدول مجازی برای ذخیره‌ی اطلاعات افراد. اینجا فرض کردیم مدل Person شامل Name و Age هست. 📌 نکته: اگر هنوز مدل Person رو نساختی، فقط این خط رو حذف کن تا تمرکز روی اتصال باقی بمونه. --- ⚙️ بخش سوم: تنظیم در Program.cs و اجرای مایگریشن در فایل Program.cs، کانتکس رو به پروژه معرفی می‌کنیم: builder.Services.AddDbContext<AppDbContext>(options => options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection"))); 🔍 توضیح خط به خط: - builder.Services.AddDbContext<AppDbContext>: کانتکس رو به سیستم DI (تزریق وابستگی) اضافه می‌کنه. - options.UseSqlServer(...): مشخص می‌کنه که از SQL Server استفاده بشه. - builder.Configuration.GetConnectionString("DefaultConnection"): رشته اتصال رو از appsettings.json می‌خونه. ✅ حالا برای ساخت دیتابیس، از دستورهای EF Core استفاده می‌کنیم: dotnet ef migrations add InitialCreate dotnet ef database update 🔍 توضیح: - migrations add InitialCreate: یک مایگریشن جدید می‌سازه که تغییرات مدل رو آماده‌ی اعمال به دیتابیس می‌کنه. - database update: مایگریشن‌ها رو اجرا می‌کنه و دیتابیس واقعی رو می‌سازه. --- 🎯 نتیجه‌گیری با این سه مرحله: 1. رشته اتصال رو تعریف کردیم. 2. کانتکس رو ساختیم تا نماینده‌ی دیتابیس باشه. 3. تنظیمات رو در Program.cs انجام دادیم و با مایگریشن، دیتابیس رو ساختیم. اگر مدل Person شامل Name و Age باشه، جدول مربوطه ساخته می‌شه و اطلاعات در اون ذخیره می‌شن. دوست داری در قسمت بعدی، مدل Person و فرم ثبت اطلاعات رو هم بسازیم؟