सिल्वरलाइट - पृथक भंडारण

तीसरी फ़ाइल पहुंच तंत्र है Isolated Storageतंत्र, जो उपयोगकर्ता में लॉग इन के साथ जुड़े भंडारण प्रदान करता है। एपीआई डेटा के माध्यम से प्रस्तुत करता हैStream से कक्षा .NET System.IOनाम स्थान। इसलिए, जैसा कि हमने अभी तक देखा है अन्य तंत्रों के साथ, आप अन्य प्रकारों का उपयोग कर सकते हैंSystem.IO स्ट्रीम के साथ काम करने के लिए, आपको टेक्स्ट या बाइनरी डेटा स्टोर करने में सक्षम बनाता है।

कुछ महत्वपूर्ण विशेषताएं हैं -

  • इस भंडारण तंत्र को कहा जाता है Isolated Storage क्योंकि स्टोर का विभाजन हो गया है, और एक सिल्वरलाइट एप्लिकेशन का उपयोग केवल कुछ भागों तक ही होता है।

  • आप किसी भी पुराने संग्रहीत डेटा तक नहीं पहुँच सकते। सबसे पहले, स्टोर प्रति उपयोगकर्ता विभाजन है। एक सिल्वरलाइट एप्लीकेशन एक अलग उपयोगकर्ता के लिए स्टोर में प्रवेश नहीं कर सकता है, जिसमें एक लॉग इन किया गया हो, और एप्लिकेशन को चलाया जा रहा हो।

  • यह आपके वेब एप्लिकेशन का उपयोग करने वाले किसी भी पहचान तंत्र से कोई लेना-देना नहीं है। यह याद रखने के लिए एक महत्वपूर्ण बिंदु है क्योंकि कुछ लोग जो कंप्यूटर साझा करते हैं, वे अलग-अलग विंडोज खातों से परेशान नहीं होते हैं, और केवल उन वेबसाइटों से लॉग इन और आउट करने के आदी हैं, जिनका वे उपयोग करते हैं।

पृथक भंडारण का उपयोग करना

पृथक भंडारण सिल्वरलाइट के लिए अद्वितीय नहीं है। एपीआई मूल रूप से के लिए पेश किया गया थाWindows Formsआंशिक विश्वास परिदृश्यों में स्थानीय रूप से डेटा संग्रहीत करने के लिए वेब से लॉन्च किए गए एप्लिकेशन को सक्षम करने के लिए। कार्यान्वयन अलग है, और पूर्ण तक पहुंचने का कोई तरीका नहीं है.NET सिल्वरलाइट के फ्रेमवर्क का पृथक भंडारण, या इसके विपरीत।

हालांकि, यदि आपने इसका उपयोग किया है, तो यहां के चरण बहुत परिचित दिखेंगे।

  • आप उपयोगकर्ता विशिष्ट स्टोर के लिए पूछकर शुरू करते हैं। इस मामले में, हम आवेदन के लिए एक के लिए पूछ रहे हैं। यदि हम साइट पर सभी XAPs द्वारा साझा प्रति-साइट स्टोर चाहते थे, तो हम कॉल करेंगेGetUserStoreForSite बजाय।

  • या तो विधि एक रिटर्न IsolatedStorageFile ऑब्जेक्ट, जो एक बहुत ही बेकार नाम है क्योंकि यह एक निर्देशिका का प्रतिनिधित्व करता है, एक फाइल का नहीं।

  • किसी फ़ाइल तक पहुँचने के लिए, आपको यह पूछने की आवश्यकता है IsolatedStorageFile के लिए Stream

  • हम उपयोग करते हैं IsolatedStorageFileStream वर्ग, और इसके निर्माता को आपको पास करना होगा IsolatedStorageFile एक तर्क के रूप में वस्तु।

  • इसलिए हम स्टोर में एक नई फ़ाइल बना रहे हैं। डिस्क पर फ़ाइल का सटीक स्थान अज्ञात है।

  • युक्त निर्देशिका में फ़ाइल के नाम का अनुमान लगाना असंभव बनाने के लिए रैंडमाइज्ड तत्व हैं।

  • इसके बिना, दुर्भावनापूर्ण वेबसाइटों के लिए उपयोगकर्ता के कंप्यूटर पर किसी फ़ाइल को रखना संभव हो सकता है, और फिर इसे खोलने के लिए एक फ़ाइल URL का निर्माण किया जा सकता है, जिसमें उपयोगकर्ता को किसी लिंक पर क्लिक करने की आशा में, जो स्थानीय रूप से किसी प्रोग्राम को निष्पादित करता है।

  • विंडोज में निर्मित विभिन्न अन्य सुरक्षा उपाय हैं जो इसे होने से रोकने की कोशिश करते हैं, लेकिन यह रक्षा की एक और परत है यदि अन्य किसी तरह अक्षम हो गए हैं, या बाईपास हो गए हैं।

  • फ़ाइल को उपयोगकर्ता के प्रोफ़ाइल के अंदर कहीं संग्रहीत किया जाएगा, लेकिन यह उतना ही है जितना आप इसके बारे में जान सकते हैं। तुम्हारीIsolatedStorageFileStream इसके वास्तविक स्थान की रिपोर्ट नहीं करेगा।

