`
together
  • 浏览: 220066 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

你的系统是跨平台的吗?

    博客分类:
  • java
阅读更多
开发java应用,听到的最多的一句话就是“跨平台”,那么现在小声的问一句,你开发的系统真的能跨平台吗?
以我的拙见,所谓的跨平台,包含五方面的内容:
一、跨应用服务器
二、跨数据库
三、跨操作系统
四、跨浏览器
五、多语言支持

下面分别来说一下。
■跨应用服务器
  这一点,看起来好像有些多余,java的口号之一不就是“一次编译,到外运行”嘛,可实际经验告诉我们,这仅仅是一个口号而已。实际中是“一次编译,到处调试”。为什么会这样?从应用服务器来说,各个产品或多或少都在标准的java规范之上进行了一些拓展,小规模的应用开发,多以tomcat为基准;大规模的应用,多以weblogic/websphere为基准。
那么开发完成的应用,可否在所有的应用服务器上正常部署呢?答案是否定的。在tomcat5上部署没问题,在tomcat4上却可能有问题;在tomcat5/4上没问题,却可能在resin/jetty/weblogic/websphere上有问题。在我的经历中,在resin/jetty/weblogic为基准进行开发的应用,部署到tomcat上基本上没什么问题。但是以tomcat为基准的应用,部署到其他应用服务器中,却可能出现各种各样的问题。这与tomcat本身的定位和开发方式有关,它更像是一个学术产品,而不是一个商业产品。
  小型的应用,我偏好resin,它的速度、稳定性、兼容性、中文处理,都是非常不错的。相比而言,以“纯java、快速”著称的jetty,就不太令人满意。jetty的4/5/6各个版本中,对session的存放位置、web.xml的标准、struts的plugin的支持、log4j的处理,都各不相同。在最新的jetty6中,竟然会要命地“不能使用session.validate()”方法,一使用此方法之后,就无法再使用set/getAttribute了。
  也曾经在将一个应用转移到websphere5上时,费劲周折。这个应用跑在其他应用服务器上都没问题,但是一部署到ws5上,就无法正常加载struts的配置文件。本以为是struts配置文件写得有问题,但即便把所有的action/form配置均去掉,只保留一个空的配置文件,也无法正常启动。最后实在无法,只能乱碰运气,考虑是否是struts的几个jar包版本有问题,经检查,发现应用中使用的是struts1.2的jar包,换成struts1.1的jar包,再启动后就一切正常。这样的问题,可真的是折磨人呢。
  所以,我认为跨应用服务器是很重要的。你不能告诉客户,俺们的系统只能跑在tomcat下面,至于您花重金购买的weblogic/websphere,对不起,我们暂时还不支持。客户会吐血的。
■跨数据库
  经常看到某大公司产品,要求必须使用oracle或者sqlserver数据库,你想换个数据库来部署?没门,人家说了,我们的产品只支持这一种数据库,你就老实的用吧。但对于客户方来说,为了减少投资,并且保证内部系统尽可能使用同一种数据库以减少维护成本(总不能请一个oracle DBA,再请一个sqlserver DBA吧?),总会希望新系统使用的数据库是以前用过的吧。
  现在有了hibernate,在此基础上开发的应用,基本上是能满足跨数据库要求的,个人认为这是hibernate最大的亮点。但也要注意,在开发中尽可能考虑到不同数据库的特性。诸如sqlserver的text/image字段上不能查distinct,oracle内的各种对象名称长度不得超过30等,尽量不要调用数据库的内部特性(如存储过程、视图等)
■跨操作系统
  这一点,貌似没有什么可说的,很少有开发出的系统只能部署在一种操作系统上的。不过有一点也要注意,如果系统中某些功能依赖于通过JNI来调用windows本地组件的话,比如打印、word/excel操作,或与只能运行在windows下的报表组件(如国内的数巨报表、如意报表)集成的话。
■跨浏览器
  窃以为,如果只是做国内的应用,这一点倒不重要,就以IE为标准来开发也未尝不可。
PS:完全支持IE也不是一件容易的事情,IE5/6本身就有不少的差异。
但如果产品本身想立足于世界,想与国外产品竞争,对浏览器的全面支持也必不可少。至少应该同时支持ie和firefox吧,如果对自身严格要求的话,我认为应以opera为标准,opera对html/css/javascript的标准是实现和支持得最好的浏览器。
■多语言支持
  如果您的产品只想在中国卖,根本就不考虑世界市场,那这一条就pass好了。
  但对于面向全球市场的产品来说,在开发之初不考虑多语言支持(不是没有啊),等有一天,公司老板决定要向全球推出该产品的时候,嗯,才发现,要对系统进行伤筋动骨的大手术,就等着哭吧。
分享到:
评论
5 楼 LucasLee 2006-10-19  
together 写道
给我的感觉,只要firefox上跑起来没问题,在ie上基本都正常。


我以前也以为是这样的。
自从我使用CSS作布局就改变看法了。

IE有很多智能的判断,好还是坏难说,Firefox就没有。
比如一个DIV框,指定了高度,里面嵌入一个DIV,如果里面的高度比前者大,
IE里会自动扩展外部的DIV;
Firefox就不会,结果两个DIV的边框交错了...

这个例子是IE到Firefox的,反过来也有很多啦,暂时记不起来了。
4 楼 together 2006-10-19  
交流经验嘛,不然怎么叫论坛呢?
我现在开发的时候,会同时用tomcat/resin/jetty/weblogic来测试。在linux当然非常简单了,做个符号连接就OK了。想用哪个就启动哪个好了。数据库会使用mysql/oracle/sqlserver,浏览器就用firefox。给我的感觉,只要firefox上跑起来没问题,在ie上基本都正常。可能有些css需要再细调一下,来保证效果的完全一致。比如event的触发、xy定位、script控制table等。
3 楼 abcd123efg123 2006-10-19  
File.seperator,仅在windows上做开发,可能容易有这方面的问题。所以得测试在不同操作系统上做部署。
2 楼 LucasLee 2006-10-19  
楼主总结得还不错。不过看上去似乎经验不足。(我说错了请原谅我)

我补充几点:
1.跨应用服务器。这个痛苦我比较有体会。(注意:但tomcat5到4之间的的跨越可能意义不大,因为支持的servlet ,jsp spec版本不同;倒过来是应该完全兼容的。)
  1.1 EJB跨应用服务器。虽然有spec,但每家都有自己的扩展,有些特别要命特性比如,EJB spec2.0里居然对like 只支持常数,就是不能传入?。
   然后EJB的配置文件都有各自的扩展,真是痛苦。好在Jbuilder可以自动转换Weblogic到Jboss,但也不是那么好,总有魔鬼的细节要你反复调试。
   1.2无EJB的跨应用服务器。这个容易多了,但居然也不是很顺利的。我的war曾经在tomcat上调试好了,发布到websphere5上就失败。最后用二分法逐次删除app里的文件,发现引起问题的居然是...eclipse产生的.classpath文件!websphere对eclipse支持得太好了吧?删掉即可。
    这就算好的了。我后来把在tomcat5上调试好的war发布到resion3上,更郁闷。我在网上查了resion内置了自己的xml parser,导致我的castor xml无法正确执行,要更换parser,需要N步...遂放弃...

2.跨浏览器。这个绝不是很容易的事情。Javascript就够你喝一壶的,各种细微差别,各种特殊的扩展...,这个到罢了,到CSS,更有玩意,特别是主要用CSS布局的,有得玩,这一点上如果采取老式的Table布局,兼容性倒是很不错。还来新玩意要慎用。
3.跨数据库。
  这个有hibernate之类的封装,就好多了。不用它,问题也不会很大,可参考我以前的帖子。(当然如果你用了stored procedure或trigger之类,只能手动挨个重写了)
4.跨操作系统。
  这个听上去是最容易的。但我还是碰到了几个问题。
  4.1文件路径的分隔符。windows下似乎能兼容Unix的分隔符,但反之不可。不能随意的用/或\,最好是用Java里提供的File.seperator。
  4.2字符编码问题。一般我们会是用中文版的windows,默认编码是GBK;Unix可能会有差别,所以在使用new String(byte[]),String.toBytes()等与编码相关的操作时,要注意,可以指定编码。最好还是全部使用UTF-8。
5.国际化问题
  这里暂只说文字的国际化。
  需要将文字资源外部化,并且全部用UTF-8编码,根据Local选择文字资源等等。不难也不简单。
1 楼 robbin 2006-10-19  
Java做的web应用跨操作系统,跨语言一般都没有啥问题。跨应用服务器只要不用太多高级特性也没有啥问题,就是AJAX应用跨浏览器太难了。

相关推荐

    java跨平台性

    Java 跨平台性是 Java 语言的一项重要特性,它允许 Java 程序在不同的操作系统平台上运行,而不需要重新编译。这种跨平台性是通过 Java 虚拟机(JVM)来实现的。 Java 跨平台性的定义是指 Java 程序可以在不同的...

    【QGIS跨平台编译】之【MiniZip跨平台编译】:MacOS环境下编译成果(支撑QGIS跨平台编译,以及二次研发)

    QGIS是一个开源的、跨平台的地理信息系统(GIS)软件,用于浏览、编辑和分析地理空间数据,提供了一套丰富的功能,包括地图制作、空间分析、数据管理等。QGIS可以在Windows、Mac OS和Linux等操作系统上运行。 QGIS的...

    vs2019跨平台.pdf

    VS2019 跨平台使用技巧的主要目的是为了在 Windows 上编辑代码,然后通过网口上传到另一个 Linux 系统上,并进行编辑的过程。以下是 VS2019 跨平台使用技巧的详细说明: 一、Linux 远程开发——传统的 sln 项目 1....

    用JSP开发的Web应用是跨平台的

    Java语言之所以能够实现跨平台,关键在于其编译后的字节码(Bytecode)可以在各种操作系统上的JVM中运行。无论是在Windows还是Linux环境下,只要安装了兼容版本的JVM,就可以执行相同的Java程序。因此,基于Java技术...

    是什么阻碍了我们跨平台

    3. **选择跨平台的第三方软件和数据库**:对于数据库需求,可以选择MySQL、PostgreSQL等跨平台数据库系统,这些系统在多种操作系统上都有良好的支持。 4. **使用跨平台的第三方库**:如OpenGL库用于图形渲染,...

    C++跨平台开发技术指南.pdf

    跨平台开发是软件开发领域中的一个重要方面,它允许开发者使用统一的代码库来构建能在多种操作系统上运行的应用程序,这不仅可以减少开发和维护成本,还能扩大应用的潜在用户基础。 书中首先讨论了Netscape浏览器在...

    《C/C++编写跨平台程序:实践篇》

    本书《C/C++编写跨平台程序:实践篇》主要面向已经具备一定C/C++基础的读者群体,旨在教授如何使用C/C++这一强大的编程语言来编写可以在多个操作系统上运行的跨平台程序。跨平台编程不仅需要对语言有深入理解,还要...

    Go 语言跨平台 GUI 自动化系统.zip

    Go 语言跨平台 GUI 自动化系统, 控制键盘、鼠标、位图和读取屏幕, 窗口句柄以及全局事件监听 Go 语言跨平台 GUI 自动化系统, 控制键盘、鼠标、位图和读取屏幕, 窗口句柄以及全局事件监听 Go 语言跨平台 GUI 自动化...

    基于ASP.net的跨平台智能云管理系统源码.zip

    【标题】中的“基于ASP.net的跨平台智能云管理系统源码”表明这是一个使用ASP.NET技术开发的、具备跨平台特性的智能云管理系统的源代码集合。ASP.NET是微软公司推出的一种用于构建Web应用程序的框架,它基于.NET ...

    金盾跨平台视频加密系统2021.rar

    金盾跨平台视频加密系统2021是一款专为个人和企业设计的高效视频保护工具。该系统的主要功能是确保视频内容的安全性,防止未经授权的访问、复制或传播。通过强大的加密技术,用户可以轻松地对自有的视频资料进行加密...

    java跨平台

    对于编程语言而言,跨平台能力意味着开发者编写的程序无需修改或只需少量修改就能在不同的操作系统或硬件平台上运行。 #### 平台与指令集的关系 一个平台通常指特定的操作系统与CPU的组合。不同类型的CPU有着各自...

    基于C++实现的支持多操作系统,跨平台,跨协议,跨互联网的远程控制、远程桌面软件源代码

    基于C++实现的支持多操作系统,跨平台,跨协议,跨互联网的远程控制、远程桌面软件源代码 一个跨平台,支持多协议的远程控制软件。 能让你在任何地方使用任何设备和系统通过任意方式远程管理任意设备和系统。 它包括...

    国产的跨平台的开源gui 框架

    标题中的“国产的跨平台的开源GUI框架”指的是由中国开发者创建的一种图形用户界面(GUI)开发框架,它具有跨平台的特性,可以在多种操作系统上运行,如Windows、Linux、macOS等。这样的框架通常采用开源许可证,...

    wxWidgets跨平台程序开发

    《wxWidgets跨平台程序开发》系统地介绍了wxWidgets及其跨平台程序开发。全书共有20章,第·1·章简要介绍了·wxWidgets·的发展历史和框架结构,第2章介绍了wxWidgets的程序框架及其实现,第3章深入剖析了wxWidgets...

    一个C#跨平台UI框架,支持Windows、Mac、Linux,支持国产Linux

    标题中的“C#跨平台UI框架,支持Windows、Mac、Linux,支持国产Linux”指的是一种使用C#语言开发的用户界面(UI)框架,它能够兼容多种操作系统平台,包括微软的Windows、苹果的MacOS以及开源的Linux系统,特别地,...

    c++跨平台开发

    在现代软件开发领域,跨平台开发成为了一种趋势,它允许开发者编写的代码可以在多种操作系统上运行,无需进行大量的修改或重写。C++作为一种强大的编程语言,因其高效、灵活以及对底层硬件的直接控制能力而备受青睐...

    Java跨平台的原理

    这一特性主要得益于Java的跨平台性,使得开发者可以在不同的操作系统上编译和运行相同的代码。下面我们将详细探讨Java跨平台的原理。 #### 1. Java的字节码与JVM Java程序在编译阶段不会直接编译成本地机器码,...

    【QGIS跨平台编译】之【geos跨平台编译】:源码及跨平台编译工程(支撑QGIS跨平台编译,以及二次研发)

    QGIS是一个开源的、跨平台的地理信息系统(GIS)软件,用于浏览、编辑和分析地理空间数据,提供了一套丰富的功能,包括地图制作、空间分析、数据管理等。QGIS可以在Windows、Mac OS和Linux等操作系统上运行。 QGIS的...

    跨平台进程间通信源码

    跨平台进程间通信(IPC,Inter-Process Communication)是计算机技术中的一个重要概念,它允许不同进程之间共享数据、协调工作,实现系统资源的有效利用。在标题中提到的“跨平台进程间通信源码”可能是一个软件库...

    跨平台C SDKRoseSDK.zip

    Rose 是基于SDL的跨平台C SDK,它向应用程序提供更高级接口。 特色 基于SDL实现跨平台,支持的平台包括Windows、iOS、Android、Mac OS X、Linux。 针对最终用户,做到了跨平台,在任何平台...

Global site tag (gtag.js) - Google Analytics