Java中的RMI机制和JVM沙箱安全框架。
1. Java中的RMI机制
RMI的全称是远程方法调用,相信不少朋友都听说过,基本的思路可以用一个经典比方来解释:A计算机想要计算一个两个数的加法,但A自己做不了,于是叫另外一台计算机B帮忙,B有计算加法的功能,A调用它就像调用这个功能是自己的一样方便。这个就叫做远程方法调用了。
远程方法调用是EJB实现的支柱,建立分布式应用的核心思想。这个很好理解,再拿上面的计算加法例子,A只知道去call计算机B的方法,自己并没有B的那些功能,所以A计算机端就无法看到B执行这段功能的过程和代码,因为看都看不到,所以既没有机会窃取也没有机会去改动方法代码。EJB正式基于这样的思想来完成它的任务的。当简单的加法变成复杂的数据库操作和电子商务交易应用的时候,这样的安全性和分布式应用的便利性就表现出来优势了。
好了,回到细节上,要如何实现远程方法调用呢?我希望大家学习任何技术的时候可以试着依赖自己的下意识判断,只要你的想法是合理健壮的,那么很可能实际上它就是这么做的,毕竟真理都蕴藏在平凡的生活细节中。这样只要带着一些薄弱的Java基础来思考RMI,其实也可以想出个大概来。
a) 需要有一个服务器角色,它拥有真正的功能代码方法。例如B,它提供加法服务
b) 如果想远程使用B的功能,需要知道B的IP地址
c) 如果想远程使用B的功能,还需要知道B中那个特定服务的名字
我们很自然可以想到这些,虽然不完善,但已经很接近正确的做法了。实际上RMI要得以实现还得意于Java一个很重要的特性,就是Java反射机制。我们需要知道服务的名字,但又必须隐藏实现的代码,如何去做呢?答案就是:接口!
举个例子:
public interface Person(){
public void sayHello();
}
Public class PersonImplA implements Person{
public PersonImplA(){}
public void sayHello(){ System.out.println(“Hello!”); }
}
Public class PersonImplB implements Person{
public PersonImplB(){}
public void sayHello(){ System.out.println(“Nice to meet you!”); }
}
客户端:Person p = Naming.lookup(“PersonService”);
p.sayHello();
就这几段代码就包含了几乎所有的实现技术,大家相信么?客户端请求一个say hello服务,服务器运行时接到这个请求,利用Java反射机制的Class.newInstance()返回一个对象,但客户端不知道服务器返回的是 ImplA还是ImplB,它接受用的参数签名是Person,它知道实现了Person接口的对象一定有sayHello()方法,这就意味着客户端并不知道服务器真正如何去实现的,但它通过了解Person接口明确了它要用的服务方法名字叫做sayHello()。
如此类推,服务器只需要暴露自己的接口出来供客户端,所有客户端就可以自己选择需要的服务。这就像餐馆只要拿出自己的菜单出来让客户选择,就可以在后台厨房一道道的按需做出来,它怎么做的通常是不让客户知道的!(祖传菜谱吧,^_^)
最后一点是我调用lookup,查找一个叫PersonService名字的对象,服务器只要看到这个名字,在自己的目录(相当于电话簿)中找到对应的对象名字提供服务就可以了,这个目录就叫做JNDI (Java命名与目录接口),相信大家也听过的。
有兴趣的朋友不妨自己做个RMI的应用,很多前辈的博客中有简单的例子。提示一下利用Jdk的bin目录中rmi.exe和 rmiregistry.exe两个命令就可以自己建起一个服务器,提供远程服务。因为例子很容易找,我就不自己举例子了!
2. JVM沙箱&框架
RMI罗唆得太多了,实在是尽力想把它说清楚,希望对大家有帮助。最后的最后,给大家简单讲一下JVM框架,我们叫做Java沙箱。Java沙箱的基本组件如下:
a) 类装载器结构
b) class文件检验器
c) 内置于Java虚拟机的安全特性
d) 安全管理器及Java API
其中类装载器在3个方面对Java沙箱起作用:
a. 它防止恶意代码去干涉善意的代码
b. 它守护了被信任的类库边界
c. 它将代码归入保护域,确定了代码可以进行哪些操作
虚拟机为不同的类加载器载入的类提供不同的命名空间,命名空间由一系列唯一的名称组成,每一个被装载的类将有一个名字,这个命名空间是由Java虚拟机为每一个类装载器维护的,它们互相之间甚至不可见。
我们常说的包(package)是在Java虚拟机第2版的规范第一次出现,正确定义是由同一个类装载器装载的、属于同一个包、多个类型的集合。类装载器采用的机制是双亲委派模式。具体的加载器框架我在Java杂谈(一)中已经解释过了,当时说最外层的加载器是AppClassLoader,其实算上网络层的话AppClassLoader也可以作为parent,还有更外层的加载器URLClassLoader。为了防止恶意攻击由URL加载进来的类文件我们当然需要分不同的访问命名空间,并且制定最安全的加载次序,简单来说就是两点:
a. 从最内层JVM自带类加载器开始加载,外层恶意同名类得不到先加载而无法使用
b. 由于严格通过包来区分了访问域,外层恶意的类通过内置代码也无法获得权限访问到内层类,破坏代码就自然无法生效。
附:关于Java的平台无关性,有一个例子可以很明显的说明这个特性:
一般来说,C或C++中的int占位宽度是根据目标平台的字长来决定的,这就意味着针对不同的平台编译同一个C++程序在运行时会有不同的行为。然而对于 Java中的int都是32位的二进制补码标识的有符号整数,而float都是遵守IEEE 754浮点标准的32位浮点数。
PS: 这个小弟最近也没时间继续研究下去了,只是想抛砖引玉的提供给大家一个初步认识JVM的印象。有机会了解一下JVM的内部结构对今后做Java开发是很有好处的。
分享到:
相关推荐
8. **分布式系统**:Java在构建分布式系统方面的工具和框架,如RMI、JMS、Dubbo、gRPC等,是论文集中的重要组成部分。可能探讨了如何利用这些技术解决跨网络通信的问题。 9. **Java性能监控与诊断**:利用JMX、...
3. **RMI(Remote Method Invocation)**:RMI是Java中的远程方法调用机制,允许分布式系统的组件之间进行通信。然而,RMI连接可能会暴露在未授权的网络访问下,导致DoS攻击或远程代码执行。因此,RMI服务应进行安全...
XML和SOAP(Simple Object Access Protocol)在JAVA中被广泛用于数据交换,特别是在B2B(Business-to-Business)交易中,它们为不同系统间的数据交换提供了标准化的方式,同时保持了数据的隐私和安全。 最后,JAVA...
此外,还会讨论Java的权限模型和如何处理安全异常,以确保应用程序的稳定性和安全性。 第四章:网络移动性 随着互联网的发展,网络移动性成为现代软件的重要需求。Java以其在网络编程上的优势,为开发分布式应用...
安全性是Java设计的重要考虑,它提供了一套安全模型,包括类加载机制、安全沙箱和安全管理器,以防止恶意代码的执行。Java还可以通过数字签名和权限控制来保护代码的完整性和用户的安全。 Java的高性能主要归功于...
7. **健壮性**:Java有严格的类型检查和异常处理机制,通过数组边界检测、字节码校验等手段保证程序的稳定性和安全性。 8. **高性能**:Java的自动内存管理,包括垃圾回收机制,有效防止内存泄漏,提升了程序性能。...
### 初识JVM – JVM概念 ...JVM是Java生态系统的核心组成部分,不仅提供了强大的跨平台能力,还不断通过技术创新来提高执行效率和安全性。随着Java语言的发展,JVM也在不断进化和完善,以适应日益复杂的应用需求。
安全是Java设计中的重要考量,它通过沙箱模型和严格的类加载机制确保代码在执行时不会破坏系统安全。此外,Java还提供了一套安全管理框架,允许开发者控制程序的访问权限。 平台独立性是Java的标志性特征,Java程序...
在金融行业,Java因其稳定性和安全性而受到青睐。许多银行和金融机构使用Java来构建交易系统,特别是在高频交易领域,Java的性能优化和低延迟特性得到了充分利用。 在移动应用领域,Android操作系统虽然使用了自己...
综上所述,Java编程技术因其实时、独立和安全等优势,在计算机软件开发领域发挥了重要作用,并且已经发展成为一个不可替代的编程语言。通过对JDBC、Java注解、Java RMI等技术的研究和应用,Java不断拓展其应用范围,...
9. 安全性:Java有一套完善的安全模型,包括沙箱机制、类加载机制和安全管理器,以保护系统免受恶意代码的攻击。 JDK、JRE和JVM的关系如下: - JDK是Java开发工具包,包含了JRE和开发、调试所需的工具,如javac...
- **安全性**:Java提供了一系列安全机制,如沙箱模型和权限控制,以保护运行时环境不受恶意代码侵害。 - **平台独立性**:Java程序编写一次,即可在任何支持Java虚拟机(JVM)的平台上运行。 - **多线程**:Java...
根据提供的信息,我们可以...它的跨平台性、面向对象设计、分布式能力、健壮性和安全性等特点使其成为企业级应用、移动应用和嵌入式系统的理想选择。随着Java不断发展和完善,它将继续在未来的技术领域扮演重要角色。
此外,JAVA语言在设计时就考虑了沙箱安全模型,这种模型限制了程序的执行,防止了恶意代码的执行。 JAVA语言还具有强大的网络编程能力,这一点在现代互联网技术飞速发展的背景下尤为重要。网络编程是JAVA语言的一个...
对于并发编程,书中详细讲解了Java线程(Java Threads)的概念、创建方法和同步机制,帮助读者理解多线程编程的关键技术,如线程安全、死锁预防等。在网络编程方面,本书介绍了Java网络编程的基础,包括套接字编程、...
2. **安全性和稳定性**:Java2加强了安全性措施,包括沙箱机制、数字签名等,确保应用程序不会对系统造成损害。同时,它的垃圾回收机制也提高了程序的稳定性和响应速度。 3. **多线程支持**:Java2提供了强大的多...
3. **安全性**:Java内置的安全机制,如类加载器和沙箱模型,为网络环境中的应用程序提供了安全保障。 4. **面向对象编程**:Java是一种纯面向对象的语言,其封装、继承、多态等特性使得代码结构更加清晰,易于维护...
Java 和 C#是两种在现代软件开发中广泛使用的高级编程语言,它们虽然有着共同的根源,但也有着各自独特的特性和优势。这篇文章将深入探讨Java和C#在设计哲学、语法、性能、安全性以及应用领域等方面的主要异同。 ...
而Java小程序通常嵌入到Web页面中,由浏览器中的Java虚拟机(JVM)执行,提供动态网页内容。 Java语言的诞生与互联网的发展密切相关。随着1990年代互联网的兴起,特别是万维网的普及,Sun公司预见到了在Web页面中...