आइए हम एक सरल उदाहरण पर नजर डालते हैं जो यह बताता है कि आवेदन कितनी बार चलाया गया है। नीचे XAML कोड दिया गया है।

<UserControl x:Class = "StoreRunCount.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" d:DesignWidth = "400"> 
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
      <TextBlock x:Name = "runCountText" FontSize = "20" /> 
   </Grid> 
	
</UserControl>

यहाँ C # कोड दिया गया है जिसमें Isolated storage उपयोग किया जाता है।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Net; 

using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Documents; 
using System.Windows.Input; 
using System.Windows.Media; 
using System.Windows.Media.Animation; 
using System.Windows.Shapes; 

using System.IO.IsolatedStorage; 
using System.IO;

namespace StoreRunCount { 

   public partial class MainPage : UserControl {
	
      const string RunCountFileName = "RunCount.bin"; 
		
      public MainPage() { 
         InitializeComponent();  
         int runCount = 0;  
			
         using (var store = IsolatedStorageFile.GetUserStoreForApplication()) { 
			
            if (store.FileExists(RunCountFileName)) { 
               using (var stm = store.OpenFile(RunCountFileName, 
                  FileMode.Open, FileAccess.Read)) 
               using (var r = new BinaryReader(stm)) { 
                  runCount = r.ReadInt32(); 
               }  
            } 
			
            runCount += 1;  
            using (var stm = store.OpenFile(RunCountFileName, 
               FileMode.Create, FileAccess.Write)) 
					
            using (var w = new BinaryWriter(stm)) { 
               w.Write(runCount); 
            } 
         }  
			
         runCountText.Text = "You have run this application " + runCount.ToString() + " time(s)"; 
      } 
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न वेबपृष्ठ दिखाई देगा, जो आपको यह दिखाएगा कि आप इस एप्लिकेशन को कितनी बार चलाते हैं।

आपका कोटा बढ़ रहा है

यदि किसी कारण से प्रारंभिक राशि अपर्याप्त है तो आवेदन अधिक स्थान मांग सकते हैं। इस बात की कोई गारंटी नहीं है कि अनुरोध सफल होगा। सिल्वरलाइट उपयोगकर्ता से पूछेगा कि क्या वे एप्लिकेशन को अधिक स्थान देने के लिए खुश हैं।

वैसे, आपको केवल उपयोगकर्ता इनपुट के जवाब में अधिक भंडारण के लिए पूछने की अनुमति है, जैसे कि ए click। यदि आप इसे किसी अन्य समय से पूछने का प्रयास करते हैं, जैसे कि जब प्लग-इन लोड होता है, या टाइमर हैंडलर में, सिल्वरलाइट स्वचालित रूप से उपयोगकर्ता को संकेत दिए बिना अनुरोध को विफल कर देगा। अतिरिक्त कोटा केवल उन अनुप्रयोगों के लिए उपलब्ध है जिनके साथ उपयोगकर्ता बातचीत कर रहा है।

IsolatedStorageFile ऑब्जेक्ट कोटा को प्रबंधित करने के लिए तीन सदस्य प्रदान करता है -

