QQ登录

只需要一步,快速开始

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

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

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

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-3-31 01:31 |只看该作者 |正序浏览
|招呼Ta 关注Ta
问: 如何设置Java 2(JDK1.2)的环境变量?  
  {$ h: D5 o4 h1 w( O$ z
6 `" u! ~0 ?+ F9 ~1 F' `- b答: Java 2安装后,需要设置PATH和JAVA_HOME环境变量.与JDK1.1不同的是:设置好JAVA_HOME环境变量后,JVM将自动搜索系统类库以及用户的当前路径.  
2 ^) v% B5 f5 G7 h& `! R0 ^Java 2环境变量的设置如下例所示:  % A* U  ]' M7 n( E0 r
Solaris平台: setenv JAVA_HOME Java2的安装路径  7 o9 O" T% i3 Y/ r+ P
setenv PATH $JAVA_HOME/bin{PATH}  
( S1 e) y2 ?3 y. N3 j( e0 OWindows平台: set JAVA_HOME=Java2的安装路径  
$ i0 y* x6 W/ c3 l8 m; Q0 Eset PATH=$JAVA_HOMEbin;%PATH%  
, i2 N8 [5 J1 [8 g$ z: l, ^
+ w5 h8 R/ m( x4 E4 f+ g" q问: 哪些Java集成开发工具支持Java 2?  
8 u" A5 Y" y8 ?0 C2 N! R, C; X, \* i1 k) ~% H! ^( Y9 Y
答: 目前流行的Java集成开发环境,如Inprise的JBuilder,Symantec的Visual Cafe, Sybase的PowerJ,都支持Java 2.  
; S3 i' D9 S* H/ g7 k: q7 G. E) {' _+ y1 f8 g5 X  ^
问: 如果在Netscape或IE浏览器中运行Java applet时出现了错误,如何确定错误范围?  
4 Y- p) d6 k: b. O7 W) c% z
! l* A' Y7 F1 ^! ?. y. D答: 当java applet在浏览器中运行时,使用的是浏览器本身的缺省JVM.而不同浏览器对JDK的支持程度也不尽相同. 因此,在Netscape或IE浏览器中运行Java applet出现了错误,建议使用JDK提供的工具appletviewer或Sun公司的Hotjava浏览器来测试该applet,以确定错误的产生是与浏览器相关.  , P: V5 X5 f& P5 \
    如果applet在appletviewer或Hotjava中运行一切正常,则错误的产生是由于浏览 器不完全兼容JDK而引起的. 此时,解决方法可以是使用Hotjava浏览器或者安装 Sun公司的Java Plugin.  
) d" b, t  q2 u  m3 {+ I    如果applet在Hotjava浏览器或appletviewer中运行即发生错误,则应当根据错误 提示检查applet程序.  $ L4 D- @6 X3 }+ N9 y

( f/ [3 n# K9 t; L' v" l% F; q问: 当用JDBC向数据库中插入数据或从数据库中提取数据时,为何有时中文字符会显示为乱码?  ' [0 W& G- T; \( s% O3 E- ^
' @' g: D" c! F! i7 h' H
答: 这个问题的实现通常与各个JDBC driver的实现有关. 目前大多数JDBC driver采用本地编码格式来传输中文字符,例如中文字符"0x4175"会被转成"0x41"和"0x75"进行传输. 因此我们需要对JDBC driver返回的字符以及要发给JDBC driver的字符进行转换.  $ d+ [1 ]! b' c" |8 r

0 u# p, p, H2 C( t+ v/ r, z当用JDBC driver向数据库中插入数据时,需要先将Unicode转成native code; 当 JDBC driver从数据库中查询数据时,则需要将native code转换成Unicode. 下面给出了这两种转换的实现:  " O% V8 J! T  |: k2 x6 q! H- X. N
, ~  l% a* @" `% X* @

' K; q: n7 G& W. B3 cString native2Unicode(String s) {  # l7 U* X) m2 T6 d+ j& O8 E; l( {

% |) n0 V: |$ H. `8 {' h* Fif (s == null || s.length() == 0) {    M$ R: p. m0 m  }5 ?9 O
& N! L4 z8 M' b+ }; r; o( @7 q
return null;  8 w; S1 C. j% p# Q

3 |' Q# Z$ g" J) x, k" x- T! ]}  
- R8 `" c! X7 W! }) h0 ]
" ~0 t! _8 z" W; }byte[] buffer = new byte[s.length()];  
" w4 p0 d5 c+ |# L" M$ s- j! N; a  F, E1 v0 g% r' ~) E7 W+ g  h
for (int i = 0; i s.length(); i++) { if (s.charAt(i)>= 0x100) {  - S3 E; {8 S4 s( s/ N& u, q0 Z
9 o  r. {4 j5 j& \0 |+ }! F
c = s.charAt(i);  
8 q! D0 |4 }# L- f3 J  E" x8 \7 F  |! B4 K5 i
byte []buf = (""+c).getBytes();  
7 w7 Y+ P- s1 a/ Q5 z! {' o5 n- ~& i' o9 i! @
buffer[j++] = (char)buf[0];  , V' o: s) P' B% h4 [
8 ?/ p3 P' ?: u7 J
buffer[j++] = (char)buf[1];  
9 a! a. R+ B) {: r6 l4 ~8 a2 `( k7 Q& @: ?) Y
}  
7 |1 D. @4 I7 t5 i0 D* J1 Z, M0 g: o4 v% E1 E/ t
else {  # `3 _4 }; A( K
1 T$ x9 o: u/ M3 v
buffer[j++] = s.charAt(i);  
( O9 P; d" d' P# F  F) s6 o* C& ^8 Q) ]* P$ V6 T& [+ O
}  $ R- P1 K% n8 D, s. P0 ^
5 j+ J8 v' Z' z% n/ \' @
}  
; N7 C; k: a: n- h# f% \0 B# C+ C/ W. I, a9 H. [7 h$ d& P
return new String(buffer, 0, j);  
4 V( ^" E7 t# Z0 m; r
+ H0 K* i; b& ^' K/ y. v}  
: t% ?( F3 x. u# W  {5 D; v! e# d. H+ G$ w$ j* ?0 n
除使用以上两个方法之外,有些JDBC driver如果对jdbc driver Manager设置了正确 的字符集属性,以上2个方法就不需要了.  + t6 z& K* M9 n+ w8 w# {$ d7 I

& C* j4 j" h: f9 H/ N0 x" Z7 D- x" K
问:  
4 W0 H' S# }( B# ^" `当用Servlet来处理http请求并产生返回的HTML页面时,如何使HTML页面中的中文字符能够正常显示?  : ^6 o" ]! h( H% j. {

/ K, c( P7 {7 z答:  - X8 Y" i$ \8 n
javax.servlet.http.HttpResponse类用于产生返回页面.通过HttpResponse定义的方法getOutputStream()可以获得ServletOutputStream的实例,这样用户就可以利用ServletOutputStream.write方法向输出流中写入返回页面的内容. 但是ServletOutputStream使用的是缺省的编码方式,如果要使返回页面中的中文字 符能够正常显示,最好显示地指定所用的字符编码方式. 通常需要构造一个 OutputStreamWriter , 例程如下:  
( m8 O% Q( V- U
2 P; g5 A7 R0 e; F+ Q/ \3 R5 b0 J3 A' e0 ?$ J
public void doGet (HttpServletRequest req, HttpServletResponse res)  
" U& H5 p' I/ p4 \* U3 p$ n- e2 V; V. z# _4 ~; q
throws ServletException, IOException  
5 q. I/ f$ m7 f& M/ b9 r+ e, B$ ]) `. b5 N: o
{  " X: h8 u  h/ V; P

, P0 e3 h! d5 b  z7 hres.setContentType("text/html");  & q0 M5 J& q3 Z, ^" n
6 g* P/ ?" O% [# ]8 H* h
ServletOutputStream out = res.getOutputStream();  " b, J3 _% P; ?& t  E& \

2 A- A0 o, p: }; N8 _& MOutputStreamWriter ow = new OutputStreamWriter(out,"GB2312");  
. R: D1 q% l/ ?( I! d, n8 m0 A; ~8 w6 m
ow.write("这是测试");  ( p9 f; v! u3 j6 p6 X4 Y
5 W: s# J" [3 k+ E( G- \
ow.flush();  * I2 y  ]9 _; n9 ?/ f
( v' b1 H$ }; y) v$ O; A
ow.close();  4 N2 E4 ^- L4 A3 p
# w, x5 Q2 V' n& P" C* b
}  
0 s+ n8 Z: ~$ u6 @8 L% H, s
* q! g  {. w; W5 y" I2 E
! }. b0 k1 u( E7 [7 h3 ^问:  1 M* W0 a' K9 V
如何设置Java WebServer的CLASSPATH,以包含用户的class文件?  
9 u: |) ~$ O4 Z( C. J- l$ h
" @/ W4 O# Y2 c3 |4 e2 Q  |6 W答:  
5 E: a  a+ z- U* k' }, g- O; y有两种方法可以设置Java WebServer的CLASSPATH环境变量,以使用户编写的Servlet能够调用用户的class文件.  
" b# I2 B8 }4 |/ r6 A将用户的class文件放到 JavaWebServer_Dir/classes目录下,在Java WebServer 启动时,classes目录被自动加入到CLASSPATH环境变量中了.  
3 Q7 @& n& q( e( ^5 W, C修改httpd.nojre文件,将用户class文件所在的路径名加到CLASSPATH环境变量中.  - X& g$ @: K- e5 @
  n* D! Y7 r. ]6 j( B. G; I
, D) J. h" y& \7 V; g. ~
问:  2 Q! B1 ?7 [# _$ O) P; B: B
为什么在Windows平台上用Naming.lookup来获取远程RMI对象时会很慢?  , n% j% s5 J. V0 s

$ G6 }. w# B6 {答:  
5 `# `1 P5 J0 {$ T$ ?机器的网络设置不正确很可能会引起该问题的发生.  + K% x+ [8 x4 j% d$ y7 K
RMI使用了Java网络类,特别是java.net.InetAddress类,它将查询TCP/IP的主机名, 包括IP地址到主机名的映射和主机名到IP地址的映射.在Windows平台,这种查询功能 是由本地的Windows Socket库来实现的. 因此延时是发生在Windows库中,而非RMI中.  , K0 t( D% \" F$ E, O) R/ g  n

- ?' w' ]! w! r' b5 h4 b, _如果你的机器设置成使用DNS,问题通常是DNS服务器查不到主机名,你所发现的延时 是DNS查询的延时. 请尝试将RMI通信中涉及到的所有主机名/IP地址加到本地文件 winntsystem32driversetchosts或windowshosts中. 格式如下:  1 B- x, i& e5 f- z

* f/ z/ _* W; p- k, j* OIP地址 主机名  
. e% a+ P% s( D1 P" r  q( m1 ]/ a/ {# N2 C+ X/ N* j6 t
如此设置应当可以明显地减少查询所花的时间.  
* G6 p2 T# l% C; b
( X& N1 e) H. e( |, s4 ]问: 编写Java application时,如何设置proxy的信息,以便访问外部网站?    ~) H0 a: J. O
; w/ H2 C8 S: l  O$ F0 B
答:  
, V1 d! ]. v* l  L+ n1 d若在java application中访问外部网站,首先应设置proxy信息,样例代码如下:  % r4 |2 E' k- U6 ]+ D
5 y  z5 d$ N% z1 R
/ d2 k% P/ }2 m/ B9 t0 d0 M
import java.util.properties;  
- \. |# X9 k6 P, l; C; Q, `9 K
0 ?2 Q& P5 K: h0 v5 W$ V4 w.....  " b5 e+ Z6 C3 o3 w1 q8 F
+ y* F% Z/ E5 O" I+ D8 M! v+ d  t
Properties sys = System.getProperties();  
+ z2 \8 P6 P% T; C' z' H/ L+ X! i7 J4 R1 ]: w9 D: R! B
sys.put("proxySet","true");  
2 I: U% `1 u+ y3 r5 J3 D/ i1 B& U  s% B* K
sys.put("proxyHost","myHTTP.proxyserver.com");  " l( {& s" T5 l1 w0 C) R$ a

; g9 S: d# v9 P) b& L; tsys.put("proxyPort","80");  8 q& {, A% H" t( V, U

5 O8 Z0 u' X& m/ u, M  nSystem.setProperties(sys);  $ J* F5 u0 k, w6 F4 l/ E1 g

8 p) C1 y/ M! Z9 s5 l9 \
5 {8 W3 \9 c  E
4 f/ f' d& p2 F. Qu = new URL(website);  3 K5 L4 R6 i& B7 S: q
  n' ?2 ^8 z" v: C, A2 X" P" _5 Y
connect = (HttpURLConnection)u.openConnection();  
* z1 c1 \# R! {7 ?4 L& ^3 ~0 u
8 R5 l. j0 Z4 ]# X.....  6 |4 }. `* G5 ^0 p, x" ~
! o* Y6 Z+ a* r6 p' ^) ^* M
问: Swing组件JList的列表数据修改了,如何通知JList改变显示?  ! i1 x2 V$ i( ]" D" t4 i
/ Y( b3 ^1 D' l$ _3 }
答:  
# m) T% e9 _: y( ~0 z2 iJList组件有一个单独的显示模式ListModel来表示JList的显示数据.  
6 R7 w$ K% f4 h! b2 f9 T- w" xJList创建以后,JList数据元素的值及数据元素的数量可以动态地改变.  
; l$ p7 g' @. \# o/ oJList在它的数据模式ListModel中观察数据的改变.因此,一个ListModel 的正确实现应当在每次数据发生改变时,通知事件的监听者.  ; ?# D  |7 A& j: |3 ^- [  @# r; K
当使用构造函数JList(Object[])创建一个JList的实例时,系统将自动 创建一个DefaultListModel的实例来存储JList的显示数据, 可以调用 DefaultListModel中定义的简便方法来动态地修改JList的数据,如 removeElementAt(index),addElement(Object)等. DefaultListModel 在修改数据的同时,将通知JList关于数据的改变.  
. d; h( s) g2 a" o8 c/ l) u6 E6 p
# v' Q/ _: n& ^; w问:  
8 t7 \7 D# X. n0 z0 V, }在Java applet中如何实现一个模式对话框?  
+ [6 n! i+ S8 Y# \3 n/ _, [$ h. I7 ~2 _
答:  
' h" y4 u1 v' z在Java applet中实现模式对话框的关键就是在创建一个对话框的时候 要为该对话框指定一个正确的父窗口.因为Applet是Panel类的子类,不 可以作为对话框的父窗口,所以首先要获得applet所在的窗口,作为模式 对话框的父窗口. 样例代码如下:  $ P' t5 L7 l  N

9 V! a8 R% W0 j
7 V5 }* ?8 H: V- Q) V.....  
5 N! e) `4 l  M9 ~( f' U* n% n, J/ p& g+ \) [
Dialog d = new Dialog( getParentWindow(comp),title);  
% O- {2 B3 h; V9 A
! s6 M7 x  y4 y! U0 [) k9 k& j// comp为applet上的任意一个组件  
2 l) y/ c9 A, t# {* m6 i& p) f" R5 y; ?7 |
....  ( S* {2 {7 [  f+ r2 B

6 |# ^9 @4 _$ N: ?! S1 ~3 j1 o
, I$ H. \1 C5 p: W4 c3 k. z
* v5 {  t: y% Ipublic void getParentWindow(Component compOnApplet,String title){  , d; _. k. g/ g$ J' W) b
: h$ ~; D/ G2 i  C" y  C/ j
Container c = compOnApplet.getParent();  ' |0 u! E: d0 F5 ^4 A
- U( P7 J" r4 p$ p! Y9 x
while (c != null) {  : h* K1 P& }2 O( t) O

7 b& X  |3 D: m; f+ m& ?if (c instanceof Frame)  
$ F& f, \( O  ~* f+ ~" {& o* h
* v4 b1 u  l& v7 wreturn (Frame) c;  
7 ?1 w" `: A& t5 E: |# O2 V& R) c; v$ l- y; S9 D
c = c.getParent();  
% n5 h' b4 j$ ?3 [9 @& y& F9 w+ {, r" L7 \% u0 P% y
}  
$ D; z) s5 B1 i& c* O9 w* q6 m
( Z# S; |# k& c+ {return null;  * \: }$ e) [  L. s

% T' K' l% Y& D) p' h  ?" W}  $ Q% H: M( a- @
+ R# q+ \- [1 B  m+ P! l1 Q2 Y
问: 在Java applet中如何显示另外一个HTML页面?  - n/ |1 p' M: ]: d+ X
* z1 `7 t" b) w; e, }
答:  / {& U% y5 i& K: A. H) q
通过java.applet.Applet.getAppletContext()方法可以获得与该applet相关的AppletContext, AppletContext.showDocument(URL)方法就可以使applet所在的浏览器显示另外一个网页.  
, C- f* X$ a- x
2 Z. N! V  r4 K; h/ a问:  6 w9 y- J) [" q  ~- ]& Z+ V7 D6 g
用JDK实现的签名applet,可否在Netscape或IE中运行?  
8 x6 p+ ]" g; J* S4 |7 ^$ b% T5 `5 n5 r$ E- ]0 l% i
答:  ; e1 L1 P. a' M& C/ X: x
用JDK实现的签名applet,不可以在Netscape或IE中运行,但是可以在Hotjava浏览器中运行.  
1 D5 q% L/ \" z
- z, X) I; f8 k不同的浏览器提供了不同的签名applet机制,如Netscape提供了zigbert工具和 Capability API, 而IE则需要使用CAB文件. 但是,无论是Netscape工具产生的 签名applet,还是用IE产生的签名applet,都不可以在其它的浏览器中运行.  ; _4 w- _0 E" t' Y
; q9 [6 L* W; c: ?# p: h/ B
如果要使JDK产生的签名applet能够在Netscape或IE中运行,解决方法是在 Netscape或IE中安装Java Plugin,则用JDK实现的签名applet就可以在这两种 浏览器中运行.  1 r- e0 o+ s; ~  W" {, f8 A/ D

/ M. V; z- I5 Z" l' {' U( l6 e8 N问:  $ x. u0 n( _/ b1 m
用JNI技术可以从Java应用中调用C程序库,但是如何使该C程序库可以调用另外的C程序库?  $ [7 f' |8 m7 r2 [- x: d! p6 W( X

9 d4 v: n8 _* ~答:  ' h( o# V7 P* p( x
如果一个被Java调用的C程序库C1仍需要调用另外一个C程序库C2,那么在编译C1的时候应当联接程序库C2,步骤如下(Solaris平台):  - B* A8 ?, {6 k! v
编写调用C库的Java文件,并编译.  4 G5 ~9 I% H  M8 E
javac java文件名  8 A+ C6 w( R4 E& _6 r& }4 b

/ p0 f# I; r( j  W, T" Z4 \9 }6 ^4 Y3 K
产生C程序头文件    y; l% G- T( p$ g
javah -jni java文件名(不带后缀.java)  
; }" F  Y4 R) G, ^  j* r+ l/ \
- e1 d9 R4 X1 u7 o- G* D: x* U2 T; x+ U( ]3 {' W! J' i3 Q! U+ G
编写被Java调用的C程序C1.c,以及被C1调用的C2.c,并编译.  $ A! E$ J  b! e+ N8 A
cc -G -Iinclude路径名 C2.c -o libC2.so  % f, B2 C: a) e# a4 i7 [
cc -G -Iinclude路径名 -lC2 C1.c -o libC1.so  
+ |$ ?$ c; I) [% C- E% C+ S
( J  x. r% B' b' n3 n* T6 s; R5 N! {0 o: }3 D1 \/ d2 s0 }6 j- ^% N& @
设置环境变量  9 b: [4 E$ c3 ]/ c: W, P8 `
setenv LD_LIBRARY_PATH libC1.so,libC2.so所在路径  6 }. {# ]! ^. h6 P/ R# Q( J/ O
{LD_LIBRARY_PATH}  
% l3 w$ {5 D% R2 m, G0 x) N1 Z- f
* g' R# X+ }; y# `! v
, Z" ^  V; I% B5 y运行java应用  
, K8 u3 u9 j" W6 j4 c6 {7 Q
- V4 Q5 M6 L1 ~9 p4 @' Y; P4 `+ @6 P; O- o/ l
问:  
# l. `2 E$ E( v在Java语言中,如何列出PC机文件系统中的所有驱动器名?  
, ?9 Y( b" x) e6 e0 e! z
4 ^0 {9 L! i0 D- |答:  3 y8 A/ R# L( D+ M. W/ |
在Java 2版本中,java.io包中的File类新增加了方法listRoots()可以实现这一功能.  ' f# v7 N7 q# K* A

, d4 L; V$ V2 V- u, A问:  
! @: F$ @6 B6 G+ G& A7 S7 ]为什么Runtime.exec("ls")没有任何输出?  6 h- s; d: Y# L3 B7 N% B+ \: Q

% R1 x) a' ]; A4 x; _* a答:  9 S! W+ w: g2 u& s$ `
调用Runtime.exec方法将产生一个本地的进程,并返回一个Process子类的实例,该实例可用于控制进程或取得进程的相关信息. 由于调用Runtime.exec方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream()方法重定向给它的父进程了.用户需要用这些stream来向 子进程输入数据或获取子进程的输出. 所以正确执行Runtime.exec("ls")的例程如下:  
& }6 [* E" g4 e* s" o: N
1 t$ |# g2 @# y3 I- s% C+ P: G
$ V' ?: E8 q3 M4 A! _# O8 L/ e% L4 gtry  # v' n5 M9 D9 J: O& u& {/ `6 a! H2 N
" A3 G! N- ^) L0 `" t, X9 W
{  , t( Y, `$ y' x6 i  M

# p1 J2 F, {" Y, Hprocess = Runtime.getRuntime().exec (command);  
# E  @' C9 Q, |* H+ @1 t' P$ {
8 B5 {* _" ]' @% K3 uInputStreamReader ir=newInputStreamReader(process.getInputStream());  
# ]2 J7 P7 J& A% w& e: l2 O
" U0 _  a( q) I" F8 W  yLineNumberReader input = new LineNumberReader (ir);  # X7 w$ [2 N" v* H  M/ U
3 o! l9 f9 z$ M
String line;  % Q' t7 U+ ~8 W  F- [7 p  F* Q$ I
) e) M/ w( ~) p( S5 H3 A+ Q
while ((line = input.readLine ()) != null)  
  L/ L. w0 D# C$ A+ t6 q8 M$ l: e* [+ D8 C7 P
System.out.println(line);  
3 \  T9 S! s" q/ `* |, C
. e' _) o, {- R6 p: I}  ) w" p4 _" B: J5 z* Q
! ?" N% t" a+ b) o9 l4 o
catch (java.io.IOException e){  
0 X; ?7 Z& P; U% C6 H' h
1 R4 b, e' _7 K) q6 ]8 }8 G" U' _System.err.println ("IOException " + e.getMessage());  
% G2 L0 b: J. n* w8 t5 n
2 B( E% U% W; Z7 K. W}  
$ |1 n# d  [4 z, J5 M: B
3 i3 J: @7 P+ }! s7 R$ J, v, o8 [
问:  
2 ]! g" b4 m) m$ Q: H4 v$ H如何产生签名applet,以使applet能够访问本地资源?  
6 j1 Z+ u2 k! R- W' n6 K3 m. x3 c9 x# D0 |3 g
答:  # `1 V# L- t6 s# |, f
在jdk1.1中,可以使用javakey命令来产生公钥,私钥,证书和签名的jar文件,详细资料 请参考: http://java.sun.com/security/usingJavakey.html而java 2对签名机制做了比较大的改进,允许用户更灵活地设置安全权限.Java 2提供了三个工具:keytool,policytool和jarsigner来实现签名applet.例如,Joe编写了一个签名applet:SignedApplet.java,那么产生一个简单的签名applet的过程如下:  
& y9 e' B$ o% F' |
+ _$ h+ Z; V' l; H1 h: ~: A4 I0 P" g6 {$ ^. O9 e4 J/ x& d
//产生密钥,密钥别名为joe,口令为sign12,存放在密钥库joestore中  
  v1 C+ X% J8 Y( K1 x: q
* \# i2 V' L# b- Hkeytool -genkey -alias joe -keypass sign12 -keystore joestore    R( ?5 J: z3 w  K) S, Y7 s! {

5 V1 p$ c" `' C( p" J8 u//将SignedApplet.class及相关文件打包成jar文件  
9 b3 |2 F$ Y3 J" \6 Q5 C( \; ^% e6 |  o# {7 J# s. e
jar cvf SignedAppletDemo.jar  6 s3 \- J1 @8 S' |- L

- O  y7 A& Y8 G, X" a//利用keytool生成的自签名的证书产生签名applet(jar文件)  4 V5 o$ [( g) K, P
  i- `3 {# J! U- g
jarsigner -keystore joestore -signedjar joe.jar SignedAppletDemo.jar joe  8 i- @. S- M2 k
9 Y5 N( ?  {/ A# I/ a
//将自签名证书从keystore中输出到文件  * ?% L! M/ d/ A* P0 V
1 y- P. ^9 E# l
keytool -export -keystore joestore -alias joe -file joe.cer  - w% O# u+ [, ~; j& K" R: m& ?$ j' R8 m! s

; N' N, e6 R& T) W) k1 r+ s' q- ~! w0 Y

  O2 U! d' b0 n4 B/ g2 t% E而对于签名applet的接受方Susan,需要通过如下步骤来安全地执行  1 ]! `) T% j  O+ _9 l! }4 A! L* E! I* w
0 w- a, h) Z8 f4 |+ A) i
Joe编写的签名applet:  
% u2 _7 c. M9 X$ \/ S4 L  r1 V/ C' r0 Q3 a1 Q
//得到Joe的证书并将之读入到密钥库中susanstore中  ) k  c# D/ M7 b
$ g" n# H0 y# U7 r6 o- A
keytool -import -alias joe -file joe.cer -keystore susanstore  
- B6 y" @5 Y2 ?; D, P+ T3 _8 Y4 z$ K, G5 [' `. m7 U
//运行policytool产生满足Susan要求的policy文件  . h0 P9 O6 @0 L2 D. H5 `$ f. F
+ I8 z; T& v- h1 a4 }! h
policytool  ; r7 K! {4 d. Z
; J( P: Q& T, W; I9 [/ m% i8 M! o
//用appletviewer运行之,或在浏览器中安装java plugin来运行之.  
5 T1 a! [- n0 m& [
1 s/ A; a1 u* _9 T
: a: g3 r: r+ I5 [: s: @
: Z7 i& O& R. W" b6 k# a关于签名applet在Java Plugin中的部署请参考以下网页:  ; y9 o( K7 i2 r
( \4 g  }0 s2 B/ i8 Z$ F, P" Q
http://java.sun.com/security/signExample12/  ' _% B0 k7 [1 [) i, V! y) ]/ [, Z

/ }6 ^' @7 t* t5 Z6 V7 E9 v1 Y8 v' v& U

6 h" z. r( S+ l' F! d, P! \注:以上的例子为简单起见,使用了keytool产生的自签名证书.其实,用户也可以  ! V" |; c  H' Y: B9 l1 J, F
$ i, l9 v! o8 c/ v
使用keytool -certreq向商业CA中心申请电子证书.  7 S$ w: v) m- V. a; ?0 F% ^

) p% X. H4 P( c7 T, h+ i# @0 k* `. Y- `: V
: l4 ^; E$ [' D5 H: m
- a7 _! M5 [7 x; {( q& Q# Z
问:  
& K) y/ ]" |. x- j若通过ObjectOutputStream向一个文件中多次以追加方式写入object,为什么用ObjectInputStream读取这些object时会产生StreamCorruptedException?  
3 J. \* j4 a1 j; L3 H* W; U) d' _$ @( Z0 T! t  R
答:  
  U% o: v; A1 E$ k0 R+ h$ N使用缺省的serializetion的实现时,一个ObjectOutputStream的构造和一个ObjectInputStream的构造必须一一对应.ObjectOutputStream的构造函数会向输出流中写入一个标识头,而ObjectInputStream会首先读入这个标识头.因此,多次以追加方式向一个文件中写入object时,该文件将会包含多个标识头.所以用ObjectInputStream来deserialize这个ObjectOutputStream时,将产生StreamCorruptedException.一种解决方法是可以构造一个ObjectOutputStream的子类,并覆盖writeStreamHeader()方法.被覆盖后的writeStreamHeader()方法应判断是否为首次向文件中写入object,羰?则调用super.writeStreamHeader();若否,即以追加方式写入object时,则应调用ObjectOutputStream.reset()方法.  
* ~/ _5 @6 B5 h; q* l) z- U0 S# S
% e! ^! F( ~  J( U) n问:  
; D. I* J; ?0 B1 x* M对象的序列化(serialization)类是面向流的,应如何将对象写入到随机存取文件中?  
, Q: ~# S! V/ E" w; a
+ Y2 |6 C6 Y: o; k答:  
+ a% ^6 b5 a) d0 W' f4 Y' |3 O目前,没有直接的方法可以将对象写入到随机存取文件中.  2 Y' ]& m3 v2 Z, m
但是可以使用ByteArray输入/输出流作为中介,来向随机存取文件中写入或从随机存取文件中读出字节,并且可以利用字节流来创建对象输入/输出流,以用于读写对象.需要注意的是在字节流中要包含一个完整的对象,否则读写对象时将发生错误. 例如,java.io.ByteArrayOutputStream可用于获取ObjectOutputStream的字节流,从中可得到byte数组并可将之写入到随机存取文件中.相反,我们可以从随机存取文件中读出字节数组,利用它可构造ByteArrayInputStream,进而构造出ObjectInputStream,以读取对象.  
% \, N/ O2 I$ j6 s% Y4 D+ l( [: h
& j4 H# F8 |+ C问:  
3 l( K; J3 |2 ?运行RMI应用时,可不可以不手工启动名字服务rmiregistry,而是从程序中启动之?  7 O  d7 e1 J3 c  t
' J1 \; S" C$ U1 Y5 n* a
答:  
: X  t+ w2 z2 A可以. java.rmi包中提供了类java.rmi.registry.LocateRegistry,用于获取名字服务或创建名字服务.调用LocateRegistry.createRegistry(int port)方法可以在某一特定端口创建名字服务,从而用户无需再手工启动rmiregistry.此外,LocateRegistry.getRegistry(String host,int port)方法可用于获取名字服务.  
! Y; q( X. ?, [+ S8 y. o2 T9 H4 n8 C( h; j% M  u
问:  3 U, y8 M: k& x) C4 a0 d- L
使用类PrintJob进行打印操作时,应如何设置打印机名等打印属性?  
8 m; I9 w' |2 z; N, U$ T( B1 B
/ e* H* d' J% I3 ?答:  
1 ?% L* B' g# C6 E0 n, e1 B, m使用如下方法可以获得PrintJob的实例用于控制打印操作:    R5 |8 i* ^1 q7 R2 S

) i* K3 ~! o' E% U
  j) t3 W6 K9 A8 H4 pToolkit.getPrintJob(Frame f, String jobtitle, Properties prop)  
; v5 N) Y1 L  ?! Y; J8 }/ `
# C& m$ K- `, P" E" F: l1 K* G' @那么对于打印属性的设置可以通过对prop的属性设置来实现,打印属性包括:  
& C% r* n4 @: P  C; a
( m$ l. ~* {# zawt.print.destination: 可以是"printer"或"file"  
. V: m( e. P& V% E
3 Z9 q; x, \" s% K; R7 A/ uawt.print.printer: 打印机名  
$ d0 C2 H: U7 d* ]) Z* r3 v% e2 _4 ~; B" Y
awt.print.fileName: 打印文件名  
6 I/ G9 Q, T0 C. a8 g
% y( S; @! a% M. ?' qawt.print.numCopies: 打印份数  
% o+ ]% J% o+ U' x
  z. o7 K* t, L! ^4 D' rawt.print.options: 打印命令的打印选项  
9 l6 t! t6 I5 L/ j! s  J- q# U' V! v; }2 p$ H* b. U8 {2 F
awt.print.orientation: 打印方向,可以是"portrait"或"landscape"  , t% S0 O. |; Y) \% k" A- M; q
0 e# k& j0 T+ a+ z, o" K2 Q
awt.print.paperSize: 纸张大小,可以是"letter","legal","executive"或"a4"  
8 S2 ]& c: ?# r  V* }8 D
3 n+ X. j# i; G% B1 F( l& t+ }
) G; F5 M# y6 s* }! A
/ a: {) M- d- l
, a3 o+ v. I2 K, M
# c& G9 X: v5 J" N( [) b) w6 o
问:  
5 T( s$ ^1 }8 O$ r% D8 j+ q' u在JDK1.1中Thread类定义了suspend()和resume()方法,但是在JDK1.2中已经过时,应使用什么方法来替代之?  
. Q8 V$ W0 A& J$ |# u7 V6 {  g3 M6 i; _) q
答:  * U; h# X/ y% Q1 j
Thread.suspend本身易于产生死锁.如果一个目标线程对某一关键系统资源进行了加锁操作,然后该线程被suspend,那么除非该线程被resume,否则其它线程都将无法访问该系统资源.如果另外一个线程将调用resume,使该线程继续运行,而在此之前,它也需要访问这一系统资源,则将产生死锁.  
1 U7 {/ l# S. Y  b
) x! ], Z* Q' ]6 A因此,在Java 2中,比较流行的方式是定义线程的状态变量,并使目标线程轮询该状态变量,当状态为悬挂状态时,可以使用wait()方法使之处于等待状态.一旦需要该线程继续运行,其它线程会调用notify()方法来通知它.  
. w' C) A7 s2 m5 L4 O  Y; S1 ^8 q: F* Z$ l7 ?
问:  
; |# p8 X9 j- Z2 a" U: O  \使用JDBC编程,应如何控制结果集ResultSet的指针,使之能够上下移动,以及移动到结果集的第一行和最后一行?    N) n; }$ v8 [; I/ F  i) l7 o
& h+ T8 J+ M! f1 Q) ^3 `
答:  : {/ _6 q1 ^) Q3 _; u9 }
在JDK1.1中,ResultSet类中只定义了next()方法支持数据指针的下移.但在Java 2中,ResultSet类增加了如下方法支持数据指针的移动,包括:  ! d3 c* _( f# W! B
% I% G+ W% v6 A0 F3 F& l4 |. {

& o& g: K$ @/ v9 y2 NResultSet.first():将数据指针移到结果集的第一行  
+ y2 g6 @& I$ ~0 u  \) u
" M1 n& I' K& YResultSet.last(): 将数据指针移到结果集的最后一行  
) g* F$ b: m* @6 f- N( d: D4 E
" R1 L4 P, E3 M/ p1 x  P2 uResultSet.previous(): 将数据指针上移一行  * b% f! F! [. g% `

  z% R, ^! [/ W+ K1 c% X$ M4 u9 h9 s1 V+ {9 A1 H5 \: |/ @
以上的方法定义在JDBC2.0的规范中,所有支持JDBC 2.0的JDBC驱动程序都可以支持上述方法.目前Intersolv和OpenLink等JDBC驱动程序厂商均有产品支持JDBC 2.0 .    Y8 r4 W" x" k- v8 q2 T
/ B0 e% g6 i  T- t) a9 U
! g+ N+ E: [" ~+ e/ ]' l
问:  
+ z3 q/ m6 ^/ h2 Q哪几种Web Server支持Servlet?如何使IIS支持Servlet?  0 Y; K. ^% [. n$ B' T, o  u
( U( t8 p' [+ x. E: J# c8 ]& v2 o/ @
答:  ( p) e- d+ Z$ `
目前,支持Servlet的服务器端产品主要有: Sun公司的Java WebServer,Lotus DominoGo WebServer,BEA weblogic Tengah Server,Jigsaw,NetForge,AcmeServer和Mot Bays Jetty等.  
8 Q2 `! T' ^( f5 [# {2 q* d* K1 }+ |- m# G3 @
此外,一些第三方厂商也开发了Servlet engine,以使其它WebServer(如Netscape Web Server,IIS等)能够运行Servlet,如LiveSoftware的Jrun(http://www.livesoftware.com/ products/jrun/)等.  
1 {+ I* y, b: ?% U6 {4 I/ a$ l8 z+ Y% H1 w* V( `( C! ~1 Z
问:  
/ y0 L" \" f: h  c# d如何在Java应用中将图像存储到图像文件中?  
+ C8 }, q( B, D' L. v1 a
' \% z7 O: f) u" x' z5 I9 G) }答:  
3 j. ?' y- q& n3 VJava Advanced Imaging API(包含在Java Media API中)允许在Java应用中执行复杂的,高性能的图像处理.JAI API提供了存储图像的能力.目前,JAI API支持以下几种图像文件格式:BMP,JEPG,PNG,PNM,TIFF.下面给出了将图像存储到BMP文件的一段代码:  0 `0 n* I8 ]! n) R( Q
# l, n) D, c$ d8 S

4 _! ]6 S& E8 ]8 g4 I  xOutputStream os = new FileOutputStream(fileToWriteTo);  & c; y9 l+ A$ H& u5 D

, s2 k6 Q# @+ q) w& Z/ SBMPEncodeParam param = new BMPEncodeParam();  , T, @4 P$ D! Q( h
- \) O9 Q$ f1 g1 F. [! N
ImageEncoder enc = ImageCodec.createImageEncoder("BMP", os, param);  9 L& W. |2 r5 h" w6 }/ O

" b9 S2 _: N( u+ O. B) C$ ienc.encode(img);  0 b7 E. m2 g2 h% J/ p: B  [: Q
9 ]! v; e; }1 D' }
os.close();  4 A6 K6 \  W6 e5 @! c. E
. ^$ w! \& l: H* n7 N2 w8 S9 O
有关存储图像文件的编程指南请参考以下网页:  
; ~* U5 o3 X4 k$ u9 L  p$ b& x0 B6 K' o
http://java.sun.com/products/java-media/jai/forDevelopers/jai-guide/  
1 B$ t0 e. J* N* o( p" K. g- t/ l$ r! F9 ^% L: `
: C( P. i9 M0 Y% ^

( ^2 w  J( W, g0 I. [% r9 y. v1 b; v& Q6 V" X9 w$ N9 [' Y: q
问:  . v+ w/ j- F' [/ m& \9 ]
如何用Java语言向串口读写数据? font>  $ Q3 L" s! a, J
' I3 m/ z  \. i+ g7 J
答:  # b( A+ S0 W4 p7 {* G
Sun公司的Java Communication API2.0可用于读写串口,它支持RS232串口和IEEE 1284 并口,提供了一种与平台无关的串/并口通信机制.  / ]$ r- C8 s6 u& J
+ l" I5 ^) P1 F3 T8 V/ l4 ?9 Z
详细文档,请访问:<a href="http://java.sun.com/products/javacomm/" target="_blank" >http://java.sun.com/products/javacomm/</A>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
如果我没给你翅膀,你要学会用理想去飞翔!!!
deven1985 实名认证       

23

主题

3

听众

2433

积分

智慧的蓝色小毛驴

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

    [LV.6]常住居民II

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

    新人进步奖

    回复

    使用道具 举报

    wl820609        

    1

    主题

    3

    听众

    23

    积分

    升级  18.95%

    该用户从未签到

    新人进步奖

    回复

    使用道具 举报

    wangyu249        

    1

    主题

    3

    听众

    54

    积分

    升级  51.58%

    该用户从未签到

    新人进步奖

    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-6-12 04:00 , Processed in 0.555844 second(s), 70 queries .

    回顶部