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

相关文章
|
8月前
|
缓存 自然语言处理 API
关于 Spartacus 开源 Storefront 在 PWA 模式下运行时的 index.html hash mismatch 问题
关于 Spartacus 开源 Storefront 在 PWA 模式下运行时的 index.html hash mismatch 问题
54 0
|
8月前
|
Web App开发 Windows
让网页自动调用双核浏览器的极速模式
让网页自动调用双核浏览器的极速模式
67 0
|
2月前
|
Web App开发 数据可视化 测试技术
Selenium Headless模式:无头浏览器的使用与优势
Selenium Headless模式是无界面的自动化测试方式,适用于Chrome和Firefox等浏览器,提供更快的速度、更高的隐秘性和资源节省。在Python中启用该模式,需导入Options并设置相关参数。示例代码展示了如何在无头模式下访问网站、执行点击和输入操作。这种模式提升了测试效率和稳定性,尤其适合大规模测试和CI环境。
47 1
|
4月前
|
JavaScript 前端开发
JavaScript DOM 操作:如何检测浏览器是否支持某个特性?
JavaScript DOM 操作:如何检测浏览器是否支持某个特性?
26 0
|
5月前
|
Web App开发 Windows
Windows【Chrome浏览器 02】Auto Dark Mode for Web Contents 无需安装插件开启chrome浏览器黑暗模式
Windows【Chrome浏览器 02】Auto Dark Mode for Web Contents 无需安装插件开启chrome浏览器黑暗模式
78 0
|
5月前
|
JavaScript
sgSpeedMode.js判断360浏览器是“兼容模式”,提示使用“极速模式”
sgSpeedMode.js判断360浏览器是“兼容模式”,提示使用“极速模式”
|
6月前
|
移动开发 前端开发 开发者
在HTML5中DOCTYPE的作用是什么?标准与兼容模式(混杂模式)各有什么区别?
在HTML5中DOCTYPE的作用是什么?标准与兼容模式(混杂模式)各有什么区别?
56 0
|
8月前
|
存储 搜索推荐 数据挖掘
关于微软 Edge 浏览器的 Tracking Prevention 特性在 Angular 应用中的影响
关于微软 Edge 浏览器的 Tracking Prevention 特性在 Angular 应用中的影响
70 0
|
11月前
|
运维 前端开发 JavaScript
Html|前后端分离模式的思考
Html|前后端分离模式的思考
79 0
|
12月前
|
数据采集 Web App开发 编解码
在 Linux 服务器中创建假桌面运行模拟浏览器有头模式
在 Linux 服务器中创建假桌面运行模拟浏览器有头模式
139 0