  • AvailableFreeSpace
  • IncreaseQuotaTo
  • Quota

AvailableFreeSpace

उपलब्ध फ़्रीस्पेस स्पेस संपत्ति आपको बताती है कि आपका कोटा कितना मुक्त है।

ध्यान दें कि यहां तक ​​कि एक खाली उपनिर्देशिका आपके कुछ कोटा का उपभोग करती है क्योंकि ऑपरेटिंग सिस्टम को निर्देशिका का प्रतिनिधित्व करने के लिए डिस्क पर स्थान आवंटित करने की आवश्यकता होती है। तो, उपलब्ध स्थान कुल कोटा से कम हो सकता है, आपकी सभी फ़ाइलों का कुल आकार घटा सकता है।

IncreaseQuotaTo

यदि आपके पास आगे बढ़ने के लिए पर्याप्त जगह नहीं है, तो आप कॉल करके अधिक मांगते हैं IncreaseQuotaTo तरीका।

कोटा

यहां हम तीसरी संपत्ति का उपयोग कर रहे हैं, Quota, वर्तमान कोटा आकार की खोज करने के लिए, और फिर हम अपने नए अनुरोधित कोटा को प्राप्त करने के लिए आवश्यक अतिरिक्त राशि जोड़ रहे हैं।

विधि या तो लौटती है True या Falseयह इंगित करने के लिए कि क्या हमें आवंटित किया गया है जो हमने मांगा था। ध्यान दें कि सिल्वरलाइट आपके द्वारा पूछे गए से अधिक स्थान आवंटित करने का निर्णय ले सकती है।

यहाँ एक सरल उदाहरण है कि वृद्धि हुई है quota, जब बटन पर क्लिक किया जाता है। नीचे XAML कोड दिया गया है।

<UserControl x:Class = "ChangeQuota.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" d:DesignWidth = "400"> 
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
      <TextBlock x:Name = "infoText" FontSize = "20" TextWrapping = "Wrap" />  
      <Button x:Name = "increaseQuota" Content = "Increase" HorizontalAlignment = "Center" 
         FontSize = "20" 
         VerticalAlignment = "Center" Click = "increaseQuota_Click" /> 
   </Grid>
	
</UserControl>

यहाँ का कार्यान्वयन है click वह घटना जिसमें कोटा बढ़ा है।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Net; 

using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Documents; 
using System.Windows.Input;
using System.Windows.Media; 
using System.Windows.Media.Animation; 
using System.Windows.Shapes; 

using System.IO.IsolatedStorage;
  
namespace ChangeQuota { 

   public partial class MainPage : UserControl { 
	
      public MainPage() { 
         InitializeComponent(); 
      } 
	  
      private void increaseQuota_Click(object sender, RoutedEventArgs e) { 
         using (IsolatedStorageFile isoStore = 
            IsolatedStorageFile.GetUserStoreForApplication()) { 
               long newQuota = isoStore.Quota + 10240; 
					
               if (isoStore.IncreaseQuotaTo(newQuota)) { 
                  infoText.Text = "Quota is " + isoStore.Quota + ", free space: " + 
                  isoStore.AvailableFreeSpace; 
               } else { 
                  infoText.Text = "Meanie!"; 
               } 
         } 
      } 
   } 
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

जब आप क्लिक करेंगे Increaseशीघ्र प्रकट होता है। इसे बढ़ाने के लिए कहता हैQuota जो पहले से ही है उससे 10KB बड़ा होना।

जब आप क्लिक करेंगे Yes, यह तब उपलब्ध कोटा की मात्रा को प्रिंट करता है।

हम आपको बेहतर समझ के लिए उपरोक्त उदाहरणों को निष्पादित करने की सलाह देते हैं।