JAVA 和.NET在安全功能的比较

2016-02-19 18:57 7 1 收藏

每个人都希望每天都是开心的,不要因为一些琐事扰乱了心情还,闲暇的时间怎么打发,关注图老师可以让你学习更多的好东西,下面为大家推荐JAVA 和.NET在安全功能的比较,赶紧看过来吧!

【 tulaoshi.com - 编程语言 】

本文根据Denis Piliptchouk的文章翻译、摘录而来,有些术语翻译不太好理解,还请参考原文。

第一部分 安全配置和代码封装

安全配置

两个平台的配置都是通过XML或纯文本文件,两个平台最大的区别在于处理安全配置体系的方式不同。

在.NET平台,有图形接口和命令行二种方式来修改安全配置参数。Mscorcfg.msc是图形接口方式,CASPol.exe提供了命令行方式,适用于批处理或配置文本。

Java平台只提供了图形接口的工具policytool.exe。和.NET不同的是,它的目标对象(配置文件)的名字和位置不是固定的。

.NET定义了不同范围的安全配置文件:系统范围,本机范围,本用户范围。在配置有冲突时,原则上小范围的参数有优先权。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

JAVA和J2EE的核心配置文件都保存在固定位置,但扩展配置文件随厂家不同而不同。

代码封装:检验

JAVA 和.NET 的Common Library Runtime (CLR) 都实行内存安全或类型安全的保护机制,在这些平台开发的应用的安全性也是可以检验的。他们的实现机制有很大的不同。

在.NET, CLR总是执行编译好的代码,它不解释代码。但是在中间语言(IL)被编译之前,编译器会有验证和检验的步骤。第一步是检查文件的结构和代码完整性;第二步包括一些扩展的检查,内存安全、堆栈跟踪、数据流分析、类型检查等。在运行阶段,由VES (Virtual Execution System) 来负责安全性检查和出错意外情况处理。

在JAVA平台,JAVA虚拟机(JVM)负责类的载入、链接、检验和执行。对于已经编译和优化的代码,JVM也用二个无条件调用堆栈来保留最初的字节代码信息。

小结:和.NET不同,JVM的默认设置是不检验本地代码。另外,JVM保留最初的字节代码供运行时检查,而.NET把静态分析和运行时插入检验代码相结合。

代码封装:应用隔离

在.NET, 域隔离建立在内存安全机制的基础上,不同的域不能直接访问彼此的地址空间,只能通过.NET远程通信机制访问。

在JAVA平台,应用隔离是通过ClassLoaders 和 ProtectionDomains 相结合来实现的,安全类加载是JVM安全机制的基石。

小结:.NET的 AppDomains 就象操作系统的进程一样,使用起来比JAVA的 ProtectionDomains 更直接、轻易一些。

代码封装: 语言特征

两个平台基本上差不多,.NET在灵活性上稍微好一点。

总结:

JAVA在安全配置上有较多的优势,.NET在代码封装的选择性和易用性好一些。

第二部分 加密和通信

加密法:概论

.NET的加密法主要基于CryptoAPI 和相关扩展。大多数有关加密的类都在System.security.Cryptography, X509Centificates 和XML中。.NET利用基于流的模型来完成加密传输,所有的算法都被默认为最高的安全级别。.NET也答应用户自己在 machine.config 中定义自己的算法。

JAVA平台的加密算法分二个部分:Java Cryptography Architecture (JCA) 和 Java Cryptography Extension (JCE)。 JCE的出口受到有关法律的限制。假如要使用用户自己的加密算法,必须得到认证机构(SUN 或 IBM)的认证。

加密法:算法

.NET主要提供了下面几大类加密算法:非对称算法、HASH算法、对称算法、随机数生成法。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

JAVA提供的加密算法更多,但是较少第三方厂商可以在JAVA中提供自己的算法。


来源:http://www.tulaoshi.com/n/20160219/1619628.html

延伸阅读
标签: Web开发
Java Servlet及其特点 Servlet是Java技术对CGI编程的回答。Servlet程序在服务器端运行,动态地生成Web页面。与传统的CGI和许多其他类似CGI的技术相比,Java Servlet具有更高的效率,更容易使用,功能更强大,具有更好的可移植性,更节省投资(更重要的是, Servlet程序员收入要比Perl程序员高:-): 高效: 在传统的CGI中,每个请求都要启...
标签: Java JAVA基础
即使你不在微软的平台上写程序,你可能也听过 Microsoft 推出的「.NET」平台,此技术是用来对付非微软阵营的兵器。如果你读过微软的新闻稿,或者你浏览过 MSDN 的内容,还是你出席了微软的专业程序员会议(也就是「.NET」平台现身的地方),你可能仍有两个疑问: 「.NET」平台到底是什么? 「.NET」架构和 J2EE 有哪些差异? 如果你想得更...
根据来自数据调查公司Evans Data的分析,在实施面向服务体系架构(SOA)的时候,开发者正在呈现选择Java还是.NET的分歧。 这个调查公司在六月份进行了一个调查,调查了在Web服务项目中工作的近400名开发者。这些调查结果被与六个月前的调查结果进行了对比。 新的调查发现,.NET依然是实施SOA的首选平台,其中有31%的开发者计划...
原文地址:http://www.codeproject.com/dotnet/AddingTemplatesAddBox.asp 英文水平有限我就不翻译了,他主要的操作步骤如下 1、用记事本打开Microsoft Visual Studio .NET 2003\VC#\CSharpProjectItems\LocalProjectItems\Code文件夹下的code.vsdir文件找到下面的一行: ..\..\CSharpAddClassWiz.vsz|{FAE04EC1-301F-11d3-BF4B-00C04F79EFBC}...
标签: 电脑入门
我们在输入一些长的命令句的时候,常常会觉得麻烦,不过你知道吗?Terminal是具有自动补全功能的哦,现在图老师小编就教你开启的方法吧。 开启方法: 打开终端,输入: nano .inputrc 在里面粘贴上以下语句: set completion-ignore-case on set show-all-if-ambiguous on TAB: menu-complete Control+O,保存,重启终端,OK! ...

经验教程

176

收藏

41
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部