QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4914|回复: 3
打印 上一主题 下一主题

[转帖]Java常见问题集锦(来自Sun中国官方站)

[复制链接]
字体大小: 正常 放大
god        

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-3-31 01:31 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
问: 如何设置Java 2(JDK1.2)的环境变量?  3 O' A" Z5 C' B/ U$ }9 M

7 T& P% `" D7 y9 H答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.  
0 T( Z# x2 Y& \. FJava 2环境变量的设置如下例所示:  
9 \, X/ s2 e) M( Q7 x( i' g( |# J7 f' ~) JSolaris平台: setenv JAVA_HOME Java2的安装路径  
+ j& B" f! a. l  {. Ysetenv PATH $JAVA_HOME/bin{PATH}  
! D7 I7 ?8 W2 d+ ?; J" |/ NWindows平台: set JAVA_HOME=Java2的安装路径  
1 ^  G4 a$ D% ~8 ?: f7 Iset PATH=$JAVA_HOMEbin;%PATH%  % `% ]+ ^' ^3 s+ X, M) x9 v/ Y6 C
* O  H' n! a. e/ V3 ?. a
问: 哪些Java集成开发工具支持Java 2?  
$ l7 [8 W2 k  W( @9 M& @
# F% `. p4 }: A9 T4 j  r: M! ]答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.  5 h/ w/ Q5 d- R: N
2 k& V  }+ L. z1 F* ?
问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围?  " X3 _. u& F6 L5 @; z# W9 a2 b5 Q: h
8 v1 u. D0 v& l$ D
答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关.  9 w; L& R* l7 C+ p9 f. z" }3 e0 d
    如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin.  
, l3 ?6 n' @0 b8 D    如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序.  
0 Q8 u: D. S9 O6 C7 o7 j9 R' }3 l* M, b3 B- b
问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?  
/ z) m/ S- w$ i$ x4 H* Z6 R8 Z* M, @6 l% }5 Y8 ^
答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换.  8 d+ R$ c6 d* |+ S; c' _, x; U: J
9 R) H6 |) g* [" |$ p; S# u
当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现:  5 r5 X. N7 ]9 U0 `# W; f: i
  ]2 j3 k; S  j. s+ P% ]2 g+ n5 e! R

! u5 N1 r+ b; ]- o/ Y+ w% G$ S- `String native2Unicode(String s) {  0 m- H1 r. I" g8 b. D" t2 K
* G) m. ~' d! q- ]
if (s == null || s.length() == 0) {  
3 C) U5 H0 n( [5 @, V) [8 y( f: x( q6 U$ y9 i2 t2 o* J
return null;  % I8 ?+ c1 W/ s6 W7 U

' F; l: d* D" Y# N4 ?}  % B% M! ]$ ?: f

' s7 j9 j  i7 A" L5 P. Xbyte[] buffer = new byte[s.length()];  
9 m) s; M% _1 c: B0 X6 ^
0 B, ~4 a; T4 t2 K5 ~9 dfor (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {  
* Z: e! t* b: v& ^8 l3 i
6 m+ G9 v4 L- _* K' e# R/ F/ mc = s.charAt(i);  
$ Q$ q/ R/ p/ u( D/ b7 R& Y0 A3 Q3 @1 G3 K
byte []buf = (""+c).getBytes();  7 h2 W6 |3 a: f1 I
, e( [+ n. R0 t4 e
buffer[j++] = (char)buf[0];  
4 K5 a; N/ p$ W! B9 _6 t! h. c: Y9 _8 q* M8 `1 |1 [" y
buffer[j++] = (char)buf[1];  % a/ Y  F+ R4 u2 f0 Y
4 V% J1 D( p+ ?, n$ e7 w3 e
}  " z. }' d- L9 m; \
) M+ B' {6 M$ v+ x! U% r$ W( S
else {  6 D9 o" w& t$ G1 ^5 R4 }" j& L
0 a# j, K5 O' {. T2 r
buffer[j++] = s.charAt(i);  
: o* v- S1 p$ Y! n, o: _2 k
- p; U9 l' ?8 A5 m9 U! ~7 u  [}  
: d* I$ D9 v* s: _. i! R3 n
- ]% \$ D+ i2 v+ ~; w' d1 E}  
& G5 F9 Y3 d. x( U+ N# l- L: d' L* }; M% |. m0 l; ~
return new String(buffer, 0, j);  
& M8 @3 ~% v2 Q! r$ \5 _4 b7 N* P7 j. l- `8 \
}  
  _3 ^: R" p4 h* L/ e4 i/ i0 |( G$ B( _* j; @0 O( G
除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了.  4 v' d; R" J: k4 A" Y9 d
# T0 a4 y9 `9 w$ @- E! V" V- y  E
6 N! L% }) l3 ^: M) v4 c
问:  
6 Z+ e9 S5 a; [- s当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?  2 i+ \; a. E* ~) S# @
: r( ^* `: b% _& [
答:  
; _+ n% M, P1 P  zjavax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:  & N. D8 {) w  z+ H" {

" k& k" ^% f# R6 B8 Q9 r
' ]9 ]( y) b, o. D' v) _1 V% p. |public void doGet (HttpServletRequest req, HttpServletResponse res)  
# b9 c+ F6 `7 `) o" P4 Y% ]- J& x) k4 `. f& K* c
throws ServletException, IOException  3 t3 z# I+ Z( S) p3 ^. A

( \) A7 j- @. U! J4 w  e$ @{  ) U. q' }" O8 r/ Q. Y: [
2 u$ S5 r* I" ]$ G& m
res.setContentType("text/html");  
- Y( G. R3 P1 N0 w
1 ]. y# w6 w. ?) R( \ServletOutputStream out = res.getOutputStream();  2 A5 p& j2 t4 n: L/ G8 C; a( F

/ O  T  j3 i' n' k+ x; zOutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");  
& o# \4 K0 L6 j; r1 j
1 W' x  G/ f" m0 n4 a+ b. Q. Kow.write("这是测试");  
$ ?: N' m- h5 a
9 \8 @8 M* v# V9 P. j  ^* x+ j4 _  N6 how.flush();  0 P$ L3 [# K7 q) n; h+ \' V- @
, n2 E% g) Q; c) ^: f/ j, W/ I
ow.close();  
. ?8 X) s1 M- {: L% z/ k; T$ k7 H
, Q6 g$ G2 U0 }* b; r}  ' b$ x9 ~; u, \! ~2 O2 A6 X
8 o+ M4 P; J# }) i$ i8 I

5 ^1 o: _8 v  q7 p& o* }5 y3 s问:  ! C* Z3 V+ I6 `) v  k9 h% s8 _
如何设置Java WebServer的CLASSPATH,以包含用户的class文件?  
$ [' Z! \# ]6 w4 B# M& y' [
% I8 p% d8 s2 B/ Q2 X答:  
4 M/ l! G0 o" h& a, j0 V3 X5 Y有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.  
1 K9 q1 d, w0 f2 J/ O$ i将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.  
: O& e) l# L' h修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中.  ; k9 [" `. o5 }( S& \" T+ p
5 U! s. r9 I8 _* ]- H
, b. [9 e1 {1 ]9 [% g8 x
问:  
8 ]- ~6 V! L. e, _) F为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢?  2 `: \5 h% E7 R: w3 v8 o$ j) |
4 T  q* v3 Y5 F& b* d
答:  
9 `. ?/ B) E0 Z# E' z. J8 O7 ?机器的网络设置不正确很可能会引起该问题的发生.  
& [& e' `0 m# k8 ?; URMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中.  : d* N' I; |& e0 [9 H+ H5 b2 A

" A1 S- X! ]3 @% l如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:  
2 l) t0 D) a  e* w. c( ?  f6 v  g) a* G5 \
IP地址 主机名  . C4 [) i8 U5 a3 H0 j7 g
( C$ U* b8 U1 A' `# X" C0 \
如此设置应当可以明显地减少查询所花的时间.  
7 w1 @0 j+ X3 j6 a# E( \$ I- P
1 M- u% u/ K! k( g问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?  2 d  L6 ~; B& e4 ^4 n

, t) r8 p; b+ M( A8 V, T答:  
* r( K, l8 _5 B$ H7 j! [若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:  
7 ]- Z8 d9 I) E1 v" t0 F8 Z# }: w, t

+ l# W* V  q% C1 m) h3 B( N6 Vimport java.util.properties;  
+ E/ Z& H9 g# I3 I% w4 O+ u
! h" m& c8 o/ v+ H5 ]  X) f.....  
0 d( [7 o$ m9 P; L; A6 X! [8 H  s7 M! s, ^/ g
Properties sys = System.getProperties();  
) M7 o2 k$ |* |- U: r7 n7 M* ]% m. w5 O
sys.put("proxySet","true");  
2 c  M) M4 O4 f; [  q* P3 T9 `" T( b5 D( \1 R/ F
sys.put("proxyHost","myHTTP.proxyserver.com");  9 H. o8 p& R! f' s

, e. ?* U; K7 X: }# [& `sys.put("proxyPort","80");  6 _: l. U+ k; ?9 V

7 ]+ L$ c; ^+ T" c1 j, H& XSystem.setProperties(sys);  
2 X' u; e1 v# w
/ y- B& X  b& I% O# T1 E+ G7 m7 z# d, E- t& C1 p  K0 ^
4 `5 O7 M9 v$ C; [. \
u = new URL(website);  
3 y( s, {& R/ q" V" q5 q9 m4 |* K! X. F- S
connect = (HttpURLConnection)u.openConnection();  
2 I3 D3 V/ Q: L; j
# y+ m3 H. b+ ~: X2 D.....  
7 W( R, l" R  `1 u0 |# A9 l
1 W* Y( Q' d: }! h# D6 h6 I/ o问: Swing组件JList的列表数据修改了,如何通知JList改变显示?  
( W& ^+ l% o3 _, x( f% \5 b7 T) A( x8 Q1 _) e4 [
答:  
! J. a+ t0 s6 H$ o6 M, l3 Y( wJList组件有一个单独的显示模式ListModel来表示JList的显示数据.  1 g- d+ s; x) z; O
JList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.  
* H) }2 U- T* \- a5 O) s$ YJList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者.  
; L& h2 D9 K8 [2 ~当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.  ! \' U5 F7 O9 _; h3 M. A9 J( }

; N1 m% x$ X6 E% v! @7 |问:  + i* H' F1 i: J$ T" N
在Java applet中如何实现一个模式对话框?  
* q( L2 u0 v4 |0 t! \; s9 H. p5 L2 \: Q+ W
答:  
: Y$ [2 b1 U/ O2 I1 @* I在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下:  
( j4 a( r% E: i$ z/ S. V3 B" K5 s3 Y
/ y5 U3 p) w5 y2 N' l/ Y( Z
.....  * V( B/ N, n9 n, _- m- f5 M
0 b" J7 P! Q0 @( R  U
Dialog d = new Dialog( getParentWindow(comp),title);  
* L; H$ G! ]1 t( B8 C0 V1 q7 j7 c- J& J7 I
// comp为applet上的任意一个组件  # S; y) o: T2 s: m" Y" Y

, i& _7 G  j6 a3 f....  
; @6 {' \. m0 _; W" M* ?% z  T8 i- _& D, f1 A  t( ~4 ^" k  J' R. M
9 K6 I8 [% A% `6 b/ X1 {, q  S

3 P( d0 Q% b0 j8 @0 U) K- J  Jpublic void getParentWindow(Component compOnApplet,String title){  . p1 O/ q9 h0 |4 B6 R9 e2 z' @
8 U! p( B" {( R0 p3 l# s
Container c = compOnApplet.getParent();  
' }, x7 o# o+ Y" J% e: S2 B% C! h: `; O0 _* }9 n: |1 w# J; ]
while (c != null) {  
1 g% x  ~; X4 t4 k. |5 {/ P2 m
1 G" t  I/ p' F( ^+ l& V8 ]7 x( Z- qif (c instanceof Frame)  ! J+ l) Z; \/ N! Z9 J2 @) U

3 K" R  [) U1 l: Ireturn (Frame) c;  
  o8 {$ ?1 [: c9 H. x' m/ T* W7 c
c = c.getParent();  . V: b$ e  p* ~+ x2 h) ~

. L4 z/ c1 s4 ?2 A9 L}  9 y8 B: k6 |+ K! c1 g1 j
" k. s5 q9 A; L' T9 W( V
return null;  8 q9 n  X* E# R4 U  p. O1 h

% H* z' a1 ?) \3 A}  
- y0 H& y# E9 C5 a# Q% n! O! V: h+ c) [& D9 y, k( u7 \, v3 Y
问: 在Java applet中如何显示另外一个HTML页面?  ' T+ t' X( G  d$ H/ Q3 k

  T2 O7 O1 _7 J# @7 N8 l答:  5 t' n8 P2 y5 t/ o( x; @
通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.  
. D  r, @6 }  _) P- y8 H% M- R4 k. K* L. p3 w. H% }
问:  
. d& ]0 q( i: p7 z2 t2 e  z用JDK实现的签名applet,可否在Netscape或IE中运行?  4 P3 M/ H% o: [" E! d' A- p+ h

8 y3 N& K; f2 D6 y6 v$ F, b答:  
* j0 ~: o" i/ ?  S& g' G用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行.  . }# b' k  D0 v. S2 Q% f

8 Q* K, Q& ]8 o% A. n" I不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行.  
5 @% E" R- j4 q1 d9 h
/ o: H% ~' ]: p% c8 H2 W0 G如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.  * Y$ V% l6 V, f9 U5 ^
: m% x; b% b$ Q  h- X8 D8 S
问:  - T' ^: R5 y1 \2 ~  J" ?0 V
用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?  6 q  G: z* h1 ?+ n( g+ b0 k
& T( N% P+ f9 a5 k8 M
答:  
3 n, W4 b/ E* t& j2 v, x如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):  6 D6 @4 ]+ n: W: |
编写调用C库的Java文件,并编译.  
/ [" q* {2 {) D4 p) J* m1 \+ j/ }9 Tjavac java文件名  + A- R! _$ h  V6 T; S
6 Q" ?" E! s  U
" e5 N) x0 W8 t0 M  M5 M
产生C程序头文件  0 t: f! U7 j- ~( _9 K8 D' }
javah -jni java文件名(不带后缀.java)  * l+ [2 a+ c0 e$ \) o
. ^0 }2 z" Z2 z+ {3 \3 s% f+ m

( c* X: g: O3 c5 g- T0 }% G- v" g8 W编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.  
; V: N! S8 w# Hcc -G -Iinclude路径名 C2.c -o libC2.so  
) {! z) V) O! d" G2 Q- z' b. ~cc -G -Iinclude路径名 -lC2 C1.c -o libC1.so  " g, p& l% a2 D
6 d3 b0 n( c% n! T% [- y

, m$ H, t0 r! w9 a设置环境变量  
% @5 i0 r) @8 y& }/ G; a7 r$ Rsetenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径  7 j4 t5 `( C" X* c. C! ]
{LD_LIBRARY_PATH}  % ]! }1 j# V, s* I& [9 u

# B; R1 Z3 Z8 @- D
: m$ D% h5 _/ n& Y运行java应用  
; S: s& Z5 w+ E/ [8 G" J; Z, m' V% O; D' a- {9 V0 R2 j# ?, `2 ^1 {

( |! g0 }7 k# o7 U2 p问:  
( o& O4 x0 s* ^3 H+ r3 F6 i3 z* P$ z在Java语言中,如何列出PC机文件系统中的所有驱动器名?  
' p" m  `4 [- B  n* T5 l# L. S  @' d' w' \! I7 r% [
答:  ) f& d& G( s# G% I$ {7 y
在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.  
. ^- T1 k; j  \4 L5 y. G( M" \7 {- R
问:  
. @, x2 J2 b. S* h' P, C为什么Runtime.exec("ls")没有任何输出?  8 U4 Y, ]  W4 _/ `/ p  r

" C8 O, z  I$ x, W8 W0 G+ {0 V答:  9 G: x" P7 u* z
调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下:  " [9 M  R! w! e1 n& ~" `

4 |5 W/ b3 p% W) \; c$ l$ k! U) \% f4 L; W4 U2 B' ]' \
try  + K8 W3 X8 d: T5 F" R
3 F* D# P0 A, F# L" B  @9 t
{  
% r5 C% K4 M6 k5 ?' s
" k) B* e+ l9 H( o2 ~process = Runtime.getRuntime().exec (command);  3 M1 x5 m9 b- X) }( @: K

5 K$ p9 y% Q: iInputStreamReader ir=newInputStreamReader(process.getInputStream());  
& H; b2 g  B6 h8 [$ o. ^
* B* a5 l3 c9 b" qLineNumberReader input = new LineNumberReader (ir);  & I$ Q4 r8 g- l9 k# \8 [
1 j/ Q' m- ?9 p/ B- r: y  f+ v: A
String line;  
& Z2 J9 K% _0 z% R+ z. f( B& I* U+ P5 d  |
while ((line = input.readLine ()) != null)  , h6 x' M& G; I! _# n$ \
* N" b/ R1 I! u; x' Z1 V+ U8 a
System.out.println(line);  8 s! Y) g6 O4 }! j: u; b. K

/ n" z) x) ]  y5 Z; \}  
+ u2 @% L0 E3 }9 T# a. {* M, M, w* i1 }5 d
catch (java.io.IOException e){  
1 i; O1 a+ M+ P' z3 _$ _! Z+ C1 M0 B! P1 x
System.err.println ("IOException " + e.getMessage());  ) E( K. T& B. Z7 K
; a/ m6 {& W# D* g3 b. @
}  
* I! W$ S  Y% T6 w! D+ {5 w
" P# b' \8 |' G; G+ H& x
6 O9 S( \! C  _! D# x: }3 V2 p. i问:  
6 \5 o; i2 h4 W5 e如何产生签名applet,以使applet能够访问本地资源?  
' h: n( l9 W# u% O9 a$ {  {4 k! O$ A. j; \& Q+ [
答:  
' `: J, s; a$ G; o& h0 D在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:  8 K$ M! t3 P' J: m: k
  H! i' @1 U7 e/ ^% j

# b  w4 f* G  ^//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中  
( a0 H: W% V, M) f. R4 v+ _# [) f" S2 X; V1 ?# W1 f/ u
keytool -genkey -alias joe -keypass sign12 -keystore joestore  ! U/ {% e- C$ t$ n3 v. F6 b9 Y
* b* D  r* H% k6 R7 X( ^$ Q( ^2 U" j
//将SignedApplet.class及相关文件打包成jar文件  - h3 z" L) K9 C8 }- {8 D, |
+ \4 K  d- W! x8 a+ P" _
jar cvf SignedAppletDemo.jar  
9 u2 {4 y2 z; `" t/ o
5 `' `8 W. R3 w. ]//利用keytool生成的自签名的证书产生签名applet(jar文件)  
4 x2 }- C! I7 z. \
: Q" x# [* _' i* Xjarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe  
, P  q' u& F8 ?2 f0 w" ^6 }, b  h  f+ B6 u
//将自签名证书从keystore中输出到文件  
. ~/ m% y# \. d8 g- U) u+ i$ E0 K8 Y- U4 s
keytool -export -keystore joestore -alias joe -file joe.cer  
8 ~2 J& `( q' i# H# p( a  O" R5 h4 X. u; n+ d& @

' p  ?8 O+ p0 a$ f( R
/ ^+ M+ {* ]  P: x' T7 u7 E( [而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行  ) v/ k1 b6 E+ z5 X
) \# g) C! Z3 ~* P8 o% W1 z
Joe编写的签名applet:  $ T  u* G, D! h  c7 ~% @& f
0 H/ P# L7 ]! o& Q# ~$ x8 H" T; o/ Q
//得到Joe的证书并将之读入到密钥库中susanstore中  
2 z& P- Y: Y; s; k5 V2 z
9 m3 G- t0 B' e, [$ n+ d8 lkeytool -import -alias joe -file joe.cer -keystore susanstore  5 l3 c1 x8 S: L$ W! T! G
* |* q% M9 m  y6 \* `
//运行policytool产生满足Susan要求的policy文件  : C7 @: E! A' ^# @& b  s0 M5 j

  V4 f: A% a$ d! tpolicytool  
# j1 J( H0 b$ V. Z: [- s5 H
8 W7 y* V( t" c1 F" R5 r, ~//用appletviewer运行之,或在浏览器中安装java plugin来运行之.  
& ?* T) Y, X4 H( {4 D" ?# Y) o: O) t# e9 u' W

  Y! E# Z9 M+ X+ W  K+ D3 B) ]. x% r4 A7 n. B
关于签名applet在Java Plugin中的部署请参考以下网页:  3 P. Y* j; h; @0 D# `: p, \/ |: }' P
1 ~  ]/ d9 }' n! G0 x& Y
http://java.sun.com/security/signExample12/  0 s2 e, G' w5 S' U- R
, P& w$ a6 ?" M7 K; M  m, T

: u$ D$ W6 H) V0 g& T3 k5 `" x1 k- Y7 E" u! a( {! b
注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以  # b$ E8 o8 F/ N+ H  s6 S& d9 ]" }" k! t

6 h7 w. k. B1 g6 r使用keytool -certreq向商业CA中心申请电子证书.  
% ?' j- D7 `# c( M' Q1 }& C* Y& m' @
4 N" B2 {& r% r  ^  k* x7 g

) I* }/ e' u- s3 ]( y6 U' Q. }( x% U7 R+ o9 J
问:  6 [3 [, m* _9 @! Q) _% F# A
若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?  * {5 K$ ]+ t8 ?; d) `9 d2 T

( B* R% ]# ~# L* I: S& T答:  1 \# F/ y  x0 x5 b" L( s
使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.  * a/ W3 H4 S7 I; Y; ]
% B# k2 o; P5 ~$ f" U0 S
问:  * H# e* a7 C# e$ {
对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?  # L- F, E& }/ Y7 G% E
3 I3 o5 `! f  X/ q
答:  # p3 Y5 T( G7 x! z3 \
目前,没有直接的方法可以将对象写入到随机存取文件中.  4 \- n. B& P5 q( k1 `# O, N# F
但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.  
! L( {% C* r, l' k; t( m
8 E, d$ S- j  {+ m问:  5 f: [& i% w( n1 S* S* t
运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?  
$ {& D) F$ w4 n4 p
/ Q6 O7 {/ ~- X( C6 c答:  
( g6 v( s  {% a可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务.  
. T  k% d) q: |8 l  i' u! X! k; c* I1 d' \7 \- R
问:  ( c. d0 W- K# ^# ~6 R
使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?  # h! y& J  c$ q9 J
6 E. n7 p  K! m3 d
答:  
: Z4 P6 y2 D0 y  N使用如下方法可以获得PrintJob的实例用于控制打印操作:  
, N$ ^. I9 C& `" j% O9 _9 T8 D( C4 |) h' R

) F9 B3 u- y# k+ ]. I8 @Toolkit.getPrintJob(Frame f, String jobtitle, Properties prop)  
$ O! O! }8 u2 }, z
9 e4 T  r; E/ w/ j那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:  
: c7 {4 ^. H3 I9 v. z* f) _5 _3 u: A/ S" g0 G9 w0 E
awt.print.destination: 可以是"printer"或"file"  - t' F: [# U8 |! ^" p4 k

' t/ f. t( o" v, Oawt.print.printer: 打印机名  " y; b" b- D% \, w

* F- w. y! y; q+ H6 ^7 ]awt.print.fileName: 打印文件名  
& F1 }" a( ^5 I% @6 \5 n/ W' k' R& S3 u0 ]7 k0 D
awt.print.numCopies: 打印份数  
8 c, V) A2 t& o( s
: m2 j; E0 c6 r, x- d2 @awt.print.options: 打印命令的打印选项  
4 M  ~1 U6 \+ {+ J- H
% d, c* O2 ]1 q6 Tawt.print.orientation: 打印方向,可以是"portrait"或"landscape"  : X  u" `: c3 }

5 M. B& X: Z2 M# y8 Bawt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4"  
& J7 r0 }$ T* T0 n1 L6 z8 p5 j# H3 y+ S! M$ d
8 A/ x( y0 W) |7 W7 n* m
# d6 t2 J$ ]5 y, a! x

% B, I6 ?8 G: U
4 t; `$ U1 O- s4 }/ K
% y8 j" Y# b* V5 d9 w+ ~4 C/ h问:  
  Z  g6 \+ w/ y9 K- S( h" Y2 j7 D在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?  2 E2 [* W1 }4 @6 s

: n& q: H- x/ @6 T8 o+ r( u答:  ( B8 k- ?& a6 g* b
Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.  $ C% M( v1 @" I+ }* R7 c
3 ~* _- L/ T1 z; C6 |. r
因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.  + X! a, M! p3 v7 l( O" s

$ y. {  }% d6 {$ W问:  
. g* ^1 P# c) t  q+ z4 }+ N. z/ q" e使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?  : }5 t' w2 \0 v; T8 ?, y% F4 U. I4 U+ C- f

8 n0 O  W5 l$ |- d答:  
# M6 S- h. g# X& |$ I在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:  
1 s/ k3 C( A! g0 l1 l6 M2 S8 P4 t) W
2 G; s; A8 ]: F
ResultSet.first():将数据指针移到结果集的第一行  ; R3 k: g/ d( Z6 [3 n  x
+ m; e# `; `5 j  ]  s1 l8 l
ResultSet.last(): 将数据指针移到结果集的最后一行  
) A  q, P* B4 W( G: N
5 w4 o  r$ w3 Y% @1 k; ]- A& n9 e7 mResultSet.previous(): 将数据指针上移一行  
: q" T8 W) Z: O2 B7 z) a! W7 y

8 h3 S0 K* [( w4 u. L以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .    o- O+ [! J5 }1 q2 p5 o
+ F: y. w+ w. R& S$ i, U: `- Y

+ y5 c/ A# P9 s+ N( a问:  $ B& O. [, H& @) @: ^/ h% |
哪几种Web Server支持Servlet?如何使IIS支持Servlet?  & x$ w; Q2 ~  U- C% L! M

. s8 Y0 W8 ~1 q9 ]& s- q- x答:  : }3 c+ W) l9 r" x7 t
目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.  ) I( O% r7 W) U4 m
1 N3 F8 a1 f2 g# o3 ^! L' l
此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.  5 [( d( _; D. x1 [/ j, Z
% M, p' T# P, t" U' _
问:  
+ E6 `4 I( t) C' \如何在Java应用中将图像存储到图像文件中?  + s+ {( w0 K+ V/ l% {! Y! \
/ G2 \4 s0 U5 F4 ]3 G" ^
答:  & a" C2 K$ h: S  f# X4 f
Java Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:  * r* R0 N) i0 n( ]1 T

% r* F# {4 S9 ~2 ?3 |5 D( ~6 F1 F  U! G3 D
OutputStream os = new FileOutputStream(fileToWriteTo);  8 E, y8 S7 ~! S% X7 o! [! q

% b2 [% ~, r; B, `1 g3 H# JBMPEncodeParam param = new BMPEncodeParam();  # [2 s. r+ @9 U$ K

. F% u& ^" k. y  K3 A5 \; IImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);  
$ u$ D& J5 D( B% d5 T) d' D+ ]; N# Y9 H- I# z3 C! ?3 F
enc.encode(img);  
& f# i5 y4 |# p9 b7 D9 o7 W
, i: D/ w  ?7 _6 p1 m% A& h7 {os.close();  
$ N9 K; ?; [1 s$ D( w, U0 C/ Q4 P2 L+ F4 D( \7 G
有关存储图像文件的编程指南请参考以下网页:  . J. R8 g5 r( k1 y% f
0 G1 |5 ?7 i7 `/ S+ m/ ~: G
http://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/  
3 Z, ]5 h& n2 G% {2 |( p. ~# k0 P% g0 Q. B4 p( C3 _" l% n

; T  _+ G5 w) J4 A2 q1 [# |1 h7 q/ M1 q, o2 ~$ }

0 v" s  }4 g. K+ b6 \1 R8 k问:  
: z- }* P1 b! s如何用Java语言向串口读写数据? font>  
0 _7 f: Y8 Q4 b$ Z9 N  J' h, o
5 `0 w# }% T( g6 `: l答:  * J2 @: Y) N# Y# _/ H: w/ V
Sun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制.  & U6 i& c( f7 L6 S  x( R

4 ^; z- L8 u1 T" ?详细文档,请访问:<a href="http://java.sun.com/products/javacomm/" target="_blank" >http://java.sun.com/products/javacomm/</A>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
如果我没给你翅膀,你要学会用理想去飞翔!!!
wangyu249        

1

主题

3

听众

54

积分

升级  51.58%

该用户从未签到

新人进步奖

回复

使用道具 举报

wl820609        

1

主题

3

听众

23

积分

升级  18.95%

该用户从未签到

新人进步奖

回复

使用道具 举报

deven1985 实名认证       

23

主题

3

听众

2433

积分

智慧的蓝色小毛驴

  • TA的每日心情
    开心
    2011-12-5 23:03
  • 签到天数: 106 天

    [LV.6]常住居民II

    自我介绍
    200 字节以内
    不支持自定义 Discuz! 代码

    新人进步奖

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-21 13:24 , Processed in 0.372416 second(s), 70 queries .

    回顶部