‫۳ سال و ۷ ماه قبل، چهارشنبه ۱۵ بهمن ۱۳۹۹، ساعت ۲۳:۴۲
قبل از اینکه از دامنه جدید استفاده کنند
... قرار نبود که اصلا تغییری باشد؛ مجبور شدیم (سطر اول مطلب جاری و یا اینجا) ... + به تمام کاربران ثبت نام شده‌ی سایت، ایمیل ارسال شده.
‫۳ سال و ۷ ماه قبل، چهارشنبه ۱۵ بهمن ۱۳۹۹، ساعت ۱۴:۲۸
- نظرات و مطالب « بررسی فریم ورک Logging» و « فعال سازی صفحات مخصوص توسعه دهنده‌ها » را مطالعه کنید. 
- اگر برنامه را از طریق dotnet run و یا dotnet watch run اجرا می‌کنید، در صفحه‌ی کنسول ظاهر شده، خطاها هم لاگ می‌شوند. یا اگر با ویژوال استودیو آن‌را اجرا می‌کنید، در برگه‌ی دیباگ آن این خطاها هم لاگ می‌شوند.

- اگر از پروژه‌ی DNT Identity استفاده می‌کنید، به همراه یک ef db logger هست که اطلاعات خطاهای رخ‌داده را در بانک اطلاعاتی ذخیره می‌کند و در قسمت لاگ‌های سیستم قابل گزارشگیری هست (منوی مدیریتی/گزارش رخ‌دادهای سیستم).
+ مطلب «کار با ASP.NET Web API» را هم در مورد ویژگی‌های FromBody و امثال آن مطالعه کنید.  
«... البته باید درنظر داشت اگر طول عمر این توکن دسترسی را برای مثال به 120 یا 2 دقیقه تنظیم کنید، پس از سپری شدن این 2 دقیقه ... هنوز هم برنامه‌ی کلاینت قادر است به Web API دسترسی داشته باشد. علت آن وجود بازه‌ی 5 دقیقه‌ای است که در طی آن، انجام این عملیات مجاز شمرده می‌شود و برای کلاینت‌هایی درنظر گرفته شده‌است که ساعت سیستم آن‌ها ممکن است اندکی با ساعت سرور IDP تفاوت داشته باشند ...» به این زمان «clock skew» هم گفته می‌شود که با خاصیت JwtValidationClockSkew قابل تنظیم است.
//...
 .AddIdentityServerAuthentication(options =>
        {
            options.JwtValidationClockSkew = TimeSpan.Zero;
‫۳ سال و ۷ ماه قبل، سه‌شنبه ۷ بهمن ۱۳۹۹، ساعت ۲۳:۳۹
یک نکته‌ی تکمیلی: یکی از دلایل رد نشدن ایمیل‌ها
چند روزی بود ایمیل‌های سایت رد نمی‌شدند. تمام موارد بررسی شدند؛ اما ایمیل‌ها در پوشه‌ی C:\Inetpub\mailroot\Queue باقی مانده و ارسال نمی‌شدند. مشخص شد که (احتمالا به دلیل نصب وصله‌های امنیتی جدید سیستم عامل)، تعداد اتصالات قابل قبول توسط SMTP Server، راسا انتخاب (SMTP Virtual Server > Properties > Delivery > Outbound Connections) و به صفر تنظیم شده بود. با لغو این مورد، مشکل برطرف شد:

‫۳ سال و ۷ ماه قبل، شنبه ۴ بهمن ۱۳۹۹، ساعت ۱۳:۱۳
تغییرات Logging در EF Core 5x

1- متد استاندارد ToQueryString، امکان دسترسی به SQL متناظر با یک کوئری را میسر کرده‌است:
var sql = ctx.Artists.Where(a => a.Name == "name 1").ToQueryString();
2- متد LogTo، دریافت خروجی از لاگ عملیات صورت گرفته‌ی توسط EF Core را ساده می‌کند:
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    => optionsBuilder.LogTo(Console.WriteLine);
که در حقیقت خلاصه شده‌ی کدهای زیر است:
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    => optionsBuilder.LogTo(message => Console.WriteLine(message));
اطلاعات بیشتر
‫۳ سال و ۷ ماه قبل، پنجشنبه ۲ بهمن ۱۳۹۹، ساعت ۱۴:۴۵
به روز رسانی نکات مطرح شده‌ی در این مطلب، بر اساس امکانات C# 8.0 به بعد

1- یک کلاس معمولی تنها می‌تواند از یک کلاس Abstract ارث بری کند ولی همان کلاس میتواند از چندین Interface ارث ببرد.
وضعیت فعلی: هنوز هم برقرار است. اما چون اینبار اینترفیس‌ها هم می‌توانند به همراه کد باشند، می‌توان به multiple inheritance از طریق اینترفیس‌ها نیز رسید. هنگامیکه پیاده سازی‌های پیش‌فرض اینترفیس‌ها فراخوانی می‌شوند، فراخوان باید نوع اینترفیس متناظر را هم دقیقا مشخص کند. این ویژگی، مشکل معروفی را به نام «diamond problem»، که در ارث بری چندگانه‌ی از کلاس‌های پایه در زبان‌های دیگر وجود دارد، حل می‌کند: زمانیکه دو یا چند کلاس پایه، متد هم نامی را داشته باشند.
 
2- یک Interface  فقط میتواند اعلان متدها و خصوصیتها را داشته باشد؛ اما یک کلاس Abstract  علاوه بر آنها میتوانید متدها و خصوصیتهایی با کدهای کامل داشته باشد.
وضعیت فعلی: دیگر اینطور نیست. اینترفیس‌ها در C# 8.0 می‌توانند به همراه «default implementation» هم باشند.


3- عناصر موجود در کلاس Abstract میتوانند مانند یک کلاس معمولی دارای سطح دسترسی باشند؛ ولی Interface‌ها فاقد این امکان هستند.
وضعیت فعلی: دیگر اینطور نیست. از زمان C# 8.0 به بعد، اعضای یک اینترفیس هم می‌توانند دارای access modifiers باشند. حالت پیش‌فرض، public است. اما اکنون اینترفیس‌ها می‌توانند دارای اعضای private هم باشند که فقط داخل همان اینترفیس قابل دسترسی هستند. این مورد برای خواناتر کردن پیاده سازی‌های پیش‌فرض متدها در اینترفیس‌ها می‌تواند مفید باشد. در اینجا امکان تعریف اعضای protected نیز میسر است.


4- وقتی شما متدی را به کلاس Abstract اضافه می‌کنید، به طور خودکار به همه زیر کلاسها اعمال می‌شود؛ اما در Interface اگر متدی اضافه کنید باید در تمام زیر کلاسها آن را اعمال کنید . 

وضعیت فعلی: دیگر اینطور نیست؛ به علت امکان تعریف «default implementation» در اینترفیس‌ها.

5- کلاس‌های Abstract مانند کلاسهای معمولی می‌توانند دارای فیلد و عناصر دیگری (مثل ثابت‌ها) باشند؛ در حالیکه یک Interface فاقد این امکان می‌باشد. همچنین کلاس abstract میتواند شامل سازنده باشد، اما اینترفیس نمیتواند.
وضعیت فعلی: هنوز هم تا حدودی برقرار است. با تغییرات زبان #C، اکنون اینترفیس‌ها می‌توانند دارای فیلدها، سازنده‌ها و تخریب‌گرهای استاتیک هم باشند. یک فیلد استاتیک، فیلدی است که مقدار آن متعلق به یک وهله‌ی خاص نیست (هنوز هم نمی‌توان instance filed در اینجا داشت) و به اشتراک گذاشته می‌شود (دقیقا مانند فیلدهای استاتیک کلاس‌ها عمل می‌کند).
‫۳ سال و ۷ ماه قبل، سه‌شنبه ۳۰ دی ۱۳۹۹، ساعت ۲۳:۱۱
کار زیادی از دست شما ساخته نیست. باید با هاست تماس بگیرید و آن‌ها باید لاگ‌های سرور را برای مشاهده‌ی خطاها بررسی کنند. دسترسی‌ها را بررسی کنند. شماره نگارش NET Core. برنامه‌ی شما را با شماره نگارش IIS Web hosting package یا همان NET Core Hosting Bundle. تطابق دهند (مهم). خودتان هم می‌توانید تا حدودی این خطاها را لاگ کنید: «بررسی خطاهای ممکن در حین راه اندازی اولیه برنامه‌های ASP.NET Core در IIS»