在多种浏览器中嵌入Applet

1 基本信息

摘要:一个开发好的Java Applet,是通过标准的标签(Tag)嵌入到HTML页面中的。浏览器在解析到支持的嵌入Applet的标签时,会启动Java Plug-in来渲染标签中的Java Applet。
由于历史原因,在页面中嵌入Applet产生了几种相互不兼容的方式,不同的浏览器、乃至同一个浏览器的不同版本,支持的标签都不完全相同。本文关注的是不同浏览器Applet嵌入的差异性,首先介绍几种把Applet嵌入到页面中的标签,再介绍几个能够支持多种浏览器的嵌入方式。

作者:丁向武

2 页面中嵌入Applet的几种方式

2.1 Applet Tag

  Applet标签是最早IE用来支持嵌入Java Applet的标签,那个时候微软还有自己的JAVA虚拟机。在有些版本的浏览器上,Applet标签是由浏览器自己渲染的,而不是由SUN Java Plug-in渲染的。这个标签出现的比较早,现在有些浏览器仍然能够兼容它,比如IE、Firefox等,但Netscape不支持这个标签。现在的W3C规范里,这个标签已经不推荐使用,而是被Object标签代替了。这个标签最大的问题是,在客户端没有安装Java Plug-in时,不能指定一个自动下载安装Java Plug-in的地址。

下面是这个标签的一个例子:

  1. <APPLET code="XYZApp.class" codebase="html/" archive="Sample.jar"
  2. align="baseline" width="200" height="200">
  3. <PARAM name="model" value="models/HyaluronicAcid.xyz">
  4. No Java 2 SDK, Standard Edition v 1.4.2 support for APPLET!!
  5. </APPLET>


2.2 Embed Tag

  这是Netscape Navigator 4.x浏览器支持的嵌入Applet的标签,其他浏览器很少支持这个标签的,因此实际应用的很少。这个标签不支持以内嵌Param标签的方式为Applet传递参数。

下面是这个标签的例子:

  1. <EMBED type="application/x-java-applet;jpi-version=1.4.1" width="200"
  2. height="200" align="baseline" code="XYZApp.class"
  3. codebase="html/" model="models/HyaluronicAcid.xyz"
  4. pluginspage="http://java.sun.com/j2se/1.4.1/download.html">
  5. <NOEMBED>
  6. No Java 2 SDK, Standard Edition v 1.4.1 support for APPLET!!
  7. </NOEMBED>
  8. </EMBED>


2.3 Object:clsid Tag

  这是现在IE浏览器中推荐的用来嵌入Applet的标签,如下面的例子所示。

  这个标签中的URI以“clsid”开始,只有IE浏览器支持这个属性,其他浏览器都不支持。URI以“clsid”开始,表明这是一个ActiveX控件,只有Windows中的IE才识别的属性,代表注册表中一个注册的ActiveX类,“CAFEEFAC-0014-0002-0000-ABCDEFFEDCBA”是SUN JRE安装时在Windows中注册的,代表SUN Java Plug-in 1.4.2。因此当IE解析到示例中的标签时,会通过注册表,查找到Java Plug-in,然后启动JRE,在当前位置渲染这个Applet。另外一个clsid值:“8AD9C840-044E-11D1-B3E9-00805F499D93”,代表当前最新的JRE版本。

  “codebase”属性指定了一个特定版本JRE的下载地址,当客户端机器上没有安装Java Plug-in时,会自动从这个地址下载安装Java Plug-in。

  “scriptable”属性用于指定Applet示例是否能与页面中的JavaScript交互。

  这个标签功能比较丰富,可以通过Param标签为Applet传递参数、设置需要的JDK版本、指定自动下载JRE的路径等。在IE中嵌入Applet时,都要使用这个标签。

下面是这个标签的示例:

  1. <OBJECT classid="clsid:CAFEEFAC-0014-0002-0000-ABCDEFFEDCBA"
  2. width="200" height="200" align="baseline"
  3. codebase= http://java.sun.com/products/plugin/autodl/jinstall-1_4_2-windows-i 586.cab#Version=1,4,2,0">
  4. <PARAM name="code" value="XYZApp.class">
  5. <PARAM name="codebase" value="html/">
  6. <PARAM name="type" value="application/x-java-applet;jpi-version=1.4.2">
  7. <PARAM name="model" value="models/HyaluronicAcid.xyz">
  8. <PARAM name="scriptable" value="true">
  9. No Java 2 SDK, Standard Edition v 1.4.2 support for APPLET!!
  10. </OBJECT>

2.4 Object:java Tag

  这是当前的W3C规范推荐的在浏览器中嵌入Applet的方式,除IE外的大多数浏览器的当前版本都能够支持,包括Netscape Navigator、Firefox等,并且不受操作系统平台的限制。URI以“java”开始,表明这里嵌入的是一个Java Applet,浏览器会启动Java Plug-in来渲染这个Applet对象。如果客户端没有安装Java Plug-in,浏览器会自动到Sun的站点上下载和安装最新的Java Plug-in。

