java applet详解、实例

原文链接

在做一个portal项目时,需要从portal单点登录到一个C/S的业务系统,这样就需要从浏览器调用客户端本地的单点程序SSO,进而进入C/S的业务系统。想了一下有两种解决办法,一是写一个dll或ocx控件去调用SSO,二是通过applet调用SSO。

最后我们选择了applet的方式,在写的过程中,发现细节问题还挺多,现我把它列举出来,希望你少走弯路。

一、先看看一个简单的applet.

import java.applet.*;
import java.awt.*;
public class HelloApplet extends Applet {
public void paint(Graphics g) {
      g.drawRect(0, 0, 499, 149);
      g.drawString("Printing...", 5, 70);
}
}

以下是html页面:

<HTML>
<HEAD>
   <TITLE>A Simple Program</TITLE>
</HEAD>
<BODY>
   <CENTER>
           <APPLET CODE=" HelloApplet.class" WIDTH="500" HEIGHT="150">
      </APPLET>
   </CENTER>
</BODY>
</HTML>

运行的前提是把编译后的HelloApplet.class拷贝的和html同一个目录下。这是个很简单的例子,但这样简单的例子在实际应用中用处很少。

二、下面接着学一下applet的标签的用法。

先学习一下applet标签的属性:

Width:     Applet在Html页面上的宽度
Height :    Applet在Html页面上的高度
Name :    Applet在Html页面上的名称,用于区名一个Html页面上的多个Applet。

Id:为 applet 指定一个 id 属性,从而能够将其作为简单的对象处理,用javascript调用其对象的方法。

Archive: 当 applet 被存储在某个 JAVA 档案文件或 ZIP 文件中时,此 applet 的 URL。

Code: 执行 applet 的 class 的 URL。

Codebase: 指示 applet 的基准 URL,假如 code 属性是相对的。

Param:传递参数。

这些属性里面,可能最容易出现错误的是Code和Codebase属性。举个例子可能就明白了:

     假如我的web工程下有个index.jsp的页面放在根目录下,该页面需要调用一个applet,而这个HelloApplet.java在com包下。正确的做法是先把HelloApplet.class拷贝到index.jsp的同一目录下,然后

      <APPLET CODE="com.HelloApplet.class" id="helloApplet" codebase="."/>

注意:

1、 code一定要写包名,codebase="."表示是从index.jsp的当前目录开始。

2、 一定要把HelloApplet.class拷贝出来放到jsp的页面目录下,如果放到web-info/classes/com/下就会出错,因为web-inf文件夹安全性比较高,客户端无法访问的。

三、下面我们看一个复杂的例子,这个例子中前台的页面需要调用的applet不是一个class,这样就需要调用一个jar包,而且这个applet需要调用客户端本地的应用程序。

(1) Applet类:

package com;
import java.applet.*;
import java.awt.*;
import java.io.IOException;
public class HelloApplet extends Applet {

     public void paint(Graphics g) {

            g.drawRect(0, 0, 499, 149);

            g.drawString("Hello World", 5, 70);

     }

     /**

      * 通过applet调用本地的计算器

      */

     public void openApp() {

            String url = "C:\\WINDOWS\\system32\\calc.exe";

            System.out.println("url=" + url);

            try {

                   Runtime.getRuntime().exec(url);

            } catch (IOException e) {

                   e.printStackTrace();
            }
     }
}
(2) jsp页面


<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

    <title>demo</title>

</head>

<body>

      <APPLET CODE="com.HelloApplet.class" id="helloApplet" codebase="." ARCHIVE = "helloApplet.jar" WIDTH="500" HEIGHT="150">

      </APPLET>

      <p><a href="#" οnclick="openApp()">计算器</a></p>

      <script type="text/javascript">

      function openApp()

      {

        var helloApplet = document.getElementById("helloApplet");

        helloApplet.openApp();

      }

      </script>

</body>

</html>


(3)把HelloApplet打成jar包,因为在实际的应用中一个类就能解决问题的情况很少。Cmd 切换到web-info/classes目录下,通过如下命令打包:

jar -cvf helloApplet.jar *.*

(4)为了使得applet能够访问本地的应用,需要给它签名。

keytool -genkey -keystore hello.store -alias hello

这个命令用来产生一个密匙库,执行完毕后应该产生一个 hello.store的文件,这个名字你可以对它进行修改。另外在执行命令的时候还有提示你输入密匙库的密码,这里你一定要记住,否则后面要用的时候无法输入。输入密码后,它会提示你输入用户名,公司名等信息,这些都不是必须输入的,你可以直接回车跳过,最后问你输入是否正确,你可以输入y或n回答正确或错误。

keytool -export -keystore hello.store -alias hello -file hello.cert

这个命令用来产生签名时所要用的证书,这个命令执行完后产生一个pepper.cert的文件。

jarsigner -keystore hello.store helloApple

这个命令用上面产生的证书将我们的jar文件进行了签名。最后把该jar包拷贝到jsp文件所在地目录下。

(5)因为applet的运行是沙箱机制,在调用本地程序时需要做安全性设置。在本地运行该applet的jre\lib\security\java.policy文件里最后加permission java.security.AllPermission;这里需要注意的是如果客户端装有多个jre的话,需要找一下哪个jre是真正运行applet的。

(6)在运行的时候,第一次会提示是否信任该applet,点击使准信任,然后运行,下次就不会在提示。

注意:在用浏览器调试applet的过程中,可以打开java控制台,位置在Ie的工具菜单的java控制台。













javacard applet 开发实例 正常运行 带jar包 package mifare; import com.ibm.jz.JZSystem; import javacard.framework.APDU; import javacard.framework.Applet; import javacard.framework.ISO7816; import javacard.framework.ISOException; import javacard.framework.Util; public class AmbiqApplet extends Applet { byte[] mifarePassDefault={(byte)0x0b,(byte)0x54,(byte)0x57,(byte)0x07,(byte)0x45,(byte)0xfe,(byte)0x3a,(byte)0xe7}; byte[] mifarePass8={(byte)0x0b,(byte)0x54,(byte)0x57,(byte)0x07,(byte)0x45,(byte)0xfe,(byte)0x3a,(byte)0xe7}; byte[] mifarePass9={(byte)0x0b,(byte)0x54,(byte)0x57,(byte)0x07,(byte)0x45,(byte)0xfe,(byte)0x3a,(byte)0xe7}; byte[] adminPass={(byte)0x40,(byte)0x41,(byte)0x42,(byte)0x43,(byte)0x44,(byte)0x45,(byte)0x46,(byte)0x47,(byte)0x48,(byte)0x49,(byte)0x4a,(byte)0x4b,(byte)0x4c,(byte)0x4d,(byte)0x4e,(byte)0x4f}; public static void install(byte[] bArray, short bOffset, byte bLength) { // GP-compliant JavaCard applet registration new AmbiqApplet().register(bArray, (short) (bOffset + 1), bArray[bOffset]); } public void process(APDU apdu) { short i; byte[] send=new byte[52]; byte[] send2=new byte[24]; // Good practice: Return 9000 on SELECT if (selectingApplet()) { return; } byte[] buf = apdu.getBuffer(); if(buf[ISO7816.OFFSET_CLA]==AmbiqConstant.CLS_AMBIQ) { switch (buf[ISO7816.OFFSET_INS]) { case AmbiqConstant.INS_GET_MIFARE: if(buf[ISO7816.OFFSET_P1]!=0 || buf[ISO7816.OFFSET_P2]!=0) { ISOException.throwIt(ISO7816.SW_INCORRECT_P1P2); return; } /*Get Entire Mifare Ticket data * Returns back the content of the entire sector 8 (3 block 8.0, 8.1, 8.2) and the first 4 bytes of block 9.0; total 52bytes. Filed Length (in bytes) Data Comments CLA 1 0x80 Fixed class for the applet INS 1 0x20 Read entire data P1 1 0x00 Sector number P2 1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值