Silverlight 5 beta新特性探索系列:10.浏览器模式下内嵌HTML+浏览器模式下创建txt文本文件

简介:

    在Silverlight 5 beta版本中,已经支持浏览器模式(in-browser)模式下使用WebBrowser控件访问网页和在浏览器模式下创建txt文本文件。当然想要获得这个功能有三个条件在注册表内添加一个新的键、设置XAP签名(如果是在本地http://localhost:做测试时可以不需要这两个条件)和提升信任级别。

        第一、在注册表内添加一个新的键AllowElevatedTrustAppsInBrowser

        其名为AllowElevatedTrustAppsInBrowser,DWORD类型,值为1。设置Silverlight允许访问一些本地资源。

 
  1. •键名: AllowElevatedTrustAppsInBrowser 
  2. •键类型: DWORD 
  3. •键值: 0x00000000 (disabled) or 0x00000001 (enabled) 

        其键注册位置在32位系统和64位系统中不一样的,下面请看:

 
  1. HKEY_LOCAL_MACHINE\Software\Microsoft\Silverlight\ (for 32-bitor 
  2. HKEY_LOCAL_MACHINE\Software\Wow6432Node\Microsoft\Silverlight (for 64-bit)  

        二、将XAP包签名设置XAP包是可信任的应用程序

        1.右键点击Silverlight项目-->属性-->签名-->点击选中“为Xap文件签名”-->点击“创建测试证书”。如下图所示:


 

        2.安装证书:在上图中点击“更多详细信息”-->“安装证书(I)”。如下图:

        3.在弹出的“证书导入向导”窗口中选中“将所有的证书放入下列存储区”--在弹出的“选中证书存储”窗口中,选择“受信任的根证书颁发机构”。如下图:

        4.安装签名证书成功

        三、提升信任级别

        首先我们设置Silverlight的OOB模式提升信任级别如下:

        在这里我们提升了OOB模式的信任级别,此时项目会自动设置从Silverlight项目启动如左图,我们需要手动设置从Web项目启动,如右图:

 

        最后我们来看本篇文章的实例Demo代码,首先看MainPage.xaml代码如下:

 

 
  1. <Grid x:Name="LayoutRoot" Background="White"
  2.     <WebBrowser Height="463" HorizontalAlignment="Left"  Margin="0,137,0,0" 
  3.                 Name="webBrowser1" VerticalAlignment="Top" Width="800" /> 
  4.     <Button Content="加载百度" Height="39" HorizontalAlignment="Left" 
  5.             Margin="25,58,0,0" Name="button1" VerticalAlignment="Top" 
  6.             Width="141" Click="button1_Click" /> 
  7.     <Button Content="打开写字本" Height="39" HorizontalAlignment="Left" 
  8.             Margin="314,58,0,0" Name="button2" VerticalAlignment="Top" 
  9.             Width="141" Click="button2_Click" /> 
  10.     <Button Content="创建文件" Height="39" HorizontalAlignment="Left" 
  11.             Margin="626,58,0,0" Name="button3" VerticalAlignment="Top" 
  12.             Width="141" Click="button3_Click" /> 
  13. </Grid> 

        接着我们来看CS代码如下:

 

 
  1. private void button1_Click(object sender, RoutedEventArgs e) 
  2. //访问百度 
  3. this.webBrowser1.Source = new Uri("http://www.baidu.com/"
  4. UriKind.RelativeOrAbsolute); 
  5.  
  6. private void button2_Click(object sender, RoutedEventArgs e) 
  7. //打开一个记事本文件 
  8. dynamic cmd = AutomationFactory.CreateObject("WScript.Shell"); 
  9. cmd.Run(@"c:\windows\notepad.exe", 1, true); 
  10. Random _rnd = new Random(); 
  11. private void button3_Click(object sender, RoutedEventArgs e) 
  12. // 创建一个文件存放路径 
  13. var tempDirectory = @"c:\temp"
  14. if (!Directory.Exists(tempDirectory)) 
  15. Directory.CreateDirectory(tempDirectory); 
  16.  
  17. // 创建文件全名 
  18. var filename = string.Format("tempFile-{0}.txt", _rnd.Next(0, 65536)); 
  19. var fullPath = System.IO.Path.Combine(tempDirectory, filename); 
  20.  
  21. // 写入一个新的文件 
  22. using (FileStream fs = File.Create(fullPath)) 
  23. using (StreamWriter sr = new StreamWriter(fs, Encoding.UTF8)) 
  24. sr.WriteLine("这是一个可被信任的XAP文件"); 
  25.  
  26. // 通知用户 
  27. MessageBox.Show("文件已经创建成功"); 
  28.  

        最后我们来看点击三个按钮的效果分别如下面三图:

       本实例采用VS2010+Silverlight 5 beta编写,如需源码请点击 SL5Trusted.zip 下载。



本文转自程兴亮 51CTO博客,原文链接:http://blog.51cto.com/chengxingliang/826427

相关文章
|
7月前
|
缓存 自然语言处理 API
关于 Spartacus 开源 Storefront 在 PWA 模式下运行时的 index.html hash mismatch 问题
关于 Spartacus 开源 Storefront 在 PWA 模式下运行时的 index.html hash mismatch 问题
54 0
|
6月前
|
Web App开发 移动开发 JavaScript
【前端用法】HTML5 Video标签如何屏蔽右键视频另存为的js代码以及如何禁用浏览器控件,Video 禁止鼠标右键下载
【前端用法】HTML5 Video标签如何屏蔽右键视频另存为的js代码以及如何禁用浏览器控件,Video 禁止鼠标右键下载
168 0
|
3月前
|
移动开发 JavaScript 前端开发
如何处理html5新标签的浏览器兼容问题?
如何处理html5新标签的浏览器兼容问题?
17 0
|
3月前
|
搜索推荐 前端开发 UED
html页面实现自动适应手机浏览器(一行代码搞定)
html页面实现自动适应手机浏览器(一行代码搞定)
56 0
|
3月前
|
JavaScript 前端开发
JavaScript DOM 操作:如何检测浏览器是否支持某个特性?
JavaScript DOM 操作:如何检测浏览器是否支持某个特性?
24 0
|
4月前
|
编解码 JavaScript 前端开发
BOM和DOM:BOM(浏览器对象模型)提供了与浏览器交互的能力,如弹窗、定时器等;DOM(文档对象模型)提供了操作HTML元素的能力,如获取、修改元素内容和属性。
BOM和DOM:BOM(浏览器对象模型)提供了与浏览器交互的能力,如弹窗、定时器等;DOM(文档对象模型)提供了操作HTML元素的能力,如获取、修改元素内容和属性。
38 2
|
4月前
【JavaWeb学习】—手托html页面和在浏览器中输入地址访问的背后不同原因(十一)
【JavaWeb学习】—手托html页面和在浏览器中输入地址访问的背后不同原因(十一)
|
5月前
|
移动开发 资源调度 JavaScript
html2canvas 一个强大的使用js开发的浏览器网页截图工具
html2canvas 一个强大的使用js开发的浏览器网页截图工具
41 0
|
5月前
vscode用浏览器预览运行html文件
vscode用浏览器预览运行html文件
55 2
|
5月前
|
Web App开发 JSON 前端开发
根据markdown文件反向转换成chrome浏览器书签html
前几天手贱直接把 bookmark 的源文件给删了,这下这么多年收藏整理的书签只有自己博客里的一个 markdown 文件了,毕竟还是直接用浏览器自带的 bookmark 查看会方便好多,只能想办法怎么根据现在的 markdowm 文件转换回 bookmark.html 文件了
48 0