一起谈.NET技术,关于Windows Phone数据库和Silverlight本地文件操作

简介:   Isolated Storage是针对各个独立用户分配的单独的虚拟存储空间,在Windows会存储在\%AppData%\LocalLow\Microsoft\Silverlight\is, 而在Mac OS X会存储在 /Users//Library/Application Support/Microsoft/Silverlight/is。

  Isolated Storage是针对各个独立用户分配的单独的虚拟存储空间,在Windows会存储在\%AppData%\LocalLow\Microsoft\Silverlight\is, 而在Mac OS X会存储在 /Users/<user>/Library/Application Support/Microsoft/Silverlight/is。

  Isolated Storage有点像cookies,每个用户独立存储,Isolated Storage的容量是有配额的,但是可以通过调用System.IO.IsolatedStorage.IsolatedStorageFile.IncreaseQuotaTo()来增加容量。

下图为Isolated Storage的地址。

image

  无论浏览器版本的Silverlight还是Out Of Browser都可以自由使用Isolated Storage

IsolatedStorageFile theStore = IsolatedStorageFile.GetUserStoreForApplication();
FileStream fs = new System.IO.IsolatedStorage.IsolatedStorageFileStream(@"wp.db", File
Mode
.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite, theStore);

可以在Isolated Storage里面自由的增加,修改删除文件和目录。

theStore.CreateDirectory("db");

  但是不能把Isolated Storage外面的文件拷贝到Isolated Storage里面。这个为开发带来很多困难,例如我想把sqlite的数据库文件存放到XAP里面一同发布,然后把这个数据文件存放到到Isolated Storage里面,以后可以对这数据库继续修改,数据还是保存在Isolated Storage里面。可是不能把XAP里面的文件拷贝到Isolated Storage里面,没办法使用预先定义的数据。

image

从我的文档拷贝数据到Isolated Storage的时候出错。

在Out of Browser中使用我的文档

如果使用了Out of Browser,程序可以中使用我的文档(My Documents)的文件。

image

  在项目属性中选择 "Enable running application out of browser",然后点击 "Out-of-Browser Settings",然后选择"Required elevated trust when running outside the browser"

image

if (App.Current.HasElevatedPermissions)
{
FileStream stream = new FileStream(Environment.GetFolderPath(Environment.Special
Folder
.MyDocuments) + @"\wp.db", FileMode.OpenOrCreate);
string streamobject = new StreamReader(stream).ReadToEnd();
}

配置完毕以后就可以使用我的文档的文件了。使用我的文档的文件,App.Current.HasElevatedPermissions必须为true.

使用内嵌资源文件

  所谓内嵌资源文件就是把程序需要用到的offline文件打包到XAP包里面。可以参考 Silverlight如何内嵌资源,适用于Windows Phone

XDocument xDoc = XDocument.Load(@"db/wp.xml");

程序可以读取xml文件。

Image image = new Image();
image.Source = new BitmapImage(new Uri("Images/" + station.Image, UriKind.Relative));

  也可以使用图片文件。

image

但是不能打开文件进行操作。

SaveFileDialog

SaveFileDialog 为用户提供了把文件保存到其他目录的可能性,但是其具有限制性,必须由用户操作,不能直接通过程序把文件保存到其他位置上。

image

SaveFileDialog textDialog;
public MainPage()
{
InitializeComponent();
textDialog = new SaveFileDialog();
textDialog.Filter = "Text Files | *.txt";
textDialog.DefaultExt = "txt";
}

private void button1_Click(object sender, RoutedEventArgs e)
{
bool? result = textDialog.ShowDialog();
if (result == true)
{
System.IO.Stream fileStream = textDialog.OpenFile();
System.IO.StreamWriter sw = new System.IO.StreamWriter(fileStream);
sw.WriteLine("Writing some text in the file.");
sw.Flush();
sw.Close();
}
}

