开发者社区> 科技小能手> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
2013年五大主流浏览器 HTML5 和 CSS3 兼容性大比拼
  转眼又已过去了一年,在这一年里,Firefox 和 Chrome 在拼升级,版本号不断飙升;IE10 随着 Windows 8 在去年10月底正式发布,在 JavaScript 性能和对 HTML5 和 CSS3 的支持方面让人眼前一亮。
1024 0
Groundwork:响应式 HTML5,CSS & JavaScript 工具包
  Groundwork 是基于强大的 CSS 预处理器 Sass & Compass 的响应式 HTML5,CSS & JavaScript 工具包。使用 Groundwork,您可以快速构建 Web 应用程序。
520 0
2012五大主流浏览器 HTML5 和 CSS3 兼容性大比拼
  距离上一次发布《五大主流浏览器 HTML5 和 CSS3 兼容性大比拼》转眼已过去一年,在这一年里,浏览器领域的竞争愈演愈烈。Firefox 成为新的“版本帝”但依然未能摆脱被 Chrome 超越的命运,支持更多标准的 IE10 将随着 Windows 8 在10月底正式发布,淡定的 Opera 也在上个月发布了新版本,国内的各大浏览器厂商更是掀起一轮又一轮的 HTML5 跑分竞赛。
1057 0
HTML5实践 -- 如何使用css创建三角形,使用CSS3创建3d四面体
  今天读了篇关于如何使用css3创建3d四面体的文章,觉的相当不错,所以拿出来和大家分享一下。原文地址:http://www.paulrhayes.com/2010-10/css-tetrahedron/。
815 0
HTML5实践 -- 使用css装饰你的图片画廊 - part2
  转载请注明原创地址:http://www.cnblogs.com/softlover/archive/2012/11/20/2779893.html     在上一讲中,我们的解决方案使用到了jquery去创建一个span标签。
752 0
html5 css 万能的position大法
水平居中的text-align:center 和 margin:0 auto   这两种方法都是用来水平居中的,前者是针对父元素进行设置而后者则是对子元素。
980 0
文章
问答
文章排行榜
最热
最新
相关电子书
更多
《零基础HTML入门教程》
立即下载
利用 Poplayer 在手淘中实现稳定业务和临时业务分离
立即下载
WEB浏览器中即将发生的安全变化
立即下载