<?xml version="1.0" encoding="UTF-8"?>

<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/">
	<channel>
		<title>سایت علمی دانشجویان ایران - توسعه Web</title>
		<link>http://www.daneshju.ir/forum/</link>
		<description />
		<language>fa</language>
		<lastBuildDate>Thu, 17 May 2012 11:03:36 GMT</lastBuildDate>
		<generator>vBulletin</generator>
		<ttl>60</ttl>
		<image>
			<url>http://www.daneshju.ir/forum/images/misc/rss.png</url>
			<title>سایت علمی دانشجویان ایران - توسعه Web</title>
			<link>http://www.daneshju.ir/forum/</link>
		</image>
		<item>
			<title>آموزش بررسی کوکی‌ها (Cookies) و جلسات (Sessions) در ASP.NET</title>
			<link>http://www.daneshju.ir/forum/forum576/thread157671-new-post.html</link>
			<pubDate>Sun, 22 Apr 2012 14:28:43 GMT</pubDate>
			<description>در  این مقاله ابتدا به بررسی کوکی‌ها (Cookies) پرداخته و سپس جلسات  (Sessions) را بررسی خواهیم کرد. به دلیل نزدیکی بسیار زیاد این دو مفهوم  تصمیم...</description>
			<content:encoded><![CDATA[<div>در  این مقاله ابتدا به بررسی کوکی‌ها (Cookies) پرداخته و سپس جلسات  (Sessions) را بررسی خواهیم کرد. به دلیل نزدیکی بسیار زیاد این دو مفهوم  تصمیم گرفتم همه آنها را در یک مقاله جمع‌آوری کنم. اگر مفاهیم فوق را به  درستی درک کنید و طرز استفاده از آنها را یاد بگیرید، می توانید به قدرت  برنامه‌های کاربردی وب خود بیفزایید. اما استفاده نابجا از این مفاهیم در  وب سایتهای مختلف می تواند به شدت روی عملکرد سایت تاثیر گذاشته و از  مخاطبان و کارایی آن بکاهد. در نتیجه با مطالعه این مقاله در مورد این دو  مفهوم، باید بتوانید تصمیم بگیرید که کدامیک برای وب سایت شما مناسب‌تر می  باشد. در هر حال مثال‌هایی را در این مقاله خواهید دید که به طور حتم به  شما کمک زیادی خواهند کرد. لازم به ذکر است که بیشتر سعی در انتقال مفاهیمی  کرده‌ام که پایه کار نمی باشند و سعی کردم به بیان نکاتی بپردازم که راحت  پیدا نمی‌شوند.<br />
کوکی‌ها (Cookies)<br />
استفان  والتر در کتاب ASP.NET Unleashed در ابتدای بخش کوکی‌ها اینگونه می‌گوید:  “پروتکل HTTP هیچ امکانی را در اختیار وب سرور قرار نمی‌دهد تا بتواند به  کمک آن تشخیص دهد درخواست جدید از همان مرورگری صادر شده که در خواست قبلی  را فرستاده یا از مرورگر دیگری آمده است. از این جهت به HTTP صفت ناپایداری  (Stateless) را میدهند. از نقطه نظر وب سرور هر درخواستی که برای دریافت  یک صفحه صادر شده است از طرف کاربری جدید ارسال شده است.” این به طور قطع  آن چیزی نیست که ما می خواهیم! وقتی می‌خواهیم اطلاعات کاربر را در هر صفحه  به او نشان بدهیم (از قبیل شناسه کاربری، کلمه عبور، سبد خرید و…) باید  بتوانیم وضعیت آن را حفط کنیم یکی از راههای بسیار خوب در این زمینه  استفاده از کوکی‌ها می‌باشد.<br />
اولین بار Netscape کوکی‌ها را در مرورگر  خود به کار برد و به تدریج کنسرسیوم وب (W3C) نیز آن را پذیرفت و امروزه  اکثر مرورگرها از کوکی‌ها پشتیبانی می کنند. بر اساس مستندات اولیه  Netscape، یک کوکی نمیتواند حجمی بیشتر از ۴ کیلوبایت داشته باشد و با بستن  صفحه مرورگر کوکی‌ها نیز از بین می روند. البته نگران نباشید اینها  کوکی‌هایی هستند که پارامتر Expires آنها تنظیم نشده است. اما اگر این  پارامتر را تنظیم کنید، کوکی‌ها باقی مانده و دائمی می شوند. اما تا کی؟ تا  آن تاریخی که در خاصیت Expires تنظیم کرده‌اید. مرورگرهایی که می توانند  با کوکی‌ها کار کنند دارای چند فایل ویژه می‌باشند که در ویندوز به آنها  فایل‌های کوکی و در مکینتاش فایل‌های جادویی می گویند. کوکی‌ها از طریق  هدرهای HTTP بین مرورگر و سرور جابجا می شوند. سرور با استفاده از هدر Set  Cookie یک کوکی جدید ایجاد کرده و در درخواست‌های بعدی این کوکی به سرور  فرستاده می شود.<br />
در مقاله‌ای از سایت ASPFREE در مورد خواندن و نوشتن  کوکی‌ها اینگونه نوشته شده است: “برای نوشتن کوکی یک شیئ جدید HttpCookie  بسازید و مقدار یک رشته را به آن اختصاص دهید (به خاصیت Value آن) و سپس  متد ()Add را در Response.Cookies فرا بخوانید. شما همچنین می توانید مقدار  Expires را به یک مقدار تاریخ تغییر دهید تا زمان انقضاء برای کوکی‌تان  تایین کرده باشید.”<br />
باید توجه داشته باشید که کوکی‌ها فقط مقادیر  رشته‌ای را ذخیره می کنند و برای نوشتن مقادیر دیگر در کوکی‌ها باید هر  آنها را به یک رشته تبدیل کنید. این کد از سایت CodeToad برای یادگیری نحوه  استفاده کوکی‌ها بسیار مناسب می باشد:<br />
Using System.<span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=Web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#87;&#101;&#98;</a>

</span> ;<br />
// نوشتن<br />
Response.Cookies[&quot;BackgroundColor&quot;].Value = &quot;Red&quot;;<br />
// خواندن<br />
Response.Write(Request.Cookies[&quot;BackgroundColor&quot;].Value)<br />
;به  دلایل امنیتی شما می‌توانید فقط کوکی‌هایی را بخوانید که از یک دامنه آمده  باشند. همچنین ممکن است شما نیاز به کوکی‌هایی داشته باشید که چند آیتم را  در خود نگهداری کنند، یک مثال برای این کار در زیر می بینید:<br />
HttpCookieCollection cookies = Request.Cookies;   for (int n = 0; n &lt; cookies.Count; n++) {<br />
HttpCookie cookie = cookies[n];<br />
Response.Write(&quot;&lt;hr/&gt;Name: &lt;b&gt;&quot; + cookie.Name + &quot;&lt;/b&gt;&lt;br /&gt;&quot;);<br />
Response.Write(&quot;Expiry: &quot; + cookie.Expires + &quot;&lt;br /&gt;&quot;);<br />
Response.Write(&quot;Address1: &quot; + cookie.Address1+ &quot;&lt;br /&gt;&quot;);<br />
Response.Write(&quot;Address2: &quot; + cookie.Address2+ &quot;&lt;br /&gt;&quot;);<br />
Response.Write(&quot;City: &quot; + cookie.City+ &quot;&lt;br /&gt;&quot;);<br />
Response.Write(&quot;Zip: &quot; + cookie.Zip+ &quot;&lt;br /&gt;&quot;);<br />
}یک مثال درباره کوکی‌های تو در تو به زبان VB.NET:<br />
If Request.Form(&quot;savecookie&quot;) = &quot;Yes&quot; and ValidLogin = &quot;Yes&quot; Then<br />
Response.Cookies(&quot;member&quot;)(&quot;username&quot;) = Request.Form(&quot;username&quot;)<br />
Response.Cookies(&quot;member&quot;)(&quot;password&quot;) = Request.Form(&quot;password&quot;)<br />
Response.Cookies(&quot;member&quot;).Expires = DATE + 365<br />
End if<br />
جدول زیر بعضی از خصوصیات پیشرفته کوکی‌ها را نمایش می‌دهد:<br />
خاصیت         توضیحات<br />
<span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=Domain"  onmouseover="return overlib('دامنه');" onmouseout="return nd();">&#68;&#111;&#109;&#97;&#105;&#110;</a>

</span>         دامنه‌ای که محدوده کوکی را تعیین می کند. <br />
Path             مسیر منتسب به کوکی. <br />
Secure         مقدار بولینی که تعیین می کند آیا کوکی باید فقط روی یک اتصال رمز شده ارسال گردد یا نه؟ <br />
HasKeys      مقدار بولینی که تعیین می کند که آیا کوکی مربوط به یک کوکی دیکشنری است یا نه؟ <br />
بطور خلاصه، کوکی‌ها چه خوبیهایی دارند؟  اشغال فضا روی کلاینت که باعث کاهش ترافیک و اشغال فضا روی سرور می شود و  اطمینان کار. کوکی‌ها چه بدیهایی دارند؟ بعضی از مرورگرها از کوکی‌ها  پشتیبانی نمی کند، بعضی از کاربران کوکی‌ها را پاک می کنند یا نمی پذیرند و  این که فقط داده نوع رشته‌ای را ذخیره می کنند.<br />
جلسات (Sessions)<br />
فریم  ورک دات نت برای رد گیری حرکت کاربر ما را تنها نگذاشته و یک امکان خوب به  نام Session State را در اختیار ما قرار داده است. به طور پیش فرض وقتی  کاربر اولین بار صفحه‌ای را از یک وب سایت ساخته شده با ASP.NET درخواست می  کند یک کوکی جلسه به نام ASP.NET_SessionID ساخته شده و به مرورگر او  ارسال میشود. با این کار ASP.NET قادر به پیگیری کاربر شده و میتواند در  درخواست‌های بعدی او را شناسایی کند.<br />
بر این اساس در ASP.NET یک شیء به  نام Session قرار داده شده است که میتوانید از آن برای نگهداری اطلاعات  مربوط به هر کاربر استفاده کنید. برای مثال دستور زیر یک آیتم با نام  MyItem ایجاد کرده و Hello را به آن نسبت میدهد:<br />
Session(“MyItem”)=”Hello!”<br />
هنگام کار با Sessionها باید به نکات زیر توجه کنید:<br />
هر Session اگر کاریر مرورگر را ببندد یا ۲۰ دقیقه از سرور درخواست نکند از بین می رود.<br />
Session هر کاربر جدا از Session بقیه کاربران است.<br />
در Session بر خلاف کوکی‌ها می توان شیئ هم ذخیره کرد.<br />
جدول زیر بعضی از خصوصیات و متدهای شیئ Session را نمایش میدهد:<br />
خاصیت                 متد توضیحات<br />
Remove              پاک کردن Session <br />
RemoveAll          پاک کردن تمام Sessionها <br />
SessionID ID      منحصر به فرد جلسه فعلی را برمیگرداند. <br />
Session            Abandonفعلی را خاتمه میدهد. اگر کاربر پس از دستور فوق درخواست یک صفحه جدید <br />
                          کند به عنوان کاربر جدید در نظر گرفته می شود. <br />
TimeOut              تغییر مهلت پیش فرض ختم جلسه. این خصوصیت هر عددی که باشد بعد از همان قدر  دقیقه اگر کاربر درخواستی به سرور نفرستد Session ختم می شود. <br />
نکته: از طریق فایل <span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#119;&#101;&#98;</a>

</span> .config نیز می‌توان مهلت ختم جلسه را تغییر داد:<br />
&lt;configuration&gt;<br />
 &lt;system.<span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#119;&#101;&#98;</a>

</span> &gt;<br />
&lt;sessionstate timeout=&quot;60&quot; /&gt;<br />
&lt;/system.<span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#119;&#101;&#98;</a>

</span> &gt;<br />
&lt;/configuration&gt;Eventها  یا وقایع جلسه‌ها دو مورد هستند: Session_Start و Session_End. که  Session_Start وقتی رخ می دهد که جلسه آغاز و Session_End وقتی رخ می دهد  که جلسه خاتمه پیدا کند. این Eventها را باید در فایل Global.asax تعریف  کرد.<br />
در زیر یک مثال عملی از این رویدادها را خواهید دید:<br />
&lt;html&gt;<br />
&lt;head&gt;<br />
&lt;title&gt;SessionCount.aspx&lt;/title&gt;<br />
&lt;Script Runat=&quot;Server&quot;&gt;<br />
 Sub Page_Load()<br />
lblSessionCount.Text = Application(&quot;SessionCount&quot;)<br />
End Sub<br />
&lt;/Script&gt;<br />
&lt;/head&gt;<br />
   &lt;body&gt;<br />
   Current Sessions:<br />
&lt;asp:Label ID=&quot;lblSessionCount&quot; Runat=&quot;Server&quot; /&gt;<br />
   &lt;/body&gt;<br />
&lt;/html&gt;Default.aspx<br />
   &lt;Script Runat=&quot;Server&quot;&gt;<br />
Sub Session_Start()<br />
If Application(&quot;SessionCount&quot;) Is Nothing Then<br />
 Application(&quot;SessionCount&quot;) = 0<br />
End If<br />
   Application(&quot;SessionCount&quot;) += 1<br />
End Sub<br />
    Sub Session_End()<br />
Application(&quot;SessionCount&quot;) -= 1<br />
End Sub<br />
&lt;/Script&gt;Global.asax<br />
بطور  کلی برای نگهداری مقادیر Sessionها در ASP.NET سه روش وجود دارد: درون  پروسه (In Process)، ذخیره در سرویس ویندوز و ذخیره در SQL Server.<br />
Sessionها  به طور پیش فرض در داخل پروسه مدیریت می شود و تمام آیتم‌هایی که در  Sessionها می‌سازیم در همان پروسه وب سرور ذخیره می شوند. مهمترین مشکل این  روش این است که اگر به هر دلیل سرور از کار بیفتد و یا <span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=Web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#87;&#101;&#98;</a>

</span>  Applicationما  دستکاری شود، تمام داده‌ها از بین میرود و از طرف دیگر بسط پذیری را در  سایت محدود می کند و نمی توان آن را به اشتراک گذاشت.<br />
اما با استفاده از  تکنیک ذخیره در پایگاه داده SQL Server می‌توان حتی در صورت از کار افتادن  سرور نیز اطلاعات را حفظ کرد. تعریف اشیای ضروری در SQL Server به منظور  مدیریت داده‌های جلسه با اجرای بچ فایل InstallSqlState.sql صورت می گیرد.  بعد از این کار باید فایل <span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#119;&#101;&#98;</a>

</span> .config را نیز به شکل زیر تغییر داد:<br />
&lt;configuration&gt;<br />
&lt;system.<span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#119;&#101;&#98;</a>

</span> &gt;<br />
&lt;sessionstate<br />
mode=&quot;SqlServer&quot;<br />
sqlConnectionString=&quot;Server=127.0.0.1;UID=sa;Pwd=Y  ourPassword&quot; /&gt;<br />
&lt;/system.<span class="glossarylink">



	<a href="http://www.daneshju.ir/forum/vbglossar.php?do=showentry&amp;item=web"  onmouseover="return overlib('بافت یا غشا؛ پرده؛ پره.');" onmouseout="return nd();">&#119;&#101;&#98;</a>

</span> &gt;<br />
&lt;/configuration&gt;</div>

 ]]></content:encoded>
			<category domain="http://www.daneshju.ir/forum/f576.html">توسعه Web</category>
			<dc:creator>R a h a</dc:creator>
			<guid isPermaLink="true">http://www.daneshju.ir/forum/f576/t157671.html</guid>
		</item>
	</channel>
</rss>