下面是这个标签的示例:

  1. <OBJECT classid="java:Sample2.class"
  2. type="application/x-java-applet"
  3. archive="Sample2.jar"
  4. height="300" width="450" >
  5. <PARAM name="model" value="models/HyaluronicAcid.xyz">
  6. </ OBJECT>

3 同时支持多种浏览器的嵌入方式

  通过上面的介绍可以看到,已有的几种在页面中嵌入Applet的方式,都只能适应特定的浏览器。对于几种常用的浏览器,如IE、Netscape Navigator、Firefox等,没有一种方式能够同时适应。必须要做一项特殊处理,才能使同一段HTML代码能够适应多种浏览器。下面介绍几种方法。

3.1 组合Object:clsid、 Embed

  如下面的示例所示,把Embed标签用Comment标签包含起来,放在Object标签内部。IE在解释Object标签时,会忽略Comment标签内的内容。而Netscape Navigator不能识别clsid、不能识别Comment标签,它会忽略忽略外层的Object标签和Comment标签,而只看到Embed标签的内容。这样,这段代码可以同时适应IE和Netscape Navigator两种浏览器。

示例:

  1. <OBJECT classid="clsid:8AD9C840-044E-11D1-B3E9-00805F499D93"
  2. width="200" height="200" align="baseline"
  3. codebase="http://java.sun.com/products/plugin/1.4/jinstall-14-win32.cab#Version=1,4,0,mn">
  4. <PARAM NAME="code" VALUE="XYZApp.class">
  5. <PARAM NAME="codebase" VALUE="html/">
  6. <PARAM NAME="type" VALUE="application/x-java-applet;jpi-version=1.4">
  7. <PARAM NAME="model" VALUE="models/HyaluronicAcid.xyz">
  8. <PARAM NAME="scriptable" VALUE="true">
  9. <COMMENT>
  10. <EMBED type="application/x-java-applet;jpi-version=1.4" width="200"
  11. height="200" align="baseline" code="XYZApp.class"
  12. codebase="html/" model="models/HyaluronicAcid.xyz"
  13. pluginspage="http://java.sun.com/j2se/1.4/download.html">
  14. <NOEMBED>
  15. No Java 2 SDK, Standard Edition v 1.4 support for APPLET!!
  16. </NOEMBED>
  17. </EMBED>
  18. </COMMENT>
  19. </OBJECT>

3.2 利用IE的条件注释

IE识别如下样式的条件注释(Conditional Comments):
 <!--[if !IE]>
  非IE浏览器时的代码
 <![endif]-->

  这个条件注释只有IE识别,其他浏览器会把这两行作为普通的HTML注释忽略。因此,可以用下面的形式来适应所有的浏览器:

  1. <!--[if !IE]> Firefox and others will use outer object -->
  2. <object classid="java:Sample2.class"
  3. type="application/x-java-applet"
  4. archive="Sample2.jar"
  5. height="300" width="450" >
  6. <!--<![endif]-->
  7. <!-- MSIE (Microsoft Internet Explorer) will use inner object -->
  8. <object classid="clsid:8AD9C840-044E-11D1-B3E9-00805F499D93"
  9. codebase="http://java.sun.com/update/1.5.0/jinstall-1_5_0-windows-i586.cab"
  10. height="300" width="450" >
  11. <param name="code" value="Sample2" />
  12. <param name="archive" value="Sample2.jar" />
  13. <strong>
  14. This browser does not have a Java Plug-in.
  15. <br />
  16. <a href="http://java.sun.com/products/plugin/downloads/index.html">
  17. Get the latest Java Plug-in here.
  18. </a>
  19. </strong>
  20. </object>
  21. <!--[if !IE]> close outer object -->
  22. </object>
  23. <!--<![endif]-->

  对于IE浏览器,它会忽略条件注释之间的代码,因此只会看到<object classid="clsid:..这个标签内的内容。对于非IE的其他浏览器,会忽略HTML注释,并且不会解释clsid这个属性,因此也会忽略<object classid="clsid:..>…</object>之间的内容,也就是只会看到<object classid="java:…的内容。

  这种方法可以适应所有的浏览器。

3.3 利用JavaScript

  各种主流浏览器的当前版本都能够支持JavaScript,因此我们可以用JavaScript来判断浏览器的版本,然后输出合适的HTML代码。这种方式能支持大多数主流的浏览器,如IE、Netscape Navigator、Firefox等。

示例如下:

  1. <script language="Javascript">
  2. var _app = navigator.appName;
  3. if (_app == 'Netscape') {
  4. document.write('<embed code="Applet1.class"',
  5. 'width="200"',
  6. 'height="200"', 'type="application/x-java-applet;version=1.5.0">');
  7. }
  8. else if (_app == 'Microsoft Internet Explorer') {
  9. document.write('<OBJECT ',
  10. 'classid="clsid:8AD9C840-044E-11D1-B3E9-00805F499D93"',
  11. 'width="200"',
  12. 'height="200">',
  13. '<PARAM name="code" value="Applet1.class">',
  14. '</OBJECT>');
  15. }
  16. else {
  17. document.write('<p>Sorry, unsupported browser.</p>');
  18. }
  19. </script>
 
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值