关于Windows Phone数据库的思考

  Windows Phone不支持直接操作物理文件。沿用了传统Silverlight的做法,使用了Isolated Storage的虚拟目录空间。我想Isolated Storage对于Silverlight来说是不错的做法,程序不能直接操作物理文件,这样有效防止病毒的传播。但是Windows Phone从文件系统的角度看就是一台PC,如果PC本地程序(例如Winform和WPF)都不能操作物理文件,那也太杯具了。如果这个问题一直不能解决,Windows Phone第三方数据库永远都会有突破,因为没办法把预先定义的数据读取出来。

  目前解决方法有二:

  1. 等待微软出SQL CE for Windows Phone。我们不可以做,不代表微软不可以做,微软可以写原生代码(native C++)的。理论上什么都能做出来。

  2. 使用云和网络存储,没想到微软现在走的那么前,比google还绝,什么都用云。

之前认为微软是重点关注桌面系统,因为大部分收入来源于Windows和Office,而google重点关注Web,由于没有自身的操作系统,什么都想使用Web一统天下。但是从微软发布IE9对HTML5的支持可以看到,微软也对Web和云投入很大。但是基于Windows Phone来说,还是提供本地支持比较好,因为移动设备网络连通性没有其他电脑设备好,离线应用还具有很大市场。

目录
相关文章
|
7月前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
593 2
|
7月前
|
开发框架 安全 .NET
Microsoft .NET Framework 3.5、4.5.2、4.8.1,适用于 Windows 版本的 .NET,Microsoft C Runtime等下载
.NET Framework是Windows平台的开发框架,包含CLR和FCL,支持多种语言开发桌面、Web应用。常用版本有3.5、4.5.2、4.8.1,系统可同时安装多个版本,确保软件兼容运行。
1659 0
Microsoft .NET Framework 3.5、4.5.2、4.8.1,适用于 Windows 版本的 .NET,Microsoft C Runtime等下载
|
8月前
|
监控 Java 关系型数据库
HikariCP 高性能数据库连接池技术详解与实践指南
本文档全面介绍 HikariCP 高性能数据库连接池的核心概念、架构设计和实践应用。作为目前性能最优异的 Java 数据库连接池实现,HikariCP 以其轻量级、高性能和可靠性著称,已成为 Spring Boot 等主流框架的默认连接池选择。本文将深入探讨其连接管理机制、性能优化策略、监控配置以及与各种框架的集成方式,帮助开发者构建高性能的数据访问层。
842 8
|
8月前
|
监控 Java 关系型数据库
HikariCP 高性能数据库连接池技术详解与实践指南
本文档全面介绍 HikariCP 高性能数据库连接池的核心概念、架构设计和实践应用。作为目前性能最优异的 Java 数据库连接池实现,HikariCP 以其轻量级、高性能和可靠性著称,已成为 Spring Boot 等主流框架的默认连接池选择。本文将深入探讨其连接管理机制、性能优化策略、监控配置以及与各种框架的集成方式,帮助开发者构建高性能的数据访问层。
542 1
|
8月前
|
SQL 数据管理 BI
数据库操作三基石:DDL、DML、DQL 技术入门指南
本文围绕数据库操作核心语言 DDL、DML、DQL 展开入门讲解。DDL 作为 “结构建筑师”,通过CREATE(建库 / 表)、ALTER(修改表)、DROP(删除)等命令定义数据库结构;DML 作为 “数据管理员”,以INSERT(插入)、UPDATE(更新)、DELETE(删除)操作数据表记录,需搭配WHERE条件避免误操作;DQL 作为 “数据检索师”,通过SELECT结合WHERE、ORDER BY、LIMIT等子句实现数据查询与统计。三者相辅相成,是数据库操作的基础,使用时需注意 DDL 的不可撤销性、DML 的条件约束及 DQL 的效率优化,为数据库学习与实践奠定基础。
|
9月前
|
缓存 关系型数据库 MySQL
MySQL数据库性能调优:实用技术与策略
通过秉持以上的策略实施具体的优化措施,可以确保MySQL数据库的高效稳定运行。务必结合具体情况,动态调整优化策略,才能充分发挥数据库的性能潜力。
383 0
|
11月前
|
存储 人工智能 关系型数据库
诚邀您参加《智启云存:AI时代数据库RDS存储新突破》线上闭门技术沙龙!
诚邀您参加6月11日(周三)14:00在线上举行的《智启云存:AI时代数据库RDS存储新突破》闭门活动。免费报名并有机会获得精美礼品,快来报名吧:https://hd.aliyun.com/form/6162
|
8月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
514 158
|
8月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
8月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1288 152

热门文章

最新文章