- 在线时间
- 0 小时
- 最后登录
- 2007-11-12
- 注册时间
- 2004-12-24
- 听众数
- 2
- 收听数
- 0
- 能力
- 0 分
- 体力
- 2467 点
- 威望
- 0 点
- 阅读权限
- 50
- 积分
- 882
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 205
- 主题
- 206
- 精华
- 2
- 分享
- 0
- 好友
- 0
升级   70.5% 该用户从未签到
 |
问: 如何设置Java 2(JDK1.2)的环境变量?
9 m! r, L" c$ Q9 y+ Y: V" A
9 S6 g5 I' T" E答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.
0 c9 t0 y1 `9 T! PJava 2环境变量的设置如下例所示:
* P3 c8 r5 i, wSolaris平台: setenv JAVA_HOME Java2的安装路径 . d( @, Z; c( } R9 F
setenv PATH $JAVA_HOME/bin {PATH}
1 D! ^% j1 R# q& mWindows平台: set JAVA_HOME=Java2的安装路径
# u0 S8 z8 v& Q* v9 H! [set PATH=$JAVA_HOMEbin;%PATH% 1 c6 C& t- O0 _# N6 W0 w6 |6 z
$ b! G i$ V1 k. k. H- H" B3 h, _问: 哪些Java集成开发工具支持Java 2? + _: O! T1 g' P
. p3 B4 s7 r$ \8 R$ C答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2. 7 g4 K' |1 `6 @9 K; w
1 D0 [; c0 A+ @; G1 ]0 y( P. E; U1 j
问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围? : P( c) A# a/ f" P( T* e
- l0 t0 {% n2 I5 g( V$ u答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关. ; j1 g# T1 j7 p" G0 E8 n% \- M
如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin. , m; L4 s4 B6 O" n; D
如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序. . _$ M7 F' {7 o, H" l" @& Z
* L" C* G- M2 X4 p4 B; U
问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?
# S3 O0 O& m4 [: n' v8 W5 v& l! X" r: t# `
答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换. ) w5 O; E, m$ J/ h/ o
% d( ~; S+ B9 Q8 V
当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现: 8 d9 m+ B* f7 i6 B' i
9 W& z! |' W& z- R/ M/ R- z; t; v$ r d: l: |! x! Z3 b
String native2Unicode(String s) { ( S; y$ Y' [$ Y/ D0 |! `: h2 B! a5 k
1 K) B8 }4 Y2 N, O3 `if (s == null || s.length() == 0) { $ B/ M2 M$ f: w% b
1 h4 D4 M+ p) M! W, w; d
return null;
7 P$ ^, ^' Z: b! S" Y6 \. V% [ ^9 `7 u( L$ x$ h1 F
}
% Z8 ?7 x8 T4 u. C' W1 m7 F
% x% w! T. m; X# k" g; Obyte[] buffer = new byte[s.length()]; . d1 W5 f. U! t) ^4 Q% ]
) w7 S! p$ ~ v; Q; @" H% C
for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {
/ w- }) ]$ h. X& b3 k8 {) M& T% U
9 T& n& q6 X8 oc = s.charAt(i);
8 k* ^' ?, A+ U, l4 t: a" k3 g% O) d- Y7 S6 i% k) V6 d/ u
byte []buf = (""+c).getBytes(); . L# w7 e. a/ ~/ w' d+ Q
/ l' s2 H4 d9 A+ B1 q6 ybuffer[j++] = (char)buf[0]; 9 c/ r+ a- s4 G0 O
& x w D9 z% y- Z" _buffer[j++] = (char)buf[1]; ( x1 O- k, r$ d/ u- u
" B( O0 I2 O8 p: U% y/ m# D} - C4 C/ ]+ `% H* @' h8 M% L
# J9 H, k$ z4 c* t; Q
else {
# v+ l M5 u* d' L9 M$ w! n. M& Y
( V8 g2 A6 W8 a! x5 gbuffer[j++] = s.charAt(i); V4 b6 f% w) E5 s+ X
. P$ k9 N( V5 @" `1 E8 ] {( M}
" R! S" _+ y- `# g
- K7 K6 m9 P6 I9 \2 O+ }5 {} ( c% Z: p$ t0 c$ k) l6 Y7 S2 H7 k7 i
" n3 O; Q' D3 ~
return new String(buffer, 0, j);
; p! w; m3 ~8 d3 }% F' s
I+ r* z* @' Q. q. P} 7 p6 v' t( g' _/ n% h( R. W
0 G X) i T2 k7 F y% R7 w* [8 n除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了. }( C+ x s) ~$ a
3 b7 W" S1 h) d% d/ w
$ t8 u- E C# v: R& p8 O问: 7 ? {) a% O! i& q3 }% j
当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?
) F, C5 j5 n ?) g
5 O) w1 e7 {2 M" E3 K/ c答:
" O1 A$ e u3 K& s: _2 Bjavax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:
! z( v c4 V$ Y/ h8 B. h) x2 e: h1 u+ z6 q4 J
. f! G: Q. V' s# `
public void doGet (HttpServletRequest req, HttpServletResponse res) . h& l* Q2 R/ Q4 S
# _/ Y4 f: n8 g2 q
throws ServletException, IOException
/ y% Z; Z) i9 A9 e- B p+ O3 M7 M3 s0 `5 p- [
{ ) V& p: l+ W/ T" ]+ C0 o
- x4 ^$ j2 M3 X/ @9 fres.setContentType("text/html");
" W' D4 g# [, ~ }0 L4 F- T: |5 D
ServletOutputStream out = res.getOutputStream(); : o% [8 B; e, g0 Y; \4 U2 w0 b
9 Z" Z [' e' y, i( ?OutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");
8 _, t2 D0 i$ c# D) b/ X
! } }4 L; v" q$ A5 y' How.write("这是测试"); 7 [8 s! P1 C9 s
" p+ \, {2 Y: c
ow.flush();
+ b( P/ A' T/ Z
8 B; O2 [$ Q, i5 s! w# X* K+ tow.close();
6 l7 A/ n/ D1 t. `. `
% ?0 O1 w& b* t) x5 r8 L} 3 e3 J9 [# U8 C* I
2 h" J" |3 p% ^" q) a5 A7 I; }8 X* B' Y
问: 8 x" j2 c m. B8 Y% g( u; {" p+ G
如何设置Java WebServer的CLASSPATH,以包含用户的class文件? 8 [' t) X: }. f0 A/ g+ T9 ?7 ^
+ k3 w* U4 X4 a! ^- [4 [答: 3 ]( Q. J& k! A& y- \$ Q
有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.
3 u7 k# p6 K9 {将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.
- j. R' T5 M, ^1 M, j5 A$ k2 J修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中. 6 B, B1 h" R% @* }9 `# E
8 n; b; l1 `6 M7 h0 H; @6 O
% T: J$ {& u! F) c
问:
, x- \" r( v9 }为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢? ; u' ~, o8 d. c
3 [. x2 B; _7 ^ ~答:
B( Y+ y6 T+ e# ~* H1 W3 {" r机器的网络设置不正确很可能会引起该问题的发生.
9 K8 N* _: t, U FRMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中. ) y/ M1 w; C/ r3 k9 c, j
* [: z+ r! F3 T3 w: V7 J# ]' g如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:
' N7 K3 D5 S/ m* g) w3 K' y5 G
7 ~( w! j u1 a' ?* Q" T" v. tIP地址 主机名 / f* D6 P1 D* F5 M1 v
8 ? Y- ?: t! ?% m
如此设置应当可以明显地减少查询所花的时间. * Y6 f6 s6 @: z0 g$ M
0 m- v9 a2 [, t! ~. d8 M* c& D" S, y问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?
6 ?6 e! S9 j( i% c# B1 D* D o0 s. j; `/ }+ F- j L- f$ ?
答: 5 q" d+ `' i! Y. A7 t% x4 \$ U
若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:
; R1 {0 S; T) g! q" Q- I" C, Y; D! X) s$ H. k% X( g7 c
! W3 E" a2 w, j2 D) n
import java.util.properties; 5 v. W, J2 {8 i
6 z" ^# g6 u. ^+ i2 U; R: J. w..... ' n1 ]& P) i+ o% K
3 e% {' q, g9 E' Y
Properties sys = System.getProperties(); X5 U. V1 o3 b2 [9 l- s* t
2 t& I3 ?! N) f3 ~' E
sys.put("proxySet","true");
/ j. y1 c0 B. a7 M# N# D, A/ _1 j/ ^
sys.put("proxyHost","myHTTP.proxyserver.com");
, j) Q1 I% H3 @+ \, R! `; U# B$ ?0 ~# m, L: z" o2 \
sys.put("proxyPort","80"); . l4 \) B: D' u% I9 {1 G2 o
2 b) {6 g1 `7 p" l& E! M
System.setProperties(sys); + p! W, d/ B" A
, Z) k6 }5 t ~0 ~: H
. B3 \' e" Z3 E* r$ G# M8 L. _7 A4 q& X% b# Z5 f
u = new URL(website); , i* P* i+ ~# f( Y, ~8 l9 @
6 k1 p6 L4 C" }+ W t" {
connect = (HttpURLConnection)u.openConnection(); 4 z) Z, G! y6 w' m' R/ G6 K
9 O# m) y4 a% K R0 O% d.....
5 ^, j/ Q3 j1 Q2 K/ [, h: a6 M% }* z2 L9 b, D9 c+ r
问: Swing组件JList的列表数据修改了,如何通知JList改变显示?
+ o6 M- Z! D) z& D- z: I% _8 Q- \. R
答: 7 b% b) H) X& O
JList组件有一个单独的显示模式ListModel来表示JList的显示数据. / }& ^& `! ?$ }
JList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.
/ D- Q5 P7 M& X" LJList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者. " v* S1 J. p* B
当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.
% A2 P+ o8 V& {0 Y6 a, `) c/ n0 N- q1 w# }% s/ e# z0 ]- E7 E' R
问: ; @% V4 p/ g. w/ ~1 I' K
在Java applet中如何实现一个模式对话框?
) p# C5 \/ {& Z* F8 S$ I- c& h; Q' i [- ]0 O" J
答: O; u- y+ E! V$ }
在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下: " f" q) D; H6 Q9 y J
. r; y4 Q- c1 w2 @0 o- Q
- \6 ^& ~! ]. u- l4 d.....
7 Z: r' r( y2 O+ |* T
" q5 i4 s# [5 {9 yDialog d = new Dialog( getParentWindow(comp),title);
2 n2 i9 h3 c M, i( W; A, D# y, E' w
$ Y: C) n. G1 B& N// comp为applet上的任意一个组件 - r6 Q$ x0 V4 {' ]+ y0 X; I( S- w
. v1 e, Z8 B$ a' ? ?
....
' k# z7 _/ E3 @! @& y
" O8 h: X+ [$ q0 A
( O. u1 Q( m4 F$ h# r
* e) h: w6 S- e4 i/ m X Qpublic void getParentWindow(Component compOnApplet,String title){ 6 z5 X0 E. |4 W, H5 j: [2 q1 G0 ]
4 N9 x3 G' [% o5 }/ O7 jContainer c = compOnApplet.getParent();
) J' c' P! D- ]4 C1 v, n# [3 N- u& @. f- }9 q' V2 w8 S
while (c != null) {
! a9 F% y& f% s3 J, D) K1 y$ [* B
if (c instanceof Frame)
4 ]4 F6 }+ [5 @1 Y# G* F
& s0 A6 h3 [& Yreturn (Frame) c;
9 O$ l2 j7 C2 `0 {: |4 B
) X( c& @6 \3 G) N8 N6 ic = c.getParent();
" [. Z7 p1 W! ]) X3 [0 @, G# W& X. d/ Z. r! v- z
} 7 e$ r- L) ~5 z9 k( H3 u; D2 _
1 L+ }% o* C- i7 d" `; _5 o7 }7 ireturn null; * q, r/ k( ^ ^2 n; _& V
v1 e# t+ `6 [& d" b$ Y
} 7 ^' ]' r; P# i2 W
" k# m- | v( d/ j: u# Z问: 在Java applet中如何显示另外一个HTML页面? , O9 c; ^2 i$ y2 H6 ]* s# e# ~& E
0 _0 Y2 x# w+ r, C! K, q答: ) g4 Y% Z3 s1 a3 q# z l4 f1 e) p
通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.
, G- }7 V2 C$ v5 a+ ^2 }* |/ I7 i, z' t0 F8 ^* |6 z- R% F
问:
8 `" o) Q2 s. a用JDK实现的签名applet,可否在Netscape或IE中运行? ! [$ O0 f0 g: H- h0 n; L. b2 d
- m1 C( Q4 a# y, B- Y6 e
答: , n8 Z2 O7 j; M K. q: Q: y3 t
用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行. : v' N* v. D- C
$ n G$ y" ?& ^& ^4 _4 m* D不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行. : [ d& q6 @+ h( |
* u: D( h* ]0 m- j2 n( t+ g如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.
- F) i2 j, z: t, K) a6 H5 P' I5 q) U; V' {! Q+ ~* b
问:
) \* J: t$ ~- B6 |% k4 B, b用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?
' r; q' F( K0 I5 F {7 m) I' U7 @: O* C: a6 Q3 [! u
答: ( O( [% G. e, H, ^& G; y* f7 ]
如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):
6 Z( T) k+ B$ R8 B" q4 N编写调用C库的Java文件,并编译.
4 ^ Z9 I, Q9 a! m7 T/ kjavac java文件名
3 i- z2 x4 a' o, G# k' v& [3 S/ D, w+ v9 g/ I: r
! Z+ p" r. L% s8 Y, H产生C程序头文件 . a8 {5 ^3 `5 y/ P- @; }! U
javah -jni java文件名(不带后缀.java)
" R; z2 S# p7 U8 S9 |2 M6 W
' P- Q( ?8 a5 K* G5 `) x6 K" O
+ w0 X$ ]5 r. _. I* D, i: b编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.
5 q% c/ i+ V1 o) ?cc -G -Iinclude路径名 C2.c -o libC2.so 7 C8 n5 E8 p9 K, D* n: H9 |7 a, h0 V
cc -G -Iinclude路径名 -lC2 C1.c -o libC1.so & |# r/ R9 p5 _8 o" c
7 {0 `5 o6 {- P* x
* R8 l4 D+ K1 t, a' v' R* T5 T设置环境变量
; z. P; p/ z9 N4 g9 p, |% ksetenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径
3 Z. b/ v! `- X% n# E- D. u {LD_LIBRARY_PATH}
% j9 |' o% j5 O: c# [1 X A, i5 J s9 v) |) p
+ a) i7 Z" q; `
运行java应用
7 N& r1 s! f2 N" c
% w) m) x! L" |0 M: p' f1 n
, a. ]1 B# t* `8 G6 y* N: u" ^& Q问: % P3 W; K M8 H& ~
在Java语言中,如何列出PC机文件系统中的所有驱动器名?
- F9 n |/ g; F. r' `) F p" ~' L/ V! t: r$ G. g
答: 6 f3 ]8 g! ]. U0 a" E- D+ r4 c
在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.
+ J; S4 R, X/ a( R9 S$ ~: H: Z- q$ S' y+ W. R- D
问:
" w+ d5 W8 }4 T0 s9 }( c为什么Runtime.exec("ls")没有任何输出?
. n9 C; s6 m( M+ o4 A
# S. Y; a* G% H, F" t答: 3 S7 J- u. P$ c3 f$ c7 Q% l' v! U
调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下: ( a5 ~7 h/ K3 M! M) l
2 M* |, J9 Y7 d1 z
6 _* p, T) v0 `: ttry , J; x4 o' S7 W3 P* J1 e) D
' G$ L1 @1 U' P* L
{ ( ]/ ?; F. a ~' H! X( N& f
$ y% ?5 ^/ C# n7 u0 L! F
process = Runtime.getRuntime().exec (command); ( I0 F L# l2 F3 S5 E
" L* a& s W' x$ P
InputStreamReader ir=newInputStreamReader(process.getInputStream());
+ _ j$ T& O( ?& V, B! H
- L. a; m, f/ p( {$ \! @LineNumberReader input = new LineNumberReader (ir); 6 ^! ]% v, U! n- F1 [; x7 R
. L2 h; }7 Q+ h8 p1 q% [/ \6 E& j
String line;
& x3 P; {# Q5 v D/ r" S5 [
# \2 N9 W' W/ ~$ Owhile ((line = input.readLine ()) != null) 5 J |0 c& e4 A- L& u* N; o$ e
# l' k8 r4 i% `( l; W+ P: k% b
System.out.println(line); $ W3 ^5 A+ n3 Y- B
2 x9 v6 w8 x* e( L! A) o} - d1 Y/ a, d$ @' f& `+ F2 e
" m. H) {" u' M r7 Ucatch (java.io.IOException e){
! K' w9 [5 ?$ H/ q& t E6 T" w: P% c! U) t. z
System.err.println ("IOException " + e.getMessage());
! f3 a, G& m" A$ x$ h- e/ x- V
}
5 I3 \/ G7 U8 O8 }: x/ B# j- o3 v3 S, g& g9 d# L$ A9 O
; r* b& G- W! y* J; V+ e0 g$ x5 V问: 6 n1 B4 z' e: E4 t/ [* l" S
如何产生签名applet,以使applet能够访问本地资源? * k* k* e1 m7 T9 R. H. u/ M
2 N. R6 V; `; w0 ~. \5 c" _4 x
答:
! I/ `% }6 J& e: |在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下: " i8 X: Q6 o# N
) \- l( ~$ U& |" W6 Q" A
! K1 E* n; g! g//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中 3 e9 f9 [6 h2 P% ?
6 e! s. z! n. r9 i% K' V# n# skeytool -genkey -alias joe -keypass sign12 -keystore joestore / W. C) U! T* {; T
* n/ g3 \- U( E6 U, k! O//将SignedApplet.class及相关文件打包成jar文件 2 u# F* J# R! Z, C0 v. O% R2 v
& O. |9 m3 k" y0 \, a; J* Wjar cvf SignedAppletDemo.jar " V" d/ l r! K( u; T$ A4 ?$ J
- b+ L7 f! T9 `) C
//利用keytool生成的自签名的证书产生签名applet(jar文件) ' s+ T$ G; z2 j C) Z3 h
- Y1 ]9 [* X) y3 v: S1 Yjarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe 3 z P/ @/ N) B9 Z9 O
5 |3 z* y' P$ p+ n; a N. P% x//将自签名证书从keystore中输出到文件
" V' Z1 R2 z( L+ a; z b& `3 Y8 w
keytool -export -keystore joestore -alias joe -file joe.cer 3 b& p5 P1 A, p0 l2 T) i2 E/ ]
# a# ]; u0 I4 T; x
) X, a7 M- ~; f' x" W! N: W8 T) r5 m1 H
而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行
: D, W4 x0 B- b1 r8 |* @9 q9 S7 t
0 T" e# R+ X1 E- S; lJoe编写的签名applet: j' E* v- B0 P! D7 J, U
1 Q5 U. ?4 W4 l+ o$ d/ M V//得到Joe的证书并将之读入到密钥库中susanstore中
% Y: |: F. N F7 n% w- g" ~. n1 ~1 V* X( W( B P
keytool -import -alias joe -file joe.cer -keystore susanstore
| b; `( T: w' g4 L% R) r4 y; D0 P- v: T7 P9 G
//运行policytool产生满足Susan要求的policy文件
( ^. M- `6 p0 M- X2 f7 r5 D, N- m v" d
policytool 0 } f0 ?. l. c+ d" }( q
3 g% M, K- e' P* e! o% C! c! O; M
//用appletviewer运行之,或在浏览器中安装java plugin来运行之.
* x, G. g, k5 V" R2 x7 C( i4 S1 G8 e5 B* Q7 w
" ~8 j3 E* f- Z9 G7 C; K) P5 m* [0 R6 N
关于签名applet在Java Plugin中的部署请参考以下网页: 8 `2 l/ e& u$ R f4 j
* w5 u0 ^/ E) Y3 u, R6 W7 D3 ^1 U; \, u
http://java.sun.com/security/signExample12/ $ h+ E4 j/ [4 @9 \
/ k) M0 ^' z) K; b$ n
% D P" y/ [9 t+ o0 O: L$ ^
" b8 ^- h. A/ S7 d8 H$ m$ X
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以
" j5 \4 ~1 E% t; o; e9 y- P0 b' q* ^" f( y5 h" t' g6 v1 @5 C* e
使用keytool -certreq向商业CA中心申请电子证书.
9 V& J) _4 W& ?4 t) e7 X5 J8 P6 K- W: D% r2 E- f
3 | M, p _$ u1 L
! {' r/ L1 ?1 k" m% D5 ~: _3 f% G: u6 a7 ?- r* D( N
问: " d( ]: i$ l. b* `6 w
若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException? 3 I4 Q1 x: J% C$ z$ m. _
' g3 E3 w6 A, l- |& X2 a答: 0 E, M' E+ Z0 h1 ]9 D0 ^
使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.
/ o6 ^. A) W5 z m7 C4 U9 M% B1 [, q$ F+ g. p2 N
问: . U& }3 e; h9 `* U( F8 [
对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中? 4 Y6 I t% @+ g/ M: P
3 Q) s! H3 c8 ], w7 u
答: / Y" u$ S+ v- q
目前,没有直接的方法可以将对象写入到随机存取文件中.
! s/ z6 M: H% W# t4 M' A/ D i但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.
0 V9 D; U7 r7 T
( h1 g3 @! r6 f$ M问:
# J9 ^9 j/ F, l- O, L4 t运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?
& O" ^* _6 w9 w; i' ^* w6 i
1 Y* J8 W% k2 r, c答:
' M e* q2 T, R1 D' Y- i可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务. ; m0 [) A. u& t7 ?/ m U! j7 ~. v
: k; i7 R, }, O4 w9 }
问: ; u' D% C6 C8 N
使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?
6 R S3 @- I* n6 y9 {7 b% W; r
% f' F3 W9 N; d5 N答:
- a1 q" N0 d7 \3 N5 e4 B% x使用如下方法可以获得PrintJob的实例用于控制打印操作: ( J- l, ^9 _' }9 {) |% n: g/ I# a4 [
% e3 X* h+ a: x- F# Z$ k! @" O
: l" k8 |! B" t1 }Toolkit.getPrintJob(Frame f, String jobtitle, Properties prop)
! {* j- X" S/ K3 f
# I& u+ F3 C2 ~+ P( @8 u那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括: ! K4 [5 B' C$ ]0 c- N
. Y1 M0 l: C3 w3 e
awt.print.destination: 可以是"printer"或"file" 1 y# J# k" C0 I7 m! _
& z( @4 v) M% [# v; ^! qawt.print.printer: 打印机名
( |; B/ C: s2 Y
8 a% F e0 m" Oawt.print.fileName: 打印文件名
" ]) L/ z# \* ?; D
/ R: H6 i6 T, m2 K, G Jawt.print.numCopies: 打印份数
; J1 U, v7 \, i3 T" L& ?8 N
0 O A) M9 U! }& Sawt.print.options: 打印命令的打印选项
8 ?% k5 r Z/ ?. g& ^7 D Y7 u9 q9 o+ r9 z* k
awt.print.orientation: 打印方向,可以是"portrait"或"landscape"
. k8 |- `- P9 A# @4 X
" G3 w% u2 v& Uawt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4" ( C( p3 w/ |6 z/ Y5 [
; ~+ P, Z2 d! {" E$ X6 Q- ]! g! D/ a I( {' U. D! y
+ @$ W( F5 T8 s- p+ r
+ [3 F1 }: }! w: @3 o
4 L: `' R) G- O. V
2 O0 _, i, J* f) G问: ; j1 M1 I+ d n( k+ b( O
在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之? " C& ?: S' W& j' V' g' f3 y4 r" r& u- r
7 M7 y' U- x& G' R
答: I3 V- M2 s2 C4 p' ~' e, J5 W/ ]
Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁. & b- O& w9 f1 l* H/ L: t
, Y2 j4 S! _+ F2 u因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.
' {/ J& U8 X, {* B- {, u( @* [+ i1 O: G/ g" I) Y- r. [
问: + k/ Y3 {4 V, t/ A5 w9 J2 Z
使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行? Y( [% Z9 g- X' i) A5 B, U3 T( u
6 p5 H0 \; P) \, I$ P答:
) a1 Z% K$ A$ R* Q7 N E" ^在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:
1 r; E0 r' s! a+ b, a6 h; f
0 f3 J, r! K- ?/ }0 b9 D* V% q% O3 b; \% Z* d" M3 I0 _7 H
ResultSet.first():将数据指针移到结果集的第一行 5 B2 A* u. S/ n% R2 ?
$ \: V' x! G) {* FResultSet.last(): 将数据指针移到结果集的最后一行
0 w" J: Z8 K0 f5 i, \$ g1 ?! q( E" F; y% |
ResultSet.previous(): 将数据指针上移一行
1 f! z. e" |7 N3 b% q2 J# \$ x+ d5 |2 c. h' ?
( d+ ^. f# u6 C$ U以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .
6 S9 w: ~; {/ E4 N) C, x; G6 o+ R8 A5 o) @$ R3 E! |5 n% b: K& M: c
7 _( [5 p/ s& S$ X+ F1 z
问:
- v1 K+ C1 |- J- P5 I5 o哪几种Web Server支持Servlet?如何使IIS支持Servlet?
l7 N0 F& `/ Y; I7 \/ \4 m
$ u$ D$ \; k5 S2 F8 J& w+ A- E3 }答:
8 ]! ?% K- ~( w L3 v目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等. ! ~. |3 f. ^" [+ I
- w$ u* u1 Q1 T此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等. ( y. i0 R' u+ V$ P; k
0 `9 E1 P0 O: Z/ j3 G8 l
问: 2 s' ^' F2 a4 Q' ~6 O) f, ~7 @
如何在Java应用中将图像存储到图像文件中? ; O0 e4 {( P0 k x, B" k( d% d
' F' @/ ?9 g3 ~% Q, j% n* [7 Z
答:
4 g. f" X* S3 ~$ y! \" `$ eJava Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:
& n8 {" F& [4 K1 Q( q$ V* U9 D6 m
4 X) W$ e7 Y: r5 W3 ^3 ^& B, j, w3 d+ V% {
OutputStream os = new FileOutputStream(fileToWriteTo); 7 R7 Y2 Q; R" S) O1 ?) w( R
6 a3 q; q( ?) ], b
BMPEncodeParam param = new BMPEncodeParam();
( g4 q4 z/ V9 V8 K/ P+ ]7 p3 G5 \# `' U- P5 u. ~9 E# n, [4 \
ImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);
1 j. ?( X) p# A5 s: u/ |2 R+ o! T# ^' r
enc.encode(img);
! E2 Q& H% n' j3 I# r% \1 K% D: ?5 _8 Y0 Z9 U0 h
os.close();
" r" L) C/ o# b$ F: u7 U; U* ?
+ p# H- Z3 M9 P! P有关存储图像文件的编程指南请参考以下网页: ) B0 H: |/ {8 b/ [
& @5 A, u# W* M6 Zhttp://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/ ' s: T/ y' X1 N2 e f) Z/ `. c
3 V# R$ S! C% }; D
; \+ }" j- E, o# z! `. B9 ^
; q# b" J( P) x$ H# u
% b* b6 x8 Z4 o8 i1 `) |2 O问: 3 c. ~9 u& @- l3 K. X/ }6 |
如何用Java语言向串口读写数据? font> # ]8 ?! Z3 T/ e c
1 v( t8 W9 y2 |2 `: p% j答:
" p& C: g" f9 w- q0 [9 FSun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制. / m# @3 B. I4 g
L' o! S5 P) Y0 [8 |3 H$ O/ ]
详细文档,请访问:<a href="http://java.sun.com/products/javacomm/" target="_blank" >http://java.sun.com/products/javacomm/</A> |
zan
|