Skip to main content

Isolated Storage in .Net



Namespace: System.IO.IsolatedStorage


IsolatedStoreage is a storage place provided to applications with full access writes where they can store data about themselves. It also prevents from the attacks intended by spywares, malwares, and viruses. And application will run without caring about the environment whether it is limited, partially, or fully trusted environment.

How to create a store:
An isolated storage can be created by just calling the respective scope level Get[Machine|User]StoreFor[Application|Assembly|Domain]();

IsolatedStorageFileStream class:
This class inherits from FileStream class, so its use is identical to FileStream class.

Reading and writing data to Isolated Storage:

IsolatedStorageFile userStore = IsolatedStoreageFile.GetUserStoreForAssembly();
IsolatedStorageFileStream vUserFileStream = new IsolatedStorageFileStream(“UserSettings.set”,
                                                                                                                                FileMode.Create, userStore);

StreamWriter sw = new StreamWriter(vUserFileStream);
Sw.WriteLine(“testing testing ….”);

Sw.Close();

There is no way to check existence of a file like Exists method. One will have to query the files in the store and then check whether the respective file exists in list or not.
String[] files = userStore.GetFileNames(“UserSettings.set”); //only  * and ? are supported wildcards
If(files.length > 0)
{
                //File exists
}

Creating Directories in Isolated Storage:

UserStore.CreateDirectory(“UI”);
IsolatedStorageFileStream newUISetting = new IsolatedStorageFileStream(
@“UI\UserSetting.set”,
FileMode.Create,
userStore);

In the same way one can check for the existence of a directory:

String[] dirs = userStore.GetDirectoriesNames(“UI”);
If(dirs.length > 0)
{
                //Directory exists
}

IsolatedStorageFilePermission class:

IsolatedStorageFilePermission class encapsulates checks to enable Code Access permission. One can configure the level of store and size quota that an assembly, application or domain can consume.

[IsolatedStorageFilePermission(SecurityAction.Demand)]
Class program
{
}

OR

[IsolatedStorageFilePermission(SecurityAction.Demand, UserQuota = 1024, UsageAllowed= IsolatedStorageContainment.AssemblyIsolationByUser)]
Class program
{
}


IsolatedStorageFile class:

Static Methods:
GetEnumerator
Gets the enumerator for the IsolatedStorageFile stores within an isolated storage scope.
GetMachineStoreForApplication
Obtains machine-scoped isolated storage corresponding to the calling code's application identity.
GetMachineStoreForAssembly
Obtains machine-scoped isolated storage corresponding to the calling code's assembly identity.
GetMachineStoreForDomain
Obtains machine-scoped isolated storage corresponding to the application domain identity and the assembly identity.
GetStore
Overloaded. Obtains isolated storage corresponding to the given application domain and assembly evidence objects and isolated storage scope.
GetUserStoreForApplication
Obtains user-scoped isolated storage corresponding to the calling code's application identity.
GetUserStoreForAssembly
Obtains user-scoped isolated storage corresponding to the calling code's assembly identity.
GetUserStoreForDomain
Obtains user-scoped isolated storage corresponding to the application domain identity and assembly identity.

IsolatedStorageFile Properties:
ApplicationIdentity
Gets an application identity that scopes isolated storage.
AssemblyIdentity
Gets an assembly identity used to scope isolated storage.
CurrentSize
Gets the current size of the isolated storage. (Overrides .CurrentSize.)
DomainIdentity
Gets a domain identity that scopes isolated storage.
MaximumSize
Gets a value representing the maximum amount of space available for isolated storage within the limits established by the quota. (Overrides .MaximumSize.)
Scope
Gets an IsolatedStorageScope enumeration value specifying the scope used to isolate the store.

IsolatedStorageFile Methods:
Close
Closes a store previously opened with GetStore, GetUserStoreForAssembly(), or GetUserStoreForDomain().
CreateDirectory
Creates a directory in the isolated storage scope.
DeleteDirectory
Deletes a directory in the isolated storage scope.
DeleteFile
Deletes a file in the isolated storage scope.
Dispose
Releases all resources used by the IsolatedStorageFile.
GetDirectoryNames
Enumerates directories in an isolated storage scope that match a given pattern.
GetFileNames
Enumerates files in isolated storage scope that match a given pattern.
Remove
Overloaded. Removes the isolated storage scope and all its contents.



Comments

Popular posts from this blog

Culture Information and Localization in .NET

Namespace: System.Globalization CultureInfo Class:                 It provides information like the Format of numbers and dates, Culture’s Calendar, Culture’s language and sublanguage (if applicable), Country and region of the culture. The Basic use of CultureInfo class is shown here: • How string Comparisons are performed • How Number Comparison & Formats are performed • Date Comparison and Formats. • How resources are retrieved and used. Cultures are grouped into three categories: Invariant Culture : It’s Culture Insensitive. It can be used to build some trial application. It can be also used to build an application with hard-coded expiry date that ignores cultures. But using it for every comparison will be incorrect and inappropriate. Neutral Culture : English(en), Frensh(fr), and Spanish(sp). A neutral culture is related to language but it’s not related to specific regi...

Concept of App Domain in .Net

Creating Application Domains: Application domain is just like process, provides separate memory space, and isolates from other code. But it’s quite light weight. It also provides the following advantages: 1-       Reliability : If a domain crashes, it can be unloaded. Hence doesn’t affect the other assemblies. 2-       Efficiency : Loading all assemblies in one domain can be cumbersome and can make the process heavy but Appdomains are efficient in this manner. Important properties of AppDomain: ApplicationIdentity , ApplicationTrust , BaseDirectory , CurrentDomain , DomainManager , DomainDirectory , Evidence , FriendlyName , ID , RelativeSearchPath , SetupInformation , ShadowCopyFiles . Important methods of AppDomain: ApplyPolicy , CreateCOMInstanceFrom , CreateDomain , CreateInstance (Assembly). To create an AppDomain: AppDomain adomain = AppDomain.CreateDomain(“D”); To execute an assembly:...

Asynchronous Execution in ASP.NET

Asynchronous Execution: Two ways either implement IHTTPAsyncHandler interface or in ASP.NET 2.0 set <%@ Page Async=”true” %>. The second option implements IHTTPAsyncHandler interface automatically for the page when parsed or compiled. AddOnPreRenderCompleteAsync ( new BeginEventHandler(BeginTask), new EndEventHandler(EndTask)); AddOnPreRenderCompleteAsync() shoud be called in Page_load. The BeginEventHandler and EndEventHandler are delegates defined as follows: IAsyncResult BeginEventHandler( object sender, EventArgs e, AsyncCallback cb, object state) void EndEventHandler( IAsyncResult ar) AsyncProcess starts and completes between PreRender and PreRenderComplete. Other way to perform Async Task is using AsyncPageTask structure. It also allows multiple tasks to execute simultaneously. void Page_Load (object sender, EventArgs e) { PageAsyncTask task = new PageAsyncTask( new BeginEventHandler(BeginTask), new EndEventH...