IdentityServer از زمان ارائهی نگارش 5 آن دیگر رایگان نیست و پیشتر
مایکروسافت از نگارش 4 آن در قالبهای استاندارد پروژههای Blazor استفاده
کرده بود. نگارش قبلی آن تنها در پروژههای NET 5x. پشتیبانی خواهد شد.
نگارش 5 آن در پروژههای NET 6x. به همراه ذکر دقیق مجوز آن هنوز هم حضور
خواهد داشت. از نگارش 7 دات نت، فکر دیگری خواهند کرد.
نظرات مطالب
ASP.NET MVC #23
- .* نیست. داخل پرانتر نوشتم. درستش *. است.
- اگر از متدهای توکار خود ASP.NET MVC برای تولید لینکها استفاده کنید، این لینکها صرفا بر مبنای اطلاعات مسیریابی تعریف شده تولید میشوند.
- باید به application pool برنامه مراجعه کنید.
- روی 2003 خیر. پس از آن به صورت پیش فرض وجود دارد.
- مراجعه کنید به application pool برنامه. احتمالا روی دات نت 2 است؛ بجای 4.
توضیحات بیشتر در اینجا
- یک اکشن متد ساده برای صفحهی Home طراحی کنید.
- اگر از متدهای توکار خود ASP.NET MVC برای تولید لینکها استفاده کنید، این لینکها صرفا بر مبنای اطلاعات مسیریابی تعریف شده تولید میشوند.
- باید به application pool برنامه مراجعه کنید.
- روی 2003 خیر. پس از آن به صورت پیش فرض وجود دارد.
- مراجعه کنید به application pool برنامه. احتمالا روی دات نت 2 است؛ بجای 4.
توضیحات بیشتر در اینجا
- یک اکشن متد ساده برای صفحهی Home طراحی کنید.
نظرات مطالب
نحوه ارتقاء برنامههای موجود MVC3 به MVC4
- اگر به اون خط ایراد گرفته یعنی تنظیمات IIS آن روی ASP.NET 4.0 و کلا دات نت 4 نیست: (^). هاست باید این مساله را بررسی و تنظیم کند (بررسی هر سه نکته یاد شده در مقاله «نکات نصب برنامههای ASP.NET 4.0 بر روی IIS 6» الزامی است).
- به علاوه MVC4 باید روی هاست و همچنین روی کامپیوتر توسعه نصب باشد.
- به علاوه MVC4 باید روی هاست و همچنین روی کامپیوتر توسعه نصب باشد.
نظرات مطالب
سرعت ایجاد اشیاء CLR
یک مطلب دیگر رو هم اضافه کنم. ThreadPool در دات نت 4 به 64 logical processors محدود شده. به عبارتی مثلا حین استفاده از Parallel.For/ForEach این محدودیت وجود دارد و پس از آزاد شدن یک task ، task بعدی (پس از 64 البته) وارد عمل خواهد شد و همینطور الی آخر
+
ویندوز سرور 2008 نگارش R2 فقط تا 256 logical processors رو پشتیبانی میکنه.
+
ویندوز سرور 2008 نگارش R2 فقط تا 256 logical processors رو پشتیبانی میکنه.
اولین کتاب، کتاب Entity Framework آقای بهروز راد بود و از انتشارات پندار پارس مربوط به زمانی که این سایت اسکین مشکی معروف خودش و داشت و خوب البته در مورد CodeFirst مطلب نداشت.
دومین کتاب باز هم از آقای راد بود با موضوع ASP.NET MVC 4 و از انتشارات پندارپارس ولی متاسفانه نتونستم ارتباط خوبی باهاش برقرار کنم تا اینکه سری آموزشش در این سایت شروع شد.
وباید بگم اینها تنها کتاب هایی بود که در طول عمرم خریداری کردم چه در زمینه دات نت و چه در هر زمینه ای :(
مثال زیر را به عنوانی نمونهای از کاربرد LINQ to XML برای خواندن فیدهای RSS که اساسا به فرمت XML هستند میتوان ارائه داد.
ابتدا کد کامل مثال را در نظر بگیرید:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;
namespace LinqToRSS
{
public static class LanguageExtender
{
public static string SafeValue(this XElement input)
{
return (input == null) ? string.Empty : input.Value;
}
public static DateTime SafeDateValue(this XElement input)
{
return (input == null) ? DateTime.MinValue : DateTime.Parse(input.Value);
}
}
public class RssEntry
{
public string Title { set; get; }
public string Description { set; get; }
public string Link { set; get; }
public DateTime PublicationDate { set; get; }
public string Author { set; get; }
public string BlogName { set; get; }
public string BlogAddress { set; get; }
}
public class Rss
{
static XElement selectDate(XElement date1, XElement date2)
{
return date1 ?? date2;
}
public static List<RssEntry> GetEntries(string feedUrl)
{
//applying namespace in an XElement
XName xn = XName.Get("{http://purl.org/dc/elements/1.1/}creator");//{namespace}root
XName xn2 = XName.Get("{http://purl.org/dc/elements/1.1/}date");
var feed = XDocument.Load(feedUrl);
if (feed.Root == null) return null;
var items = feed.Root.Element("channel").Elements("item");
var feedQuery =
from item in items
select new RssEntry
{
Title = item.Element("title").SafeValue(),
Description = item.Element("description").SafeValue(),
Link = item.Element("link").SafeValue(),
PublicationDate =
selectDate(item.Element(xn2), item.Element("pubDate")).SafeDateValue(),
Author = item.Element(xn).SafeValue(),
BlogName = item.Parent.Element("title").SafeValue(),
BlogAddress = item.Parent.Element("link").SafeValue()
};
return feedQuery.ToList();
}
}
class Program
{
static void Main(string[] args)
{
List<RssEntry> entries = Rss.GetEntries("http://weblogs.asp.net/aspnet-team/rss.aspx");
if (entries != null)
foreach (var item in entries)
Console.WriteLine(item.Title);
Console.WriteLine("Press a key...");
Console.ReadKey();
}
}
}
توضیحات:
1- در این مثال فقط جهت سهولت بیان آن در یک صفحه، تمامی کلاسهای تعریف شده در یک فایل آورده شدند. این روش صحیح نیست و باید به ازای هر کلاس یک فایل جدا در نظر گرفته شود.
2- کلاس LanguageExtender از قابلیت extension methods سی شارپ 3 استفاده میکند. به این صورت کلاس XElement دات نت بسط یافته و دو متد به آن اضافه میشود که به سادگی در کدهای خود میتوان از آنها استفاده کرد. هدف آن هم بررسی نال بودن یک آیتم دریافتی و ارائهی حاصلی امن برای این مورد است.
3- کلاس RssEntry به جهت استفاده در خروجی کوئری LINQ تعریف شد. میخواهیم خروجی نهایی، یک لیست جنریک از نوع RssEntry باشد.
4- متد اصلی برنامه، GetEntries است. این متد آدرس اینترنتی یک فید را دریافت کرده و پس از آنالیز، آنرا به صورت یک لیست بر میگرداند.
<?xml version="1.0" encoding="UTF-8" ?>
<?xml-stylesheet type="text/xsl" href="http://weblogs.asp.net/utility/FeedStylesheets/rss.xsl" media="screen"?>
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:wfw="http://wellformedweb.org/CommentAPI/">
<channel>
<title>Latest Microsoft Blogs</title>
<link>http://weblogs.asp.net/aspnet-team/default.aspx</link>
<description />
<dc:language>en</dc:language>
<generator>CommunityServer 2007 SP1 (Build: 20510.895)</generator>
<item>
<title>Comments on my recent benchmarks.</title>
<link>http://misfitgeek.com/blog/aspnet/comments-on-my-recent-benchmarks/</link>
<pubDate>Mon, 10 Aug 2009 23:33:59 GMT</pubDate>
<guid isPermaLink="false">c06e2b9d-981a-45b4-a55f-ab0d8bbfdc1c:7166225</guid>
<dc:creator>Misfit Geek: msft</dc:creator>
<slash:comments>0</slash:comments>
<wfw:commentRss xmlns:wfw="http://wellformedweb.org/CommentAPI/">http://weblogs.asp.net/aspnet-team/rsscomments.aspx?PostID=7166225</wfw:commentRss>
<comments>http://misfitgeek.com/blog/aspnet/comments-on-my-recent-benchmarks/#comments</comments>
<description>Overall I’ve been pretty impressed ...</description>
<category domain="http://weblogs.asp.net/aspnet-team/archive/tags/ASP.NET/default.aspx">ASP.NET</category>
</item>
</channel>
</rss>
var items = feed.Root.Element("channel").Elements("item");
XName.Get("{mynamespace}root");
//or
XName.Get("root", "mynamespace");
این روزها زیرنویسهای فارسی فیلمهای روز دنیا را راحت میشود در اینترنت یافت، اما مشکلات زیادی هم به همراه این نوع فایلها وجود دارند:
- گاها با فیلم دریافت شده هماهنگ نیستند.
- عموما با فرمت windows-1256 تهیه میشوند که برای استفاده از آنها در سیستمهای مختلف بهتر است به UTF8 تبدیل شوند.
- اکثر برنامههای موجود برای کار با زیر نویسها و ویرایش آنها، درکی از یونیکد ندارند.
- عموما نیاز است جهت استفاده از آنها در یک جمع، تعدادی از سطور آنها را با حفظ شماره بندی فایل، حذف کرد!
و ...
به همین جهت نیاز به یک برنامهی جمع و جور جهت کار با زیر نویسها داشتم که نتیجهی آن تهیهی برنامهی زیر شد:
الف) تغییر encoding فایل دریافتی به UTF-8
هنگام گشودن اکثر فایلهای زیر نویس فارسی با تصویر زیر روبرو خواهید شد:
برای تبدیل آن به فرمت یونیکد تنها کافی است بر روی دکمهی To UTF-8 کلیک کنید. در این حالت نتیجه به صورت زیر خواهد بود:
ب) هماهنگ سازی زیر نویس با فیلم دریافتی
ممکن است دیالوگهای زیر نویس دریافتی شما به اندازهی مدت زمان خاصی، از دیالوگهای فیلم در حال پخش، عقبتر یا جلوتر باشند. در این حالت ابتدا باید این مدت زمان را با گوش فرا دادن به ابتدای فیلم و مقایسهی آن با اولین شمارهی زیرنویس، پیدا کنید. مثلا پس از بررسی متوجه شدهاید که به کلیه زمانهای زیرنویس جاری باید 7 ثانیه اضافه گردد. اینکار را مطابق تصویر ذیل میتوان انجام داد:
ج) یکی کردن زمانهای دو زیر نویس با هم
گاهی از اوقات مشکلات زمانی یک زیرنویس وخیمتر از مورد ب است. به این معنا که شمارههای مختلف آن، زمانهای کاملا بیربطی داشته و به صورت هماهنگ، قابل افزایش یا کاهش نیستند. در این حالت ابتدا زیر نویس مورد نظر را در برنامه باز کنید. سپس یک زیر نویس خوب انگلیسی هماهنگ با فیلم را نیز پیدا کنید و از طریق دکمهی Merge times به برنامه معرفی نمائید. در این حالت به صورت خودکار زمانهای صحیح از زیر نویس دوم به زیر نویس اول منتقل خواهند شد.
د) یکی کردن دو فایل زیر نویس با هم
ممکن است فیلم دریافتی تنها از یک فایل تشکیل شده باشد، اما شما فقط توانستهاید زیر نویس مرتبط با نگارش دو سی دی این فیلم را پیدا کنید. بنابراین نیاز است تا این دو فایل زیر نویس یکی شوند با این شرط که زمانهای سی دی دوم از انتهای سی دی اول در فایل نهایی یکی شدهی تولیدی شروع گردد.
برای این منظور ابتدا فایل زیرنویس سی دی اول را در برنامه باز کرده و سپس به گزینهی join files در برنامه مراجعه کنید. در اینجا ابتدا مسیر فایل زیرنویس سی دی 2 را مشخص نمائید. برنامه سعی خواهد کرد تا زمان آغاز قسمت دوم را بر اساس آخرین زمان سی دی اول و اولین زمان سی دی دوم حدس بزند و نمایش دهد. یا میتوانید این مقدار پیش فرض را پذیرفته و بر روی دکمهی join کلیک نمائید و یا امکان تغییر دستی آن هم میسر است.
ه) حذف و یا ویرایش ردیفها
به دلایل نامشخصی اشخاصی که سعی در ترجمهی زیرنویسها میکنند عموما علاقمندند که به متن اصلی وفادار بمانند. به همین دلیل نیاز به جرح و تعدیل زیرنویسهای تهیه شده برای نمایش در یک جمع خانوادگی وجود دارد. گزینهی جستجوی موجود در بالای ردیفهای زیرنویس باز شده در برنامه، امکان نمایش ردیفهایی را که حاوی متن وارد شده است، به صورت خودکار دارد.
در این حالت اگر نیاز است سطری حذف شود، آنرا انتخاب نموده و بر روی دکمهی Delete row کلیک نمائید. در این حالت علاوه بر حذف ردیف، کلیه شمارههای موجود در زیر نویس نیز به صورت خودکار مجددا تولید و مرتب خواهند شد. (کلیک راست بر روی هر ردیف نیز این گزینه را نمایش میدهد)
یا اگر مشغول به ویرایش متنی شدید، پس از ویرایش، کلیک کردن بر روی دکمهی Save را فراموش نکنید (در حالت حذف نیازی به اینکار نیست).
ز) پیدا کردن زیرنویس یک فایل بر اساس امضای دیجیتال آن
سایت opensubtitles.org یک API را جهت پیدا کردن زیرنویسی مطابق با هش یک فایل ویدیویی ارائه داده است، که در برنامهی جاری، کلاینتی برای آن تهیه شده است:
فقط کافی است فایل ویدیویی خود را در این قسمت انتخاب نمائید. برنامه هش فایل را محاسبه کرده و سپس با کمک سرویس XML-RPC سایت opensubtitles.org سعی در یافتن زیرنویس هماهنگ با آن خواهد کرد. در اینجا دیگر مهم نیست نام فایل انتخابی چیست؛ امضای دیجیتال آن مهم است. برای دریافت موارد مورد نظر، ابتدا آنها را تیک زده و سپس بر روی دکمهی دریافت کلیک کنید. کلیک راست بر روی ردیف مورد نظر نیز این امکان دریافت را لحاظ کرده است.
همچنین قسمتی هم برای آپلود زیرنویس به این سایت پیش بینی شده است (لطفا مصرف کنندهی صرف یا به قولی لیچر نباشید!)
در اینجا انتخاب فایل ویدیویی، فایل زیرنویس هماهنگ با آن و همچنین زبان زیر نویس الزامی است. از فایل ویدیویی جهت محاسبهی هش آن برای یافتن سادهتر زیرنویسها در دفعات آتی استفاده میگردد.
پیشنیاز استفاده از این برنامه، نصب دات نت فریم ورک 4 است که اگر از ویندوز 7 استفاده میکنید، جزو به روز رسانیهای اختیاری آن است و در حالت کلی نسخهی کامل 32 بیتی و 64 بیتی آن از این آدرس قابل دریافت است.
بازخوردهای دوره
تزریق خودکار وابستگیها در ASP.NET Web API به همراه رها سازی خودکار منابع IDisposable
- قرار هست از نگارش 4 آن ObjectFactory حذف شود. اطلاعات بیشتر (انتهای نظرات بحث)
- بله. وهله نهایی ایجاد شده آن از نوع DbContext است که اینترفیس IDisposable را پیاده سازی میکند.
- بله. وهله نهایی ایجاد شده آن از نوع DbContext است که اینترفیس IDisposable را پیاده سازی میکند.
نظرات مطالب
اجرای یک Script حاوی دستورات Go در سی شارپ
سلام قربان ؛
خیلی ممنون.
در استفاده از SMO در .NET 4 مشکل داشتم در نتیجه از این روش که نیازمند به Assemblyهای SMO نیست استفاده کردم.
کامنت شما را در انتهای مطلب قرار دادم.
دات نت 7 به همراه یک Regex Source Generator توکار است که به کمک آن میتوان عبارات باقاعده را تبدیل به کدهای سیشارپ معادل آنها کرد و پیش از اجرای برنامه، آنها را کامپایل و جزئی از خروجی نهایی نمود. این روش نسبت به روش پیشین تولید کدهای معادل عبارات باقاعده در زمان اجرای برنامه، از مزایای زیر برخوردار است:
- اجرای یک عبارت باقاعده سریعتر خواهد شد. در این حالت دیگر نیازی نیست تا در حین اجرای برنامه، منتظر پردازش و تولید کدهای سیشارپ معادل آن شد.
- کدهای تولیدی پیش از کامپایل برنامه، از مزایای بهینه سازی ویژهای برخوردار میشوند که پیشتر تنها با ذکر پرچم RegexOptions.Compiled در زمان اجرا میسر میشدند.
- بعضی از سکوهای کاری مانند iOS، از تولید کد در زمان اجرای برنامه پشتیبانی نمیکنند. در این حالت یک تولید کنندهی کد سیشارپ معادل در زمان کامپایل برنامه، حداکثر کارآیی را برای اینگونه سکوهای کاری به ارمغان میآورد.
- امکان مطالعهی کدهای سیشارپ تولیدی معادل یک عبارت باقاعده، برای اولین بار پیش از اجرای برنامه میسر شدهاست.
- کدهای تولیدی معادل، قابلیت دیباگ دارند.
- میتوان با مطالعهی این کدها، نکات جدیدی را فرا گرفت!
چه عبارت باقاعدهای را میتوان به Regex source generators تبدیل کرد؟
برای استفاده از این تولید کنندهی کدهای معادل عبارات باقاعده، باید از NET 7. و C# 11 استفاده کرد. همچنین تمام پارامترهای Regex تعریف شده نیز باید ثابت باشند. برای نمونه در دو مثال زیر، در اولی، pattern ثابت است و در دومی هم pattern و هم سایر تنظیمات ذکر شده؛ بنابراین قابلیت تبدیل به روش استفاده از تولید کنندههای کد را دارند:
اما مثال زیر خیر؛ در این مثال چون pattern یک متغیر است، امکان تبدیل آن به روش تولید کنندهی خودکار کدهای معادل وجود ندارد:
روش استفاده از Regex source generators
برای تبدیل مثالهایی که عنوان شدند به نمونهی source generator، باید ابتدا یک partial method مزین شدهی به ویژگی [GeneratedRegex] را ایجاد کرد؛ برای نمونه:
سپس میتوان از این partial method، که کدهای آن به صورت خودکار تولید میشوند، در قسمتهای مختلف برنامه استفاده کرد؛ برای مثال:
اگر علاقمند بودید تا کد معادل این partial method را مشاهده کنید، بر روی آن کلیک راست کرده و گزینهی «Go to Definition» را انتخاب کنید (و یا نگه داشتن دکمهی ctrl و سپس کلیک بر روی تعریف partial متد):
همچنین ابزارهای refactoring خودکاری نیز در IDEهای جدید برای این منظور تعبیه شدهاند تا بتوان به سرعت کدهای قدیمی را به روش source generators تبدیل کرد:
و partial method تولیدی، اینبار به همراه توضیح کامل نحوهی عملکرد عبارت باقاعدهی مورد استفاده نیز هست:
- اجرای یک عبارت باقاعده سریعتر خواهد شد. در این حالت دیگر نیازی نیست تا در حین اجرای برنامه، منتظر پردازش و تولید کدهای سیشارپ معادل آن شد.
- کدهای تولیدی پیش از کامپایل برنامه، از مزایای بهینه سازی ویژهای برخوردار میشوند که پیشتر تنها با ذکر پرچم RegexOptions.Compiled در زمان اجرا میسر میشدند.
- بعضی از سکوهای کاری مانند iOS، از تولید کد در زمان اجرای برنامه پشتیبانی نمیکنند. در این حالت یک تولید کنندهی کد سیشارپ معادل در زمان کامپایل برنامه، حداکثر کارآیی را برای اینگونه سکوهای کاری به ارمغان میآورد.
- امکان مطالعهی کدهای سیشارپ تولیدی معادل یک عبارت باقاعده، برای اولین بار پیش از اجرای برنامه میسر شدهاست.
- کدهای تولیدی معادل، قابلیت دیباگ دارند.
- میتوان با مطالعهی این کدها، نکات جدیدی را فرا گرفت!
چه عبارت باقاعدهای را میتوان به Regex source generators تبدیل کرد؟
برای استفاده از این تولید کنندهی کدهای معادل عبارات باقاعده، باید از NET 7. و C# 11 استفاده کرد. همچنین تمام پارامترهای Regex تعریف شده نیز باید ثابت باشند. برای نمونه در دو مثال زیر، در اولی، pattern ثابت است و در دومی هم pattern و هم سایر تنظیمات ذکر شده؛ بنابراین قابلیت تبدیل به روش استفاده از تولید کنندههای کد را دارند:
if(new Regex("[a-z]+").IsMatch("abc")){} if(Regex.IsMatch(value, "[a-z]+", RegexOptions.CultureInvariant, TimeSpan.FromSeconds(1))){}
public static bool Match(string value, string pattern) { return Regex.IsMatch(value, pattern); }
روش استفاده از Regex source generators
برای تبدیل مثالهایی که عنوان شدند به نمونهی source generator، باید ابتدا یک partial method مزین شدهی به ویژگی [GeneratedRegex] را ایجاد کرد؛ برای نمونه:
public partial class MyRegexes { [GeneratedRegex("^[a-z]+$", RegexOptions.CultureInvariant, 1000)] public static partial Regex LowercaseLettersRegex(); }
public class RegexTests { public static bool IsLowercase(string value) => MyRegexes.LowercaseLettersRegex().IsMatch(value); }
همچنین ابزارهای refactoring خودکاری نیز در IDEهای جدید برای این منظور تعبیه شدهاند تا بتوان به سرعت کدهای قدیمی را به روش source generators تبدیل کرد:
و partial method تولیدی، اینبار به همراه توضیح کامل نحوهی عملکرد عبارت باقاعدهی مورد استفاده نیز هست: