در این مقاله سعی شده است به تفاوتهای Stored Procedure و Functionها در SQL Server به صورت مختصر و مفید بپردازیم: Functionها حتما باید مقدار بازگشتی داشته باشند ولی مقدار بازگشتی در *SPها به صورت اختیاری است. یک SP میتواند از صفر تا n خروجی داشته باشد. Functionها تنها میتوانند پارامترهای ورودی داشته باشند ولی SPها علاوه بر پارامترهای ورودی، میتوانند پارامتر خروجی نیز داشته باشند. Functionها میتوانند از داخل S ...
در MVC راههای متفاوتی برای ارسال اطلاعات از controller به view و در redirectها وجود دارد. در این مقاله سعی شده تفاوتهای آنها به صورت مختصر نمایش داده شود. این مقاله در حقیقت یک ترجمه آزاد از این مقاله است که امیدوارم خوب ترجمه شده باشد. ViewData : ViewData یک نوع دیکشنری ویژه است که از ViewDataDictionary ارث بری کرده است. برای ارسال اطلاعات از controller به view استفاده میشود. مدت زمان اعتبار مقادیر ...
یکی از مسائل ربز و فنی در دنیای .NET استفاده یا عدم استفاده از NGEN است. در مقاله کوتاه زیر بهترین مکانهای استفاده و عدم استفاده از آن را در چند بند خلاصه میکنم: کجا از NGEN استفاده کنیم؟ برنامه هایی که مقدار زیادی کد مدیریت شده قبل از نمایش فرم برنامه دارند. مانند برنامه Blend که مقدار زیادی کد در شروع برنامه دارد. استفاده از ngen میتواند باعث افزایش کارایی و سرعت اجرای برنامه شود فریم ورک ها، dllها و کامپوننتهای عمو ...
ممکن است کاربر بر روی سیستم خود نسخههای مختلفی از SQL Server را نصب کرده باشد. برای مثال SQL Express, SQL 2005, SQL 2008. و یا نسخه ای خاص (مثلا 2012) را چند بار روی سیستم خود نصب کرده باشد. SQL برای تفکیک این نسخهها و نصبها از مفهومی با عنوان Instance استفاده میکند. یعنی به هر نسخه نصب شده نامی یکتا میدهد تا بتوان به تفکیک به آنها دسترسی داشت.
برای اتصال به این نسخهها باید در بخش آدرس سرور، از ترکیب نام سیستم و نام ...
برای ایجاد امنیت در نرم افزار، باید ابتدا مشکلات رایج را بدانیم. یکی از رایجترین نقائص امنیتی نرم افزارها SQL Injection میباشد.
SQL Injection در لغت به معنی تزریق کد SQL میباشد. در اصلاح یعنی تزریق دستوراتی به کد SQL تولیدی یک نرم افزار به نحوی که به جای عمل مورد انتظار برنامه نویس آن، کاری را که ما میخواهیم انجام دهد. مثلا به جای اینکه هنگام ورود به برنامه وقتی کاربر مشخصات کاربری خود را وارد میکند، مشخصات کاربری را به نحوی و ...
قسمت هفتم 22. استفاده از CSS Sprites ایده اصلی این تکنیک به این صورت است که تمامی عکسهای کوچک (دراینجا همه 100 عکس) در قالب یک تصویر بزرگ قرار خواهد گرفت و با استفاده از CSS مختصات هر عکس کوچک را در تصویر بزرگ پیدا کرده و نمایش میدهیم. یکی شدن 100 عکس کوچک به یک عکس بزرگ، تاثیر زیادی در پایین آمدن حجم عکس جدید خواهد داشت و مرورگر شما به جای درخواست 100 عکس از سرور، تنها یکی دانلود میکند و از این به بعد از کش مرورگر برای بازیابی آن استف ...
قسمت ششم 20.اسکریپت در پایین صفحه لینکهای مربوطه به javascriptهای خود را تا جای ممکن در پایین صفحه قرار دهید. وقتی parser مرورگر به فایلهای javascript میرسد، تمامی فعالیتها را متوقف کرده و سعی در دانلود و سپس اجرای آن دارد. برخلاف اینکه مرورگرها امکان دانلود چند فایل را به صورت همزمان از سرور دارند، هنگامی که به اسکریپتها میرسند، تنها یک فایل را دانلود میکنند. یعنی اجرای برنامه و دانلودهای مرتبط با صفحه شما ...
قسمت پنجم
17. پرهیز از استفاده نسخه debugوقتی به ASP.NET مراجعه میکنید، توجه فرمایید که از چه نوع build برای محصول نهایی استفاده میکنید. وقتی از نسخه debug برنامه استفاده میکنید، بهبود دهندههای سطح کامپایلر عمل نکرده و کدشما در حالت بهینه اجرا نخواهد شد (کد شما همانگونه که هست اجرا میشود!).برای مثال هنگامی که از نسخه release استفاده میکنید، کامپایلر c# به صورت خودکار از StringBuilderها به جای تلفیق عادی رشته ها، از آرایهه ...
قسمت چهارم15.استفاده از usingاگر از objectهایی استفاده میکنید که interface مربوط به IDisposable را پیاده سازی کرده اند، حتما از عبارت using استفاده کنید. استفاده از دستور using باعث میشود زمانی که دیگر نیازی به object شما نباشد، به صورت خودکار از حافظه حذف شود و در روال جمع آوری زباله (GC) قرار گیرد. این عمل باعث حداقل رسیدن احتمال نشت حافظه در نرم افزار شما میشود. برای مثال:using System;
using System.Text;
class Program
{
...
قسمت سوم 12.استفاده از validation سمت کاربربرای جلوگیری از ارسال و دریافتهای متناوب اطلاعات به سرور، از validation سمت کاربر استفاده نمایید. فرمهای html 5 قابلیتهای چک کردن نوع ورودیها را به صورت خودکار دارد ولی ازاتکای به آن پرهیز کنید چون ممکن است یا کاربران برنامه شما از مرورگری استفاده کنند که از html5 پشتیبانی نکند و یا پشتیبانی کاملی از آن نداشته باشند. برای حل این مشکل میتوانید از کتابخانه هایی مانند JQuery و ابزارهایی مانند JQ ...