通过E-mail共享Java 对象
jdk1.1的新功能--序列化接口(serializableinterface),简化了对象持久化(persistence)的实现。以下介绍如何通过smtpe-mail将对象传送给另一个用户。
摘要:一些应用程序需要以一种非实时的方式(例如旅行指南、错误报告(bugreport)、 时间表(timesheet)等)和其余用户共享对象。java语言开发工具包(jdk)1.1版提供了一 个重要的功能:java.io.serializable接口。该技术能让你知道如何序列化一个对象,然 后用e-mail传给其它用户。
对象持久化和用户间对象共享是许多商业解决方案的基础。例如,一个公司可以用从本公司网址启动的applet来完成一个时间表的制作。同样该公司也可以提供象具有开支报告、旅行指 南、错误报告(bugreport)等功能的applet。在这些情况下,从applet的使用者获得的数据需要和负责薪水、付款、旅行房间预订的人们共享。执行这些职能的人们可能分布在不同的 城市和国家,可能工作在不同的时区,不能希望每个工作人员都能象猫头鹰一样在晚上工作以填写这样的表格。相同的信息也不应该重新输入。因此,能够存储并且把这些相关对象传 送到商业应用中是这些applet有别于其它applet的优势。
目前已经有许多方法能实现对象的持久化,例如使用对象数据库和磁盘文件。同样的也有许多办法可以共享对象,例如将数据写入一个套接字,或者实现一个符合corba,som的模 型。以上这几种方案均有自己的优点,当你设计你的商业解决方案时,需要认真地考虑这些方案。但是,还有一种开销不大但可靠的方法,它使用internet和intranet用户能够获取的 技术服务在世界范围传送对象的拷贝。它就是简单邮件传输协议,smtp。
用e-mail发送java对象
存储和保存对象的一个简单方法是将对象序列化而后用e-mail将它发送给别的用户。这种 方法有以下优点:
.发送的计算机或nc(网络计算机)无需硬盘空间
.使用现有的系统传送、排队、发送对象
.允许用户使用最喜欢的邮件客户程序来接受邮件
.提供简单的机制将同一对象的拷贝分发给许多人
这种方法也有不足之处:
邮件的传送可能因为e-mail主机的关机而被较长时间地延迟。所有的主机都可能出现这 种情况,e-mail服务器的错误恢复优先级通常比数据库服务器低。邮件的传送不能得到保证--在你的e-mail服务器通知你邮件没有发出时,你不得不重新 发送邮件。 e-mail服务器和pop客户程序的功能不足以处理大量交易信息。这些不足和你使用的应用程序有关。对于很多商业解决方案,这些不足并不重要。作为一个设计人员,你工作的一部分就是在全面考虑价格、性能和需求的情况下确定系统的最佳整体结构。
使用java传送对象的四个步骤:
applet必须依次以下面所列出的四个步骤传送java对象:
.序列化有关对象
.发送时选择base64编码方式对序列化对象编码(rfc1521)
.与一个smtp服务器连接
.将该对象传送到这个smtp服务器
下面将介绍如何用e-mail发送一个假设的"臭虫"报告到公司的质量保证部门。
将对象序列化
jdk1.1提供的一个奇妙的机制,java.io.serializable接口,能够序列化并且重建对象。 这个接口能使用存储对象(writeobject())和恢复对象(readobject())方法函数。在很多 情况下,使用这个接口很方便,只需实现并且调用这两个方法函数。
以下的代码定义了一个简单的bugreport对象,它实现了最简单的序列化接口。
1 import java.io.*;
2 public class bugreport implements serializable {
3 private float m_softwareversion; // version number from help.about, e.g. "1.0"
4 private string m_errordescription; // description of error
5 private int m_severity; // 1=system unusable - 5=minor aesthetic defect
6 public bugreport (float softwareversion, string errordescription, int severity) {
7 m_softwareversion = softwareversion;
8 m_errordesctiption = errordescription;
9 m_severity = severity;
10 }
11 public bugreport () {} // for reconstituting serialized objects
12 public void save (outputstream os)
13 throws ioexception {
14 try {
15 objectoutputstream o = new objectoutputstream(os);
16 o.writeobject(this);
17 o.flush();
18 }
19 catch (ioexception e) {throw e;}
20 }
21 public bugreport restore (inputstream is)
22 throws ioexception, classnotfoundexception {
23 bugreport restoredbugreport = null;
24 try {
25 objectinputstream o = new objectinputstream(is);
26 restoredbugreport = (bugreport)o.readobject();
27 }
28 catch (ioexception e) {throw e;}
29 catch (classnotfoundexception e) {throw e;}
30 return restoredbugreport;
31 }
32 }
文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。