﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-konhon-随笔分类-Java</title><link>http://www.blogjava.net/konhon/category/3016.html</link><description>忘掉過去，展望未來。找回自我，超越自我。
&lt;br&gt;
&lt;b&gt;逃避不一定躲的过, 面对不一定最难过, 孤单不一定不快乐, 得到不一定能长久, 失去不一定不再拥有, 可能因为某个理由而伤心难过, 但我却能找个理由让自己快乐.&lt;/b&gt;&lt;br&gt;&lt;p&gt;
&lt;!-- Search Google --&gt;
&lt;left&gt;
&lt;form method="get" action="http://www.google.com/custom" target="google_window"&gt;
&lt;table&gt;
&lt;tr&gt;&lt;td nowrap="nowrap" valign="top" align="left" height="32"&gt;
&lt;a href="http://www.google.com/"&gt;
&lt;img src="http://www.google.com/logos/Logo_25wht.gif" border="0" alt="Google" align="middle"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;input type="text" name="q" size="31" maxlength="255" value=""&gt;&lt;/input&gt;
&lt;input type="submit" name="sa" value="搜索"&gt;&lt;/input&gt;
&lt;input type="hidden" name="client" value="pub-5408663347953425"&gt;&lt;/input&gt;
&lt;input type="hidden" name="forid" value="1"&gt;&lt;/input&gt;
&lt;input type="hidden" name="ie" value="UTF-8"&gt;&lt;/input&gt;
&lt;input type="hidden" name="oe" value="UTF-8"&gt;&lt;/input&gt;
&lt;input type="hidden" name="cof" value="GALT:#008000;GL:1;DIV:#336699;VLC:663399;AH:center;BGC:FFFFFF;LBGC:336699;ALC:0000FF;LC:0000FF;T:000000;GFNT:0000FF;GIMP:0000FF;FORID:1;"&gt;&lt;/input&gt;
&lt;input type="hidden" name="hl" value="zh-CN"&gt;&lt;/input&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/form&gt;
&lt;/left&gt;
&lt;!-- Search Google --&gt;
</description><language>zh-cn</language><lastBuildDate>Tue, 27 Feb 2007 11:07:10 GMT</lastBuildDate><pubDate>Tue, 27 Feb 2007 11:07:10 GMT</pubDate><ttl>60</ttl><item><title>文件的所有操作 </title><link>http://www.blogjava.net/konhon/archive/2007/01/30/96782.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Tue, 30 Jan 2007 11:25:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2007/01/30/96782.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/96782.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2007/01/30/96782.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/96782.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/96782.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 2 /**   3  * //FileOperate.java  4  * 文件的各种操作  5  * 杨彩 http://blog.sina.com.cn/m/yangcai  6  * 文件操作 1.0  7  */   8    9 //package common;  10   11 import java.io.*;  12   13 public class FileOperate 1...&nbsp;&nbsp;<a href='http://www.blogjava.net/konhon/archive/2007/01/30/96782.html'>阅读全文</a><img src ="http://www.blogjava.net/konhon/aggbug/96782.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2007-01-30 19:25 <a href="http://www.blogjava.net/konhon/archive/2007/01/30/96782.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>[轉]prototype.js开发笔记</title><link>http://www.blogjava.net/konhon/archive/2006/07/13/58045.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Thu, 13 Jul 2006 11:53:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/07/13/58045.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/58045.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/07/13/58045.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/58045.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/58045.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 覆盖版本 1.3.1																																																								1. Prototype是什么?																																		或许你还没有用过它， prototype.js 是一个由Sam Stephenson写的JavaScript包。...&nbsp;&nbsp;<a href='http://www.blogjava.net/konhon/archive/2006/07/13/58045.html'>阅读全文</a><img src ="http://www.blogjava.net/konhon/aggbug/58045.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-07-13 19:53 <a href="http://www.blogjava.net/konhon/archive/2006/07/13/58045.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Java網站(轉)</title><link>http://www.blogjava.net/konhon/archive/2006/06/24/54915.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Sat, 24 Jun 2006 07:24:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/06/24/54915.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/54915.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/06/24/54915.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/54915.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/54915.html</trackback:ping><description><![CDATA[<div class="postcontent">
				<p>1.<a href="http://www.theserverside.com/"><font color="#366900">TheServerside.com</font></a>  依然是地位无可动摇的CCTV1。</p>
				<p>2.<a href="http://www.infoq.com/"><font color="#366900">InfoQ.com</font></a> Floyd Marinescu 在离开 TSS 后另起炉灶，2006年中最重要推荐。视野不再局限于Java 而是包括Java,.Net, Ruby ,SOA, Agile方法等热门话题。</p>
				<p>3.<a href="http://java.sys-con.com/"><font color="#366900">JDJ的电子杂志</font></a> 在JDJ首页的最底处订阅，文章质量不低于5-7的传统三强。</p>
				<p>4.<a href="http://www.swik.net/"><font color="#366900">SWik.net</font></a>  收集了大量OpenSource Project的资源聚合。其中如Spring，Hibernate的更新度非常高，出现什么和Spring有关的blog,article,project都会马上被聚合。</p>
				<p>5.<a href="http://www-128.ibm.com/developerworks/java/"><font color="#366900">IBM DeveloperWorks</font></a> 传统、稳定的Java文章来源地。</p>
				<p>6.<a href="http://www.javaworld.com/"><font color="#366900">JavaWorld</font></a> 传统、稳定的Java文章来源地。</p>
				<p>7.<a href="http://www.onjava.com/"><font color="#366900">OnJava</font></a>  传统、稳定的Java文章来源地。</p>
				<p>8.<a href="http://artima.com/"><font color="#366900">Artima.com</font></a> 类似于TSS而略逊，其中<a href="http://www.artima.com/spotlight/"><font color="#366900">Spotlight </font></a>文章值得关注，而<a href="http://www.artima.com/news/community.jsp?forum=136"><font color="#366900">Java News</font></a>是聚合了所有其他Java站点的大聚合。</p>
				<p>9.<a href="http://www.javalobby.org/"><font color="#366900">JavaLobby</font></a>  站内的<a href="http://www.javalobby.org/forumRSS/17.xml"><font color="#366900">Announcements</font></a> 是大大小小Java  Project的发布声明区，<a href="http://www.javalobby.org/forumRSS/18032.xml"><font color="#366900">Trips and Tricks</font></a> 有很多的Tips。</p>
				<p>10. <a href="http://www.nofluffjuststuff.com/blogs_summary.jsp"><font color="#366900">No Fluff Just Stuff 的Blogs 聚合</font></a> 一直缺一个所有优秀Java Blogger的rss总聚合，NFJS这里勉强算一个。</p>
		</div><img src ="http://www.blogjava.net/konhon/aggbug/54915.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-06-24 15:24 <a href="http://www.blogjava.net/konhon/archive/2006/06/24/54915.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>编码讨论---乱码问题之终极解决</title><link>http://www.blogjava.net/konhon/archive/2006/06/14/52624.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Wed, 14 Jun 2006 00:25:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/06/14/52624.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/52624.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/06/14/52624.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/52624.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/52624.html</trackback:ping><description><![CDATA[很多人 特别是新手 做j2ee 项目中<br />总能受困于 这样或那样的编码问题<br /><br />这里讨论下 新手学习，高手指教 一起研究下<br />(以 tomcat mysql 做例子 我推荐所有的编码采用utf-8)<br /><br />1 工程<br />工程内所有的 .java .jsp .xml .txt 都有默认的编码 默认的是系统环境的编码<br />我们中文系统通常是GBK 推荐都采用utf-8 <br />utf-8 的时候 你编译 生成doc 可能会遇到乱码（特别是采用ant 的时候,生成doc你几乎100%会遇到）<br /><br />解决方法 以ant 为例子<br />编译 注意 encoding 参数<br />&lt;target name="build" &gt;<br />       &lt;mkdir dir="${build.dir}" /&gt;<br />       &lt;javac encoding="utf-8" destdir="${build.dir}" target="1.3" debug="true" deprecation="false" optimize="false" failonerror="true"&gt;<br />           &lt;src path="${src.dir}" /&gt;<br />           &lt;classpath refid="master-classpath" /&gt;<br />       &lt;/javac&gt;<br />   &lt;/target&gt;<br /><br />生成doc 注意 encoding 和 charset<br />&lt;target name="doc"&gt;<br />&lt;mkdir dir="doc" /&gt;<br />&lt;javadoc charset="utf-8" encoding="utf-8" packagenames="${packages}" sourcepath="src" destdir="doc" author="true" version="true" use="true" splitindex="true" &gt;<br />&lt;classpath refid="master-classpath" /&gt;<br />&lt;/javadoc&gt;<br />&lt;/target&gt;<br /><br />这里 的encoding 就是指的你 java 文件的编码格式 javac 和javadoc 都有这个参数<br />charset 指的是 生成 doc 后的编码方式 javadoc 的参数<br /><br />2 数据库<br />mysql 的编码最复杂 从4以后 mysql 号称支持多编码 它更灵活了 我们也更麻烦了<br />mysql 有4个级别的编码 <br />系统级<br />库级<br />表级<br />sql语句级<br />请保持采用统一的编码 推荐utf-8<br />其它数据库要简单的多 一般都是一种编码<br /><br />3 web server <br />tomcat 为例<br />tomcat server.xml 中一个参数<br />&lt;Connectorport="8080" maxHttpHeaderSize="8192"<br />maxThreads="150" minSpareThreads="25" maxSpareThreads="75"<br />enableLookups="false" redirectPort="8443" acceptCount="100"<br />connectionTimeout="20000" disableUploadTimeout="true" URIncoding="utf-8"/&gt;<br />经测试 这个URIncoding 参数主要是 get 方法中采用编码<br /><br />4 jsp 显示层<br />第1条中说明了 jsp 文件本身的格式<br />很多朋友采用eclipse +myeclipse 生成jsp<br />它自动生成一个头&lt;%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%&gt;<br />不要误解 这句话不能保证你在ie里看到的不是乱码<br />pageEncoding它的意思是 这个页面本身采用的是 utf-8 (似乎只在eclipse 里有效果 ，我不确定)<br />为了在ie 里不乱码  你还得加一句 &lt;%@ page contentType="text/html; charset=UTF-8"%&gt;<br />它不能在(myeclispe)自动生成  推荐修改 myeclipse的模板 在下边的目录里<br />MyEclipse\eclipse\plugins\com.genuitec.eclipse.wizards_4.0.1\Templates<br />里边的jsp模版 你加上&lt;%@ page contentType="text/html; charset=${encoding}"%&gt;<br /><br />5 filter<br />自从tomcat 4 以后 网上就流传了一个SetCharacterEncodingFilter 过滤器 搜一下有很多<br />很好用 web.xml 中加入<br />&lt;filter&gt;<br /> &lt;filter-name&gt;Set Character Encoding&lt;/filter-name&gt;<br /> &lt;filter-class&gt;filters.SetCharacterEncodingFilter&lt;/filter-class&gt;<br /> &lt;init-param&gt;<br /> &lt;param-name&gt;encoding&lt;/param-name&gt;<br /> &lt;param-value&gt;utf-8&lt;/param-value&gt;<br /> &lt;/init-param&gt;<br />&lt;/filter&gt;<br /> &lt;filter-mapping&gt;<br /> &lt;filter-name&gt;Set Character Encoding&lt;/filter-name&gt;<br /> &lt;url-pattern&gt;/*&lt;/url-pattern&gt;<br /> &lt;/filter-mapping&gt;<br /><br />6 资源文件<br />首先保证 文件本身是utf-8<br />然后部署的时候用 native2ascii 转换 <br />这里给出 ant 里的例子<br />&lt;native2ascii encoding="utf-8" dest="${web.dir}/WEB-INF/classes" src="${src.dir}" includes="**/*.properties" /&gt;<br /><br />总结 <br />到这里 你应该彻底解决了乱码了 嘿嘿 <br />写的有点乱 还请高手们多指点 <br /><img src ="http://www.blogjava.net/konhon/aggbug/52624.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-06-14 08:25 <a href="http://www.blogjava.net/konhon/archive/2006/06/14/52624.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>论坛问题集锦</title><link>http://www.blogjava.net/konhon/archive/2006/03/24/37228.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Fri, 24 Mar 2006 07:39:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/24/37228.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/37228.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/24/37228.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/37228.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/37228.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 以下问题是这一期间回答waterlily 关于java的一些整理，发现对大家都很有作用，现在将这些详细讲解的程序单独列出来供大家参考，学习，讨论------------------------------------------------------------1.使用jdbc连接数据库--通过jdbc连接数据库，将SQL语句运行结果打印到控制台package Connect...&nbsp;&nbsp;<a href='http://www.blogjava.net/konhon/archive/2006/03/24/37228.html'>阅读全文</a><img src ="http://www.blogjava.net/konhon/aggbug/37228.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-24 15:39 <a href="http://www.blogjava.net/konhon/archive/2006/03/24/37228.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>全面解析JDBC(四)</title><link>http://www.blogjava.net/konhon/archive/2006/03/23/36985.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Thu, 23 Mar 2006 01:46:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/23/36985.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36985.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/23/36985.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36985.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36985.html</trackback:ping><description><![CDATA[<table height="726" cellspacing="0" cellpadding="2" width="100%" bgcolor="#cccccc" border="0">
				<tbody>
						<tr>
								<td class="title" style="WORD-BREAK: break-all" valign="center" align="middle" bgcolor="#ffffff" height="36">
										<strong>全面解析JDBC(四)</strong>
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="center" align="right" bgcolor="#ffffff" height="40">作者：未知     文章来源：<a href="http://www.jspcn.net/" target="_blank"><font color="#002c99">www.jspcn.net</font></a><br />访问次数： <iframe name="ad" src="../count.jsp?news_id=2815" frameborder="0" width="30" scrolling="no" height="10"></iframe>次    加入时间：2005-01-19</td>
						</tr>
						<tr>
								<td valign="top" align="left" bgcolor="#cccccc" height="2">
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="top" align="left" bgcolor="#ffffff" height="649">
										<table height="92%" cellspacing="0" cellpadding="6" width="100%" border="0">
												<tbody>
														<tr>
																<td class="content" valign="top" align="left" height="623">如何利用JDBC发送SQL语句？<br /><br />　　Statement对象用于将SQL语句发送到数据库中。实际上有三种Statement对象，它们都作为在给定连接上执行SQL语句的包容器：Statement、PreparedStatement（它从Statement继承而来）和CallableStatement（它从PreparedStatement继承而来）。它们都专用于发送特定类型的SQL语句：Statement对象用于执行不带参数的简单SQL语句；PreparedStatement对象用于执行带或不带IN参数的预编译SQL语句；CallableStatement对象用于执行对数据库已存储过程的调用。<br /><br />　　Statement接口提供了执行语句和获取结果的基本方法；PreparedStatement接口添加了处理IN参数的方法；而CallableStatement添加了处理OUT参数的方法。<br /><br />　　1. 创建Statement对象<br /><br />　　建立了到特定数据库的连接之后，就可用该连接发送SQL语句。Statement对象用Connection的方法createStatement创建，如下列代码段中所示：<br /><br />Connection con = DriverManager.getConnection（url，"sunny"，""）；<br />Statement stmt = con.createStatement（）；<br /><br /><br />　　为了执行Statement对象，被发送到数据库的SQL语句将被作为参数提供给Statement的方法：<br /><br />　　ResultSet rs = stmt.executeQuery（"SELECT a，b，c FROM Table2"）；<br /><br />　　2. 使用Statement对象执行语句<br /><br />　　Statement接口提供了三种执行SQL语句的方法：executeQuery、executeUpdate和execute。使用哪一个方法由SQL语句所产生的内容决定。<br /><br />　　方法executeQuery用于产生单个结果集的语句，例如SELECT语句。方法executeUpdate用于执行INSERT、UPDATE或DELETE语句以及SQL DDL（数据定义语言）语句，例如CREATE TABLE和DROP TABLE。INSERT、UPDATE或DELETE语句的效果是修改表中零行或多行中的一列或多列。executeUpdate的返回值是一个整数，指示受影响的行数（即更新计数）。对于CREATE TABLE或DROP TABLE等不操作行的语句，executeUpdate的返回值总为零。<br /><br />　　执行语句的所有方法都将关闭所调用的Statement对象的当前打开结果集（如果存在）。这意味着在重新执行Statement对象之前，需要完成对当前ResultSet对象的处理。应注意，继承了Statement接口中所有方法的PreparedStatement接口都有自己的executeQuery、executeUpdate和execute方法。Statement对象本身不包含SQL语句，因而必须给Statement.execute方法提供SQL语句作为参数。PreparedStatement对象并不需要SQL语句作为参数提供给这些方法，因为它们已经包含预编译SQL语句。<br /><br />　　CallableStatement对象继承这些方法的PreparedStatement形式。对于这些方法的PreparedStatement或CallableStatement版本，使用查询参数将抛出SQLException。<br /><br />　　3. 语句完成<br /><br />　　当连接处于自动提交模式时，其中所执行的语句在完成时将自动提交或还原。语句在已执行且所有结果返回时，即认为已完成。对于返回一个结果集的executeQuery方法，在检索完ResultSet对象的所有行时该语句完成。对于方法executeUpdate，当它执行时语句即完成。但在少数调用方法execute的情况中，在检索所有结果集或它生成的更新计数之后语句才完成。<br /><br />　　有些DBMS将已存储过程中的每条语句视为独立的语句；而另外一些则将整个过程视为一个复合语句。在启用自动提交时，这种差别就变得非常重要，因为它影响什么时候调用commit方法。在前一种情况中，每条语句单独提交；在后一种情况中，所有语句同时提交。<br /><br />　　4. 关闭Statement对象<br /><br />　　Statement对象将由Java垃圾收集程序自动关闭。而作为一种好的编程风格，应在不需要Statement对象时显式地关闭它们。这将立即释放DBMS资源，有助于避免潜在的内存问题。<br /><br />　　5. 使用方法execute<br /><br />　　execute方法应该仅在语句能返回多个ResultSet对象、多个更新计数或ResultSet对象与更新计数的组合时使用。当执行某个已存储过程或动态执行未知SQL字符串（即应用程序程序员在编译时未知）时，有可能出现多个结果的情况，尽管这种情况很少见。例如，用户可能执行一个已存储过程，并且该已存储过程可执行更新，然后执行选择，再进行更新，再进行选择，等等。通常使用已存储过程的人应知道它所返回的内容。<br /><br />　　因为方法execute处理非常规情况，所以获取其结果需要一些特殊处理并不足为怪。例如，假定已知某个过程返回两个结果集，则在使用方法execute执行该过程后，必须调用方法getResultSet获得第一个结果集，然后调用适当的getXXX方法获取其中的值。要获得第二个结果集，需要先调用getMoreResults方法，然后再调用getResultSet方法。如果已知某个过程返回两个更新计数，则首先调用方法getUpdateCount，然后调用getMoreResults，并再次调用getUpdateCount。<br /><br />　　对于不知道返回内容，则情况更为复杂。如果结果是ResultSet对象，则方法execute返回true；如果结果是Javaint，则返回false。如果返回int，则意味着结果是更新计数或执行的语句是DL命令。在调用方法execute之后要做的第一件事情是调用getResultSet或getUpdateCount。调用方法getResultSet可以获得两个或多个ResultSet对象中第一个对象；或调用方法getUpdateCount可以获得两个或多个更新计数中第一个更新计数的内容。<br /><br />　　当SQL语句的结果不是结果集时，则方法getResultSet将返回null。这可能意味着结果是一个更新计数或没有其它结果。在这种情况下，判断null真正含义的唯一方法是调用方法getUpdateCount，它将返回一个整数。这个整数为调用语句所影响的行数；如果为-1则表示结果是结果集或没有结果。如果方法getResultSet已返回null（表示结果不是ResultSet对象），则返回值-1表示没有其它结果。也就是说，当下列条件为真时表示没有结果（或没有其它结果）： <br /><br />　　（（stmt.getResultSet（）==null）&amp;&amp;（stmt.getUpdateCount（）==-1））<br /><br />　　如果已经调用方法getResultSet并处理了它返回的ResultSet对象，则有必要调用方法getMoreResults以确定是否有其它结果集或更新计数。如果getMoreResults返回true，则需要再次调用getResultSet来检索下一个结果集。如上所述，如果getResultSet返回null，则需要调用getUpdateCount来检查null是表示结果为更新计数还是表示没有其它结果。<br /><br />　　当getMoreResults返回false时，它表示该SQL语句返回一个更新计数或没有其它结果。因此需要调用方法getUpdateCount来检查它是哪一种情况。在这种情况下，当下列条件为真时表示没有其它结果：<br /><br />　　（（stmt.getMoreResults（）==false）&amp;&amp;（stmt.getUpdateCount（）==-1））<br /><br />　　下面的代码演示了一种方法用来确认已访问调用方法execute所产生的全部结果集和更新计数：<br /><br />stmt.execute（queryStringWithUnknownResults）；<br />while（true）{<br />introwCount=stmt.getUpdateCount（）；<br />if（rowCount＞0）{//它是更新计数<br />System.out.println（"Rows changed="+count）；<br />stmt.getMoreResults（）；<br />continue；<br />}<br />if（rowCount==0）{//DDL命令或0个更新<br />System.out.println（"No rows changed or statement was DDL command"）；<br />stmt.getMoreResults（）；<br />continue；<br />}<br />//执行到这里，证明有一个结果集<br />//或没有其它结果<br />ResultSet rs=stmt.getResultSet（）；<br />if（rs!=null）{<br />...//使用元数据获得关于结果集列的信息<br />while（rs.next（））{<br />...//处理结果<br />stmt.getMoreResults（）；<br />continue；<br />}<br />break；//没有其它结果 <br />　</td>
														</tr>
												</tbody>
										</table>
								</td>
						</tr>
				</tbody>
		</table><img src ="http://www.blogjava.net/konhon/aggbug/36985.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-23 09:46 <a href="http://www.blogjava.net/konhon/archive/2006/03/23/36985.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>全面解析JDBC(三)</title><link>http://www.blogjava.net/konhon/archive/2006/03/23/36984.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Thu, 23 Mar 2006 01:45:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/23/36984.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36984.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/23/36984.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36984.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36984.html</trackback:ping><description><![CDATA[<table height="726" cellspacing="0" cellpadding="2" width="100%" bgcolor="#cccccc" border="0">
				<tbody>
						<tr>
								<td class="title" style="WORD-BREAK: break-all" valign="center" align="middle" bgcolor="#ffffff" height="36">
										<strong>全面解析JDBC(三)</strong>
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="center" align="right" bgcolor="#ffffff" height="40">作者：未知     文章来源：<a href="http://www.jspcn.net/" target="_blank"><font color="#002c99">www.jspcn.net</font></a><br />访问次数： <iframe name="ad" src="../count.jsp?news_id=2814" frameborder="0" width="30" scrolling="no" height="10"></iframe>次    加入时间：2005-01-19</td>
						</tr>
						<tr>
								<td valign="top" align="left" bgcolor="#cccccc" height="2">
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="top" align="left" bgcolor="#ffffff" height="649">
										<table height="92%" cellspacing="0" cellpadding="6" width="100%" border="0">
												<tbody>
														<tr>
																<td class="content" valign="top" align="left" height="623">JDBC驱动管理内幕是怎么样的？<br /><br />　　DriverManager 类是 JDBC 的管理层，作用于用户和驱动程序之间。它跟踪可用的驱动程序，并在数据库和相应驱动程序之间建立连接。另外，DriverManager类也处理诸如驱动程序登录时间限制及登录和跟踪消息的显示等事务。 <br /><br />　　对于简单的应用程序，一般程序员需要在此类中直接使用的唯一方法是DriverManager.getConnection。正如名称所示，该方法将建立与数据库的连接。JDBC允许用户调用DriverManager的方法getDriver、getDrivers和registerDriver及Driver的方法connect。但多数情况下，让DriverManager类管理建立连接的细节为上策。<br /><br />　　1. 跟踪可用驱动程序<br /><br />　　DriverManager类包含一列Driver类，它们已通过调用方法DriverManager.registerDriver对自己进行了注册。所有Driver类都必须包含有一个静态部分。它创建该类的实例，然后在加载该实例时DriverManager类进行注册。这样，用户正常情况下将不会直接调用DriverManager.registerDriver；而是在加载驱动程序时由驱动程序自动调用。加载Driver类，然后自动在DriverManager中注册的方式有两种：<br /><br />　　（1）调用方法Class.forName<br /><br />　　这将显式地加载驱动程序类。由于这与外部设置无关，因此推荐使用这种加载驱动程序的方法。以下代码加载类acme.db.Driver：Class.forName（"acme.db.Driver"）。<br /><br />　　如果将acme.db.Driver编写为加载时创建实例，并调用以该实例为参数的DriverManager.registerDriver（本该如此），则它在DriverManager的驱动程序列表中，并可用于创建连接。<br /><br />　　（2）将驱动程序添加到Java.lang.System的属性jdbc.drivers中<br /><br />　　这是一个由DriverManager类加载的驱动程序类名的列表，由冒号分隔：初始化DriverManager类时，它搜索系统属性jdbc.drivers，如果用户已输入了一个或多个驱动程序，则DriverManager类将试图加载它们。以下代码说明程序员如何在~/.hotJava/properties中输入三个驱动程序类（启动时，HotJava将把它加载到系统属性列表中）：<br /><br />　　jdbc.drivers=foo.bah.Driver：wombat.sql.Driver：bad.test.ourDriver；<br /><br />　　对DriverManager方法的第一次调用将自动加载这些驱动程序类。注意：加载驱动程序的第二种方法需要持久的预设环境。如果对这一点不能保证，则调用方法Class.forName显式地加载每个驱动程序就显得更为安全。这也是引入特定驱动程序的方法，因为一旦DriverManager类被初始化，它将不再检查jdbc.drivers属性列表。<br /><br />　　在以上两种情况中，新加载的Driver类都要通过调用DriverManager.registerDriver类进行自我注册。如上所述，加载类时将自动执行这一过程。<br /><br />　　由于安全方面的原因，JDBC管理层将跟踪哪个类加载器提供哪个驱动程序。这样，当DriverManager类打开连接时，它仅使用本地文件系统或与发出连接请求的代码相同的类加载器提供的驱动程序。<br /><br />　　2. 建立连接<br /><br />　　加载Driver类并在DriverManager类中注册后，它们即可用来与数据库建立连接。当调用DriverManager.getConnection方法发出连接请求时，DriverManager将检查每个驱动程序，查看它是否可以建立连接。<br /><br />　　有时可能有多个JDBC驱动程序可以与给定的URL连接。例如，与给定远程数据库连接时，可以使用JDBC-ODBC桥驱动程序、JDBC到通用网络协议驱动程序或数据库厂商提供的驱动程序。在这种情况下测试驱动程序的顺序至关重要，因为DriverManager将使用它所找到的第一个可以成功连接到给定URL的驱动程序。<br /><br />　　首先DriverManager试图按注册的顺序使用每个驱动程序（jdbc.drivers中列出的驱动程序总是先注册）。它将跳过代码不可信任的驱动程序，除非加载它们的源与试图打开连接的代码的源相同。它通过轮流在每个驱动程序上调用方法Driver.connect，并向它们传递用户开始传递给方法DriverManager.getConnection的URL来对驱动程序进行测试，然后连接第一个认出该URL的驱动程序。这种方法初看起来效率不高，但由于不可能同时加载数十个驱动程序，因此每次连接实际只需几个过程调用和字符串比较。<br /><br />　　以下代码是通常情况下用驱动程序（例如JDBC-ODBC桥驱动程序）建立连接所需所有步骤的示例：<br /><br /><br /><br />Class.forName（"sun.jdbc.odbc.JdbcOdbcDriver"）；//加载驱动程序<br />String url = "jdbc：odbc：fred"；<br />DriverManager.getConnection（url，"userID"，"passwd"）； <br /></td>
														</tr>
												</tbody>
										</table>
								</td>
						</tr>
				</tbody>
		</table><img src ="http://www.blogjava.net/konhon/aggbug/36984.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-23 09:45 <a href="http://www.blogjava.net/konhon/archive/2006/03/23/36984.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>全面解析JDBC(一)</title><link>http://www.blogjava.net/konhon/archive/2006/03/23/36982.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Thu, 23 Mar 2006 01:44:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/23/36982.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36982.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/23/36982.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36982.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36982.html</trackback:ping><description><![CDATA[<table height="726" cellspacing="0" cellpadding="2" width="100%" bgcolor="#cccccc" border="0">
				<tbody>
						<tr>
								<td class="title" style="WORD-BREAK: break-all" valign="center" align="middle" bgcolor="#ffffff" height="36">
										<strong>全面解析JDBC(一)</strong>
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="center" align="right" bgcolor="#ffffff" height="40">作者：未知     文章来源：<a href="http://www.jspcn.net/" target="_blank">www.jspcn.net</a><br />访问次数： <iframe name="ad" src="../count.jsp?news_id=2812" frameborder="0" width="30" scrolling="no" height="10"></iframe>次    加入时间：2005-01-19</td>
						</tr>
						<tr>
								<td valign="top" align="left" bgcolor="#cccccc" height="2">
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="top" align="left" bgcolor="#ffffff" height="649">
										<table height="92%" cellspacing="0" cellpadding="6" width="100%" border="0">
												<tbody>
														<tr>
																<td class="content" valign="top" align="left" height="623">综述：Java数据库连接体系结构是用于Java应用程序连接数据库的标准方法。JDBC对Java程序员而言是API，对实现与数据库连接的服务提供商而言是接口模型。作为API，JDBC为程序开发提供标准的接口，并为数据库厂商及第三方中间件厂商实现与数据库的连接提供了标准方法。JDBC使用已有的SQL标准并支持与其它数据库连接标准，如ODBC之间的桥接。JDBC实现了所有这些面向标准的目标并且具有简单、严格类型定义且高性能实现的接口。<br /><br />　　如何选择合适的JDBC产品？<br /><br />　　有关JDBC最新的信息，有兴趣的读者可以查阅JDBC的官方网站--即JavaSoft的主页，其URL为：http：//Java.sun.com/products/jdbc<br /><br />　　1. JavaSoft框架<br /><br />　　JavaSoft提供三种JDBC产品组件，它们是Java开发工具包（JDK）的组成部份：JDBC驱动程序管理器、JDBC驱动程序测试工具包和JDBC-ODBC桥。<br /><br />　　JDBC驱动程序管理器是JDBC体系结构的支柱。它实际上很小，也很简单；其主要作用是把Java应用程序连接到正确的JDBC驱动程序上，然后即退出。<br /><br />　　JDBC驱动程序测试工具包为使JDBC驱动程序运行您的程序提供一定的可信度。只有通过JDBC驱动程序测试的驱动程序才被认为是符合JDBC标准TM的。<br /><br />　　JDBC-ODBC桥使ODBC驱动程序可被用作JDBC驱动程序。它的实现为JDBC的快速发展提供了一条途径，其长远目标提供一种访问某些不常见的DBMS（如果对这些不常见的DBMS未实现JDBC）的方法。<br /><br />　　2. JDBC驱动程序的类型<br /><br />　　目前比较常见的JDBC驱动程序可分为以下四个种类：<br /><br />　　（1）JDBC-ODBC桥加ODBC驱动程序<br /><br />　　JavaSoft桥产品利用ODBC驱动程序提供JDBC访问。注意，必须将ODBC二进制代码（许多情况下还包括数据库客户机代码）加载到使用该驱动程序的每个客户机上。因此，这种类型的驱动程序最适合于企业网（这种网络上客户机的安装不是主要问题），或者是用Java编写的三层结构的应用程序服务器代码。<br /><br />　　（2）本地API<br /><br />　　这种类型的驱动程序把客户机API上的JDBC调用转换为Oracle、Sybase、Informix、DB2或其它DBMS的调用。注意，象桥驱动程序一样，这种类型的驱动程序要求将某些二进制代码加载到每台客户机上。<br /><br />　　（3）JDBC网络纯Java驱动程序<br /><br />　　这种驱动程序将JDBC转换为与DBMS无关的网络协议，之后这种协议又被某个服务器转换为一种DBMS协议。这种网络服务器中间件能够将它的纯Java客户机连接到多种不同的数据库上。所用的具体协议取决于提供者。通常，这是最为灵活的JDBC驱动程序。有可能所有这种解决方案的提供者都提供适合于Intranet用的产品。为了使这些产品也支持Internet访问，它们必须处理Web所提出的安全性、通过防火墙的访问等方面的额外要求。几家提供者正将JDBC驱动程序加到他们现有的数据库中间件产品中。<br /><br />　　（4）本地协议纯Java驱动程序<br /><br />　　这种类型的驱动程序将JDBC调用直接转换为DBMS所使用的网络协议。这将允许从客户机机器上直接调用DBMS服务器，是Intranet访问的一个很实用的解决方法。由于许多这样的协议都是专用的，因此数据库提供者自己将是主要来源，有几家提供者已在着手做这件事了。<br /><br />　　据专家预计第（3）、（4）类驱动程序将成为从JDBC访问数据库的首方法。第（1）、（2）类驱动程序在直接的纯Java驱动程序还没有上市前会作为过渡方案来使用。对第（1）、（2）类驱动程序可能会有一些变种，这些变种要求有连接器，但通常这些是更加不可取的解决方案。第（3）、（4）类驱动程序提供了Java的所有优点，包括自动安装（例如，通过使用JDBC驱动程序的appletapplet来下载该驱动程序）。<br /><br />　　3. JDBC驱动程序的获取<br /><br /><br /><br />　　目前已有几十个（1）类的驱动程序，即可与Javasoft桥联合使用的ODBC驱动程序的驱动程序。有大约十多个属于种类（2）的驱动程序是以DBMS的本地API为基础编写的。只有几个属于种类（3）的驱动程序，其首批提供者是SCO、OpenHorizon、Visigenic和WebLogic。此外，JavaSoft和数据库连接的领先提供者Intersolv还合作研制了JDBC-ODBC桥和JDBC驱动程序测试工具包。<br /></td>
														</tr>
												</tbody>
										</table>
								</td>
						</tr>
				</tbody>
		</table><img src ="http://www.blogjava.net/konhon/aggbug/36982.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-23 09:44 <a href="http://www.blogjava.net/konhon/archive/2006/03/23/36982.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>全面解析JDBC(二)</title><link>http://www.blogjava.net/konhon/archive/2006/03/23/36983.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Thu, 23 Mar 2006 01:44:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/23/36983.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36983.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/23/36983.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36983.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36983.html</trackback:ping><description><![CDATA[<table height="726" cellspacing="0" cellpadding="2" width="100%" bgcolor="#cccccc" border="0">
				<tbody>
						<tr>
								<td class="title" style="WORD-BREAK: break-all" valign="center" align="middle" bgcolor="#ffffff" height="36">
										<strong>全面解析JDBC(二)</strong>
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="center" align="right" bgcolor="#ffffff" height="40">作者：未知     文章来源：<a href="http://www.jspcn.net/" target="_blank"><font color="#002c99">www.jspcn.net</font></a><br />访问次数： <iframe name="ad" src="../count.jsp?news_id=2813" frameborder="0" width="30" scrolling="no" height="10"></iframe>次    加入时间：2005-01-19</td>
						</tr>
						<tr>
								<td valign="top" align="left" bgcolor="#cccccc" height="2">
								</td>
						</tr>
						<tr>
								<td style="WORD-BREAK: break-all" valign="top" align="left" bgcolor="#ffffff" height="649">
										<table height="92%" cellspacing="0" cellpadding="6" width="100%" border="0">
												<tbody>
														<tr>
																<td class="content" valign="top" align="left" height="623">如何建立JDBC连接？<br /><br />　　Connection 对象代表与数据库的连接。连接过程包括所执行的 SQL 语句和在该连接上所返回的结果。一个应用程序可与单个数据库有一个或多个连接，或者可与许多数据库有连接。<br /><br />　　1. 打开连接<br /><br />　　与数据库建立连接的标准方法是调用DriverManager.getConnection方法。该方法接受含有某个URL的字符串。DriverManager类（即所谓的JDBC管理层）将尝试找到可与那个URL所代表的数据库进行连接的驱动程序。DriverManager类存有已注册的Driver类的清单。当调用方法getConnection时，它将检查清单中的每个驱动程序，直到找到可与URL中指定的数据库进行连接的驱动程序为止。Driver的方法connect使用这个URL来建立实际的连接。<br /><br />　　用户可绕过JDBC管理层直接调用Driver方法。这在以下特殊情况下将很有用：当两个驱动器可同时连接到数据库中，而用户需要明确地选用其中特定的驱动器。但一般情况下，让DriverManager类处理打开连接这种事将更为简单。<br /><br />　　下述代码显示如何打开一个与位于URL"jdbc：odbc：wombat"的数据库的连接。所用的用户标识符为"freely"，口令为"ec"：<br /><br />　　String url = "jdbc：odbc：wombat"；<br />　　Connection con = DriverManager.getConnection（url， "freely"， "ec"）；<br /><br />　　2. 一般用法的URL<br /><br />　　由于URL常引起混淆，我们将先对一般URL作简单说明，然后再讨论JDBCURL。URL（统一资源定位符）提供在Internet上定位资源所需的信息。可将它想象为一个地址。URL的第一部份指定了访问信息所用的协议，后面总是跟着冒号。常用的协议有"ftp"（代表"文件传输协议"）和"http"（代表"超文本传输协议"）。如果协议是"file"，表示资源是在某个本地文件系统上而非在Internet上（下例用于表示我们所描述的部分；它并非URL的组成部分）。<br /><br />　　ftp：//Javasoft.com/docs/JDK-1_apidocs.zip<br />　　http：//Java.sun.com/products/jdk/CurrentRelease<br />　　file：/home/haroldw/docs/books/tutorial/summary.html<br /><br />　　URL的其余部份（冒号后面的）给出了数据资源所处位置的有关信息。如果协议是file，则URL的其余部份是文件的路径。对于ftp和http协议，URL的其余部份标识了主机并可选地给出某个更详尽的地址路径。例如，以下是JavaSoft主页的URL。该URL只标识了主机：http：//Java.sun.com。从该主页开始浏览，就可以进到许多其它的网页中，其中之一就是JDBC主页。JDBC主页的URL更为具体，它具体表示为：<br />http：//Java.sun.com/products/jdbc<br /><br />　　3. JDBC URL<br /><br />　　JDBC URL提供了一种标识数据库的方法，可以使相应的驱动程序能识别该数据库并与之建立连接。实际上，驱动程序编程员将决定用什么JDBC URL来标识特定的驱动程序。用户不必关心如何来形成JDBC URL；他们只须使用与所用的驱动程序一起提供的URL即可。JDBC的作用是提供某些约定，驱动程序编程员在构造他们的JDBC URL时应该遵循这些约定。<br /><br />　　由于JDBC URL要与各种不同的驱动程序一起使用，因此这些约定应非常灵活。首先，它们应允许不同的驱动程序使用不同的方案来命名数据库。例如，odbc子协议允许（但并不是要求）URL含有属性值。 <br /><br />　　其次，JDBC URL应允许驱动程序编程员将一切所需的信息编入其中。这样就可以让要与给定数据库对话的applet打开数据库连接，而无须要求用户去做任何系统管理工作。<br /><br />　　最后，JDBC URL应允许某种程度的间接性。也就是说，JDBC URL可指向逻辑主机或数据库名，而这种逻辑主机或数据库名将由网络命名系统动态地转换为实际的名称。这可以使系统管理员不必将特定主机声明为JDBC名称的一部份。网络命名服务（例如DNS、NIS和DCE）有多种，而对于使用哪种命名服务并无限制。<br />JDBC URL的标准语法如下所示。它由三部分组成，各部分间用冒号分隔：<br />jdbc：＜子协遥荆海甲用?称??br&gt; 　　JDBC URL的三个部分可分解如下：<br /><br />　　（1）jdbc协议：JDBC URL中的协议总是jdbc。<br /><br />　　（2）＜子协议＞：驱动程序名或数据库连接机制（这种机制可由一个或多个驱动程序支持）的名称。子协议名的典型示例是"odbc"，该名称是为用于指定ODBC风格的数据资源名称的URL专门保留的。例如，为了通过JDBC-ODBC桥来访问某个数据库，可以用如下所示的URL：jdbc：odbc：book。本例中，子协议为"odbc"，子名称"book"是本地ODBC数据资源。如果要用网络命名服务（这样JDBC URL中的数据库名称不必是实际名称），则命名服务可以作为子协议。例如，可用如下所示的URL：jdbc：dcenaming：accounts。本例中，该URL指定了本地DCE命名服务应该将数据库名称"accounts"解析为更为具体的可用于连接真实数据库的名称。<br /><br />　　（3）＜子名称＞：种标识数据库的方法。子名称可以依不同的子协议而变化。它还可以有子名称的子名称（含有驱动程序编程员所选的任何内部语法）。使用子名称的目的是为定位数据库提供足够的信息。前例中，因为ODBC将提供其余部份的信息，因此用"book"就已足够。然而，位于远程服务器上的数据库需要更多的信息。例如，如果数据库是通过Internet来访问的，则在JDBC URL中应将网络地址作为子名称的一部份包括进去，且必须遵循如下所示的标准URL命名约定：//主机名：端口/子协议。<br /><br />　　假设"dbnet"是个用于将某个主机连接到Internet上的协议，则JDBC URL应为：jdbc：dbnet：//wombat：356/fred。<br /><br />　　4. "odbc"子协议<br /><br />　　子协议odbc是一种特殊情况。它是为用于指定ODBC风格的数据资源名称的URL而保留的，并具有下列特性：允许在子名称（数据资源名称）后面指定任意多个属性值。odbc子协议的完整语法为：<br /><br />　　jdbc：odbc：＜数据资源名称＞[；＜属性名＞=＜属性值＞]，因此，以下都是合法的jdbc：odbc名称：<br />　　jdbc：odbc：qeor7<br />　　jdbc：odbc：wombat<br />　　jdbc：odbc：wombat；CacheSize=20；ExtensionCase=LOWER<br />　　jdbc：odbc：qeora；UID=kgh；PWD=fooey<br /><br />　　5. 注册子协议<br /><br />　　驱动程序编程员可保留某个名称以将之用作JDBC URL的子协议名。当DriverManager类将此名称加到已注册的驱动程序清单中时，为之保留该名称的驱动程序应能识别该名称并与它所标识的数据库建立连接。例如，odbc是为JDBC-ODBC桥而保留的。假设有个Miracle公司，它可能会将"miracle"注册为连接到其Miracle DBMS上的JDBC驱动程序的子协议，从而使其他人都无法使用这个名称。<br /><br />　　JavaSoft目前作为非正式代理负责注册JDBC子协议名称。要注册某个子协议名称，请发送电子邮件到下述地址：jdbc@wombat.eng.sun.com。<br /><br />　　6. 发送SQL语句<br /><br />　　连接一旦建立，就可用来向它所涉及的数据库传送SQL语句。JDBC对可被发送的SQL语句类型不加任何限制。这就提供了很大的灵活性，即允许使用特定的数据库语句或甚至于非SQL语句。然而，它要求用户自己负责确保所涉及的数据库可以处理所发送的SQL语句，否则将自食其果。例如，如果某个应用程序试图向不支持储存程序的DBMS发送储存程序调用，就会失败并将抛出异常。JDBC要求驱动程序应至少能提供ANSI SQL-2 Entry Level功能才可算是符合JDBC标准TM的。这意味着用户至少可信赖这一标准级别的功能。<br /><br />　　JDBC提供了三个类，用于向数据库发送SQL语句。Connection接口中的三个方法可用于创建这些类的实例。下面列出这些类及其创建方法：<br /><br />　　（1）Statement：由方法createStatement所创建。Statement对象用于发送简单的SQL语句。<br /><br />　　（2）PreparedStatement：由方法prepareStatement所创建。PreparedStatement对象用于发送带有一个或多个输入参数（IN参数）的SQL语句。PreparedStatement拥有一组方法，用于设置IN参数的值。执行语句时，这些IN参数将被送到数据库中。PreparedStatement的实例扩展了Statement，因此它们都包括了Statement的方法。PreparedStatement对象有可能比Statement对象的效率更高，因为它已被预编译过并存放在那以供将来使用。<br /><br />　　（3）CallableStatement：由方法prepareCall所创建。CallableStatement对象用于执行SQL储存程序─一组可通过名称来调用（就象函数的调用那样）的SQL语句。CallableStatement对象从PreparedStatement中继承了用于处理IN参数的方法，而且还增加了用于处理OUT参数和INOUT参数的方法。<br /><br />　　不过通常来说createStatement方法用于简单的SQL语句（不带参数）、prepareStatement方法用于带一个或多个IN参数的SQL语句或经常被执行的简单SQL语句，而prepareCall方法用于调用已储存过程。 <br /><br />　　7. 事务<br /><br />　　事务由一个或多个这样的语句组成：这些语句已被执行、完成并被提交或还原。当调用方法commit或rollback时，当前事务即告就结束，另一个事务随即开始。缺省情况下，新连接将处于自动提交模式。也就是说，当执行完语句后，将自动对那个语句调用commit方法。这种情况下，由于每个语句都是被单独提交的，因此一个事务只由一个语句组成。如果禁用自动提交模式，事务将要等到commit或rollback方法被显式调用时才结束，因此它将包括上一次调用commit或rollback方法以来所有执行过的语句。对于第二种情况，事务中的所有语句将作为组来提交或还原。<br /><br />　　方法commit使SQL语句对数据库所做的任何更改成为永久性的，它还将释放事务持有的全部锁。而方法rollback将弃去那些更改。有时用户在另一个更改生效前不想让此更改生效。这可通过禁用自动提交并将两个更新组合在一个事务中来达到。如果两个更新都是成功，则调用commit方法，从而使两个更新结果成为永久性的；如果其中之一或两个更新都失败了，则调用rollback方法，以将值恢复为进行更新之前的值。<br /><br />　　大多数JDBC驱动程序都支持事务。事实上，符合JDBC的驱动程序必须支持事务。DatabaseMetaData给出的信息描述DBMS所提供的事务支持水平。<br /><br />　　8. 事务隔离级别<br /><br />　　如果DBMS支持事务处理，它必须有某种途径来管理两个事务同时对一个数据库进行操作时可能发生的冲突。用户可指定事务隔离级别，以指明DBMS应该花多大精力来解决潜在冲突。例如，当事务更改了某个值而第二个事务却在该更改被提交或还原前读取该值时该怎么办。<br /><br />　　假设第一个事务被还原后，第二个事务所读取的更改值将是无效的，那么是否可允许这种冲突？JDBC用户可用以下代码来指示DBMS允许在值被提交前读取该值（"dirty读取"），其中con是当前连接：<br />con.setTransactionIsolation（TRANSACTION_READ_UNCOMMITTED）；<br /><br />　　事务隔离级别越高，为避免冲突所花的精力也就越多。Connection接口定义了五级，其中最低级别指定了根本就不支持事务，而最高级别则指定当事务在对某个数据库进行操作时，任何其它事务不得对那个事务正在读取的数据进行任何更改。通常，隔离级别越高，应用程序执行的速度也就越慢（由于用于锁定的资源耗费增加了，而用户间的并发操作减少了）。在决定采用什么隔离级别时，开发人员必须在性能需求和数据一致性需求之间进行权衡。当然，实际所能支持的级别取决于所涉及的DBMS的功能。<br /><br />　　当创建Connection对象时，其事务隔离级别取决于驱动程序，但通常是所涉及的数据库的缺省值。用户可通过调用setIsolationLevel方法来更改事务隔离级别。新的级别将在该连接过程的剩余时间内生效。要想只改变一个事务的事务隔离级别，必须在该事务开始前进行设置，并在该事务结束后进行复位。我们不提倡在事务的中途对事务隔离级别进行更改，因为这将立即触发commit方法的调用，使在此之前所作的任何更改变成永久性的。</td>
														</tr>
												</tbody>
										</table>
								</td>
						</tr>
				</tbody>
		</table><img src ="http://www.blogjava.net/konhon/aggbug/36983.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-23 09:44 <a href="http://www.blogjava.net/konhon/archive/2006/03/23/36983.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>数据库乱码解决方案</title><link>http://www.blogjava.net/konhon/archive/2006/03/23/36961.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Thu, 23 Mar 2006 00:06:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/23/36961.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36961.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/23/36961.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36961.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36961.html</trackback:ping><description><![CDATA[<div style="BORDER-RIGHT: #cccccc 1px solid; PADDING-RIGHT: 5px; BORDER-TOP: #cccccc 1px solid; PADDING-LEFT: 4px; FONT-SIZE: 13px; PADDING-BOTTOM: 4px; BORDER-LEFT: #cccccc 1px solid; WIDTH: 98%; WORD-BREAK: break-all; PADDING-TOP: 4px; BORDER-BOTTOM: #cccccc 1px solid; BACKGROUND-COLOR: #eeeeee">
				<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top" />
				<span style="COLOR: #000000">你插入数据的时候，用<br /><img id="Codehighlighter1_11_52_Open_Image" onclick="this.style.display='none'; Codehighlighter1_11_52_Open_Text.style.display='none'; Codehighlighter1_11_52_Closed_Image.style.display='inline'; Codehighlighter1_11_52_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top" /><img id="Codehighlighter1_11_52_Closed_Image" style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_11_52_Closed_Text.style.display='none'; Codehighlighter1_11_52_Open_Image.style.display='inline'; Codehighlighter1_11_52_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top" /></span>
				<span id="Codehighlighter1_11_52_Closed_Text" style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff">/** */</span>
				<span id="Codehighlighter1_11_52_Open_Text">
						<span style="COLOR: #008000">/**</span>
						<span style="COLOR: #008000">
								<br />
								<img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" />* 转变字符串的乱码函数<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" />* </span>
						<span style="COLOR: #808080">@param</span>
						<span style="COLOR: #008000"> str<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" />* </span>
						<span style="COLOR: #808080">@return</span>
						<span style="COLOR: #008000">
								<br />
								<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top" />
						</span>
						<span style="COLOR: #008000">*/</span>
				</span>
				<span style="COLOR: #000000">
						<br />
						<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top" />
				</span>
				<span style="COLOR: #0000ff">public</span>
				<span style="COLOR: #000000"> String getStr(String str)<br /><img id="Codehighlighter1_87_248_Open_Image" onclick="this.style.display='none'; Codehighlighter1_87_248_Open_Text.style.display='none'; Codehighlighter1_87_248_Closed_Image.style.display='inline'; Codehighlighter1_87_248_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top" /><img id="Codehighlighter1_87_248_Closed_Image" style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_87_248_Closed_Text.style.display='none'; Codehighlighter1_87_248_Open_Image.style.display='inline'; Codehighlighter1_87_248_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top" /></span>
				<span id="Codehighlighter1_87_248_Closed_Text" style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff">
						<img src="http://www.blogjava.net/images/dot.gif" />
				</span>
				<span id="Codehighlighter1_87_248_Open_Text">
						<span style="COLOR: #000000">{<br /><img id="Codehighlighter1_92_209_Open_Image" onclick="this.style.display='none'; Codehighlighter1_92_209_Open_Text.style.display='none'; Codehighlighter1_92_209_Closed_Image.style.display='inline'; Codehighlighter1_92_209_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top" /><img id="Codehighlighter1_92_209_Closed_Image" style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_92_209_Closed_Text.style.display='none'; Codehighlighter1_92_209_Open_Image.style.display='inline'; Codehighlighter1_92_209_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top" /></span>
						<span style="COLOR: #0000ff">try</span>
						<span id="Codehighlighter1_92_209_Closed_Text" style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff">
								<img src="http://www.blogjava.net/images/dot.gif" />
						</span>
						<span id="Codehighlighter1_92_209_Open_Text">
								<span style="COLOR: #000000">{<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" />String temp_p </span>
								<span style="COLOR: #000000">=</span>
								<span style="COLOR: #000000"> str;<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" /></span>
								<span style="COLOR: #0000ff">byte</span>
								<span style="COLOR: #000000"> [] temp_t </span>
								<span style="COLOR: #000000">=</span>
								<span style="COLOR: #000000"> temp_p.getBytes(</span>
								<span style="COLOR: #000000">"</span>
								<span style="COLOR: #000000">ISO8859-1</span>
								<span style="COLOR: #000000">"</span>
								<span style="COLOR: #000000">);<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" />String temp </span>
								<span style="COLOR: #000000">=</span>
								<span style="COLOR: #000000"> </span>
								<span style="COLOR: #0000ff">new</span>
								<span style="COLOR: #000000"> String(temp_t);<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" /></span>
								<span style="COLOR: #0000ff">return</span>
								<span style="COLOR: #000000"> temp;<br /><img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top" />}</span>
						</span>
						<span style="COLOR: #000000">
								<br />
								<img id="Codehighlighter1_229_246_Open_Image" onclick="this.style.display='none'; Codehighlighter1_229_246_Open_Text.style.display='none'; Codehighlighter1_229_246_Closed_Image.style.display='inline'; Codehighlighter1_229_246_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align="top" />
								<img id="Codehighlighter1_229_246_Closed_Image" style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_229_246_Closed_Text.style.display='none'; Codehighlighter1_229_246_Open_Image.style.display='inline'; Codehighlighter1_229_246_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align="top" />
						</span>
						<span style="COLOR: #0000ff">catch</span>
						<span style="COLOR: #000000">(Exception e)</span>
						<span id="Codehighlighter1_229_246_Closed_Text" style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff">
								<img src="http://www.blogjava.net/images/dot.gif" />
						</span>
						<span id="Codehighlighter1_229_246_Open_Text">
								<span style="COLOR: #000000">{<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" /></span>
								<span style="COLOR: #0000ff">return</span>
								<span style="COLOR: #000000"> </span>
								<span style="COLOR: #000000">"</span>
								<span style="COLOR: #000000">null</span>
								<span style="COLOR: #000000">"</span>
								<span style="COLOR: #000000">;<br /><img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align="top" />}</span>
						</span>
						<span style="COLOR: #000000">
								<br />
								<img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top" />}</span>
				</span>
				<span style="COLOR: #000000"> <br /><img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top" /></span>
				<span style="COLOR: #008000">//</span>
				<span style="COLOR: #008000">向bean里面赋值</span>
				<span style="COLOR: #008000">
						<br />
						<img id="Codehighlighter1_300_332_Open_Image" onclick="this.style.display='none'; Codehighlighter1_300_332_Open_Text.style.display='none'; Codehighlighter1_300_332_Closed_Image.style.display='inline'; Codehighlighter1_300_332_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top" />
						<img id="Codehighlighter1_300_332_Closed_Image" style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_300_332_Closed_Text.style.display='none'; Codehighlighter1_300_332_Open_Image.style.display='inline'; Codehighlighter1_300_332_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top" />
				</span>
				<span style="COLOR: #0000ff">public</span>
				<span style="COLOR: #000000"> </span>
				<span style="COLOR: #0000ff">void</span>
				<span style="COLOR: #000000"> setAction(String action) </span>
				<span id="Codehighlighter1_300_332_Closed_Text" style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff">
						<img src="http://www.blogjava.net/images/dot.gif" />
				</span>
				<span id="Codehighlighter1_300_332_Open_Text">
						<span style="COLOR: #000000">{<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" /></span>
						<span style="COLOR: #0000ff">this</span>
						<span style="COLOR: #000000">.action </span>
						<span style="COLOR: #000000">=</span>
						<span style="COLOR: #000000"> getStr(action);<br /><img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top" />}</span>
				</span>
				<span style="COLOR: #000000">
						<br />
						<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top" />
						<br />
						<img id="Codehighlighter1_384_428_Open_Image" onclick="this.style.display='none'; Codehighlighter1_384_428_Open_Text.style.display='none'; Codehighlighter1_384_428_Closed_Image.style.display='inline'; Codehighlighter1_384_428_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align="top" />
						<img id="Codehighlighter1_384_428_Closed_Image" style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_384_428_Closed_Text.style.display='none'; Codehighlighter1_384_428_Open_Image.style.display='inline'; Codehighlighter1_384_428_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align="top" />
				</span>
				<span style="COLOR: #0000ff">public</span>
				<span style="COLOR: #000000"> </span>
				<span style="COLOR: #0000ff">void</span>
				<span style="COLOR: #000000"> setAddmanagerid(String addmanagerid) </span>
				<span id="Codehighlighter1_384_428_Closed_Text" style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff">
						<img src="http://www.blogjava.net/images/dot.gif" />
				</span>
				<span id="Codehighlighter1_384_428_Open_Text">
						<span style="COLOR: #000000">{<br /><img src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align="top" /></span>
						<span style="COLOR: #0000ff">this</span>
						<span style="COLOR: #000000">.addmanagerid </span>
						<span style="COLOR: #000000">=</span>
						<span style="COLOR: #000000"> getStr(addmanagerid);<br /><img src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockEnd.gif" align="top" />}</span>
				</span>
				<span style="COLOR: #000000">
						<br />
						<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top" />
						<br />
						<img src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align="top" />转换一下，看看可以吗，我的数据库是ORACLE没问题。</span>
		</div><img src ="http://www.blogjava.net/konhon/aggbug/36961.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-23 08:06 <a href="http://www.blogjava.net/konhon/archive/2006/03/23/36961.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Java编程电子书籍下载 </title><link>http://www.blogjava.net/konhon/archive/2006/03/21/36685.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Tue, 21 Mar 2006 12:27:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/21/36685.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36685.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/21/36685.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36685.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36685.html</trackback:ping><description><![CDATA[<span class="content">Java编程电子书籍下载<br /><br /><br />环境安装配置：<br /><br />TOMCAT的配置<br /><a href="http://download.chinaitlab.com/soft/10791.htm" target="_blank">http://download.chinaitlab.com/soft/10791.htm</a><br /><br />JAVA配置文件编写说明文档<br /><a href="http://download.chinaitlab.com/soft/10010.htm" target="_blank">http://download.chinaitlab.com/soft/10010.htm</a><br /><br />一步一步学会配置Kjava开发环境<br /><a href="http://download.chinaitlab.com/soft/9483.htm" target="_blank">http://download.chinaitlab.com/soft/9483.htm</a><br /><br />Weblogic7开发EJB的配置<br /><a href="http://download.chinaitlab.com/soft/4938.htm" target="_blank">http://download.chinaitlab.com/soft/4938.htm</a><br /><br />图解JSP环境安装配置<br /><a href="http://download.chinaitlab.com/soft/2157.htm" target="_blank">http://download.chinaitlab.com/soft/2157.htm</a><br /><br />Tomcat配置方法<br /><a href="http://download.chinaitlab.com/soft/931.htm" target="_blank">http://download.chinaitlab.com/soft/931.htm</a><br /><br />全程指导Linux下JAVA环境配置<br /><a href="http://download.chinaitlab.com/soft/11272.htm" target="_blank">http://download.chinaitlab.com/soft/11272.htm</a><br /><br />学习方法：<br /><br />通过JB4学习JAVA<br /><a href="http://download.chinaitlab.com/soft/7589.htm" target="_blank">http://download.chinaitlab.com/soft/7589.htm</a><br /><br />10步学习 JavaScript<br /><a href="http://download.chinaitlab.com/soft/6492.htm" target="_blank">http://download.chinaitlab.com/soft/6492.htm</a><br /><br /><a title="Java" href="http://www.blogjava.net/konhon/category/3016.html" target="_blank">Java</a> Sctipt学习不求人<br /><a href="http://download.chinaitlab.com/soft/6361.htm" target="_blank">http://download.chinaitlab.com/soft/6361.htm</a><br /><br />JSP学习指南<br /><a href="http://download.chinaitlab.com/soft/6152.htm" target="_blank">http://download.chinaitlab.com/soft/6152.htm</a><br /><br />JAVA学习文档<br /><a href="http://download.chinaitlab.com/soft/6114.htm" target="_blank">http://download.chinaitlab.com/soft/6114.htm</a><br /><br />J2EE学习笔记<br /><a href="http://download.chinaitlab.com/soft/6048.htm" target="_blank">http://download.chinaitlab.com/soft/6048.htm</a><br /><br />JavaScript学习<br /><a href="http://download.chinaitlab.com/soft/3029.htm" target="_blank">http://download.chinaitlab.com/soft/3029.htm</a><br /><br />Java2 学习指南<br /><a href="http://download.chinaitlab.com/soft/2743.htm" target="_blank">http://download.chinaitlab.com/soft/2743.htm</a><br /><br />Juniper学习指南<br /><a href="http://download.chinaitlab.com/soft/2227.htm" target="_blank">http://download.chinaitlab.com/soft/2227.htm</a><br /><br />J2EE学习资料<br /><a href="http://download.chinaitlab.com/soft/1618.htm" target="_blank">http://download.chinaitlab.com/soft/1618.htm</a><br /><br />JSP由浅入深<br /><a href="http://download.chinaitlab.com/soft/1315.htm" target="_blank">http://download.chinaitlab.com/soft/1315.htm</a><br /><br />面向对象编程：<br /><br />Java面向对象编程指南<br /><a href="http://download.chinaitlab.com/soft/9792.htm" target="_blank">http://download.chinaitlab.com/soft/9792.htm</a><br /><br />JAVA的核心技术：面向对象编程<br /><a href="http://download.chinaitlab.com/soft/9093.htm" target="_blank">http://download.chinaitlab.com/soft/9093.htm</a><br /><br />Java 与 UML 面向对象程序设计<br /><a href="http://download.chinaitlab.com/soft/6053.htm" target="_blank">http://download.chinaitlab.com/soft/6053.htm</a><br /><br />Java 2 编程21天自学通<br /><a href="http://download.chinaitlab.com/soft/10507.htm" target="_blank">http://download.chinaitlab.com/soft/10507.htm</a><br /><br />J2EE编程起步<br /><a href="http://download.chinaitlab.com/soft/10506.htm" target="_blank">http://download.chinaitlab.com/soft/10506.htm</a><br /><br />Java面向对象编程指南<br /><a href="http://download.chinaitlab.com/soft/9792.htm" target="_blank">http://download.chinaitlab.com/soft/9792.htm</a><br /><br />Java专业编程指南<br /><a href="http://download.chinaitlab.com/soft/9791.htm" target="_blank">http://download.chinaitlab.com/soft/9791.htm</a><br /><br />Java服务器高级编程<br /><a href="http://download.chinaitlab.com/soft/9790.htm" target="_blank">http://download.chinaitlab.com/soft/9790.htm</a><br /><br />J2EE EAI编程指南<br /><a href="http://download.chinaitlab.com/soft/9784.htm" target="_blank">http://download.chinaitlab.com/soft/9784.htm</a><br /><br />J2MEMIDP无线设备编程指南<br /><a href="http://download.chinaitlab.com/soft/9765.htm" target="_blank">http://download.chinaitlab.com/soft/9765.htm</a><br /><br />JAVA编程思想 中文版<br /><a href="http://download.chinaitlab.com/soft/9481.htm" target="_blank">http://download.chinaitlab.com/soft/9481.htm</a><br /><br />Java XML编程指南<br /><a href="http://download.chinaitlab.com/soft/9097.htm" target="_blank">http://download.chinaitlab.com/soft/9097.htm</a><br /><br />Java 数据库编程宝典<br /><a href="http://download.chinaitlab.com/soft/9095.htm" target="_blank">http://download.chinaitlab.com/soft/9095.htm</a><br /><br />JAVA的核心技术：面向对象编程<br /><a href="http://download.chinaitlab.com/soft/9093.htm" target="_blank">http://download.chinaitlab.com/soft/9093.htm</a><br /><br />JDBC API数据库编程实作教材<br /><a href="http://download.chinaitlab.com/soft/9087.htm" target="_blank">http://download.chinaitlab.com/soft/9087.htm</a><br /><br />核心 JSF 编程<br /><a href="http://download.chinaitlab.com/soft/7946.htm" target="_blank">http://download.chinaitlab.com/soft/7946.htm</a><br /><br />JAVA 2应用编程150例<br /><a href="http://download.chinaitlab.com/soft/6815.htm" target="_blank">http://download.chinaitlab.com/soft/6815.htm</a><br /><br />JAVA数据库编程JDBC<br /><a href="http://download.chinaitlab.com/soft/6113.htm" target="_blank">http://download.chinaitlab.com/soft/6113.htm</a><br /><br />深入掌握J2EE编程技术<br /><a href="http://download.chinaitlab.com/soft/6030.htm" target="_blank">http://download.chinaitlab.com/soft/6030.htm</a><br /><br />实用J2EE设计模式编程指南<br /><a href="http://download.chinaitlab.com/soft/5033.htm" target="_blank">http://download.chinaitlab.com/soft/5033.htm</a><br /><br />Java for Internet编程技术<br /><a href="http://download.chinaitlab.com/soft/4198.htm" target="_blank">http://download.chinaitlab.com/soft/4198.htm</a><br /><br />Java安全性编程指南<br /><a href="http://download.chinaitlab.com/soft/3773.htm" target="_blank">http://download.chinaitlab.com/soft/3773.htm</a><br /><br />J2ME无线设备编程<br /><a href="http://download.chinaitlab.com/soft/3669.htm" target="_blank">http://download.chinaitlab.com/soft/3669.htm</a><br /><br />J2EE EJB编程实例<br /><a href="http://download.chinaitlab.com/soft/3141.htm" target="_blank">http://download.chinaitlab.com/soft/3141.htm</a><br /><br />Java编程思想 第三版<br /><a href="http://download.chinaitlab.com/soft/2982.htm" target="_blank">http://download.chinaitlab.com/soft/2982.htm</a><br /><br />Java 极限编程<br /><a href="http://download.chinaitlab.com/soft/1707.htm" target="_blank">http://download.chinaitlab.com/soft/1707.htm</a><br /><br />Java2编程详解<br /><a href="http://download.chinaitlab.com/soft/1705.htm" target="_blank">http://download.chinaitlab.com/soft/1705.htm</a><br /><br /><br />网络编程：<br /><br />J2EE网络编程标准教程<br /><a href="http://download.chinaitlab.com/soft/9100.htm" target="_blank">http://download.chinaitlab.com/soft/9100.htm</a><br /><br />Java网络编程实例<br /><a href="http://download.chinaitlab.com/soft/9090.htm" target="_blank">http://download.chinaitlab.com/soft/9090.htm</a><br /><br />Java P2P网络编程技术<br /><a href="http://download.chinaitlab.com/soft/6333.htm" target="_blank">http://download.chinaitlab.com/soft/6333.htm</a><br /><br />Java网络编程<br /><a href="http://download.chinaitlab.com/soft/3871.htm" target="_blank">http://download.chinaitlab.com/soft/3871.htm</a><br /><br />网络编程基础篇之 Java Script<br /><a href="http://download.chinaitlab.com/soft/3618.htm" target="_blank">http://download.chinaitlab.com/soft/3618.htm</a><br /><br />Solaris Shell 编程<br /><a href="http://download.chinaitlab.com/soft/6426.htm" target="_blank">http://download.chinaitlab.com/soft/6426.htm</a><br /><br />SUN Solaris管理手册<br /><a href="http://download.chinaitlab.com/soft/5732.htm" target="_blank">http://download.chinaitlab.com/soft/5732.htm</a><br /><br />Solaris性能管理<br /><a href="http://download.chinaitlab.com/soft/11247.htm" target="_blank">http://download.chinaitlab.com/soft/11247.htm</a><br /><br />Solaris9安装指南<br /><a href="http://download.chinaitlab.com/soft/5022.htm" target="_blank">http://download.chinaitlab.com/soft/5022.htm</a><br /><br />SOLARIS高级系统管理员指南<br /><a href="http://download.chinaitlab.com/soft/3726.htm" target="_blank">http://download.chinaitlab.com/soft/3726.htm</a><br /><br />Solaris操作环境安全<br /><a href="http://download.chinaitlab.com/soft/1500.htm" target="_blank">http://download.chinaitlab.com/soft/1500.htm</a><br /><br />Solaris GNOME2.0桌面用户指南<br /><a href="http://download.chinaitlab.com/soft/1488.htm" target="_blank">http://download.chinaitlab.com/soft/1488.htm</a><br /><br />Solaris 9 12/03 安装指南<br /><a href="http://download.chinaitlab.com/soft/1484.htm" target="_blank">http://download.chinaitlab.com/soft/1484.htm</a><br /><br />Solaris管理员指南<br /><a href="http://download.chinaitlab.com/soft/1475.htm" target="_blank">http://download.chinaitlab.com/soft/1475.htm</a><br /><br />中文Solaris9 系统管理员指南<br /><a href="http://download.chinaitlab.com/soft/1463.htm" target="_blank">http://download.chinaitlab.com/soft/1463.htm</a><br /><br />Solaris安全性专题指导<br /><a href="http://download.chinaitlab.com/soft/746.htm" target="_blank">http://download.chinaitlab.com/soft/746.htm</a><br /><br /><br />XML系列：<br /><br />Java XML编程指南<br /><a href="http://download.chinaitlab.com/soft/9097.htm" target="_blank">http://download.chinaitlab.com/soft/9097.htm</a><br /><br />Java程序设计EJB、XML与数据库<br /><a href="http://download.chinaitlab.com/soft/9094.htm" target="_blank">http://download.chinaitlab.com/soft/9094.htm</a><br /><br />XML 终极教程<br /><a href="http://download.chinaitlab.com/soft/9057.htm" target="_blank">http://download.chinaitlab.com/soft/9057.htm</a><br /><br />Java&amp;XML应用<br /><a href="http://download.chinaitlab.com/soft/6211.htm" target="_blank">http://download.chinaitlab.com/soft/6211.htm</a><br /><br />XML_JAVA指南<br /><a href="http://download.chinaitlab.com/soft/6163.htm" target="_blank">http://download.chinaitlab.com/soft/6163.htm</a><br /><br />JDBC：<br /><br />JDBC API数据库编程实作教材<br /><a href="http://download.chinaitlab.com/soft/9087.htm" target="_blank">http://download.chinaitlab.com/soft/9087.htm</a><br /><br />JAVA数据库编程JDBC<br /><a href="http://download.chinaitlab.com/soft/6113.htm" target="_blank">http://download.chinaitlab.com/soft/6113.htm</a><br /><br />JDBC API 参考教程第三版<br /><a href="http://download.chinaitlab.com/soft/6057.htm" target="_blank">http://download.chinaitlab.com/soft/6057.htm</a><br /><br />JDBC与Java数据库程序设计<br /><a href="http://download.chinaitlab.com/soft/6018.htm" target="_blank">http://download.chinaitlab.com/soft/6018.htm</a><br /><br />Java语言SQL接口 JDBCprogram<br /><a href="http://download.chinaitlab.com/soft/5938.htm" target="_blank">http://download.chinaitlab.com/soft/5938.htm</a><br /><br />JSP应用程序开发指南<br /><a href="http://download.chinaitlab.com/soft/1546.htm" target="_blank">http://download.chinaitlab.com/soft/1546.htm</a><br /><br />用 JDBC 管理数据库连接<br /><a href="http://download.chinaitlab.com/soft/935.htm" target="_blank">http://download.chinaitlab.com/soft/935.htm</a><br /><br />JDO：<br /><br />全面了解JDO数据库编程<br /><a href="http://download.chinaitlab.com/soft/7992.htm" target="_blank">http://download.chinaitlab.com/soft/7992.htm</a><br /><br />Struts：<br /><br />Struts中文手册<br /><a href="http://download.chinaitlab.com/soft/10516.htm" target="_blank">http://download.chinaitlab.com/soft/10516.htm</a><br /><br />Struts架构指导<br /><a href="http://download.chinaitlab.com/soft/7529.htm" target="_blank">http://download.chinaitlab.com/soft/7529.htm</a><br /><br />精通struts技术<br /><a href="http://download.chinaitlab.com/soft/6801.htm" target="_blank">http://download.chinaitlab.com/soft/6801.htm</a><br /><br />Struts 学习起歩问答<br /><a href="http://download.chinaitlab.com/soft/6156.htm" target="_blank">http://download.chinaitlab.com/soft/6156.htm</a><br /><br />Hibernate：<br /><br />Hibernate2.1.2参考手册中文版<br /><a href="http://download.chinaitlab.com/soft/8919.htm" target="_blank">http://download.chinaitlab.com/soft/8919.htm</a><br /><br /><br /><br />JAVA与模式\J2EE模式：<br /><br />J2EE 核心模式<br /><a href="http://download.chinaitlab.com/soft/9785.htm" target="_blank">http://download.chinaitlab.com/soft/9785.htm</a><br /><br />Java 企业设计模式<br /><a href="http://download.chinaitlab.com/soft/9096.htm" target="_blank">http://download.chinaitlab.com/soft/9096.htm</a><br /><br />Java简单工厂创立性模式介绍<br /><a href="http://download.chinaitlab.com/soft/7398.htm" target="_blank">http://download.chinaitlab.com/soft/7398.htm</a><br /><br />EJB设计模式<br /><a href="http://download.chinaitlab.com/soft/6135.htm" target="_blank">http://download.chinaitlab.com/soft/6135.htm</a><br /><br />JAVA设计模式<br /><a href="http://download.chinaitlab.com/soft/6112.htm" target="_blank">http://download.chinaitlab.com/soft/6112.htm</a><br /><br />实用J2EE设计模式编程指南<br /><a href="http://download.chinaitlab.com/soft/5033.htm" target="_blank">http://download.chinaitlab.com/soft/5033.htm</a><br /><br />Java与模式<br /><a href="http://download.chinaitlab.com/soft/3073.htm" target="_blank">http://download.chinaitlab.com/soft/3073.htm</a><br /><br />设计模式Java版<br /><a href="http://download.chinaitlab.com/soft/1723.htm" target="_blank">http://download.chinaitlab.com/soft/1723.htm</a><br /><br /><br />JBuilder开发Servlet及JSP：<br /><br />精通JBuilder<br /><a href="http://download.chinaitlab.com/soft/10565.htm" target="_blank">http://download.chinaitlab.com/soft/10565.htm</a><br /><br />JBuilder速成资料<br /><a href="http://download.chinaitlab.com/soft/9714.htm" target="_blank">http://download.chinaitlab.com/soft/9714.htm</a><br /><br />Jbuilder7和weblogic7整合开发手<br /><a href="http://download.chinaitlab.com/soft/9664.htm" target="_blank">http://download.chinaitlab.com/soft/9664.htm</a><br /><br />JBUILDER9 软件开发项目实践<br /><a href="http://download.chinaitlab.com/soft/9089.htm" target="_blank">http://download.chinaitlab.com/soft/9089.htm</a><br /><br />JbuilderX开发指南<br /><a href="http://download.chinaitlab.com/soft/9088.htm" target="_blank">http://download.chinaitlab.com/soft/9088.htm</a><br /><br />Jbuilder x 指南<br /><a href="http://download.chinaitlab.com/soft/7984.htm" target="_blank">http://download.chinaitlab.com/soft/7984.htm</a><br /><br />JBuilder4开发人员指南<br /><a href="http://download.chinaitlab.com/soft/5939.htm" target="_blank">http://download.chinaitlab.com/soft/5939.htm</a><br /><br />JBuilder7 Weblogic7整和开发培训手册<br /><a href="http://download.chinaitlab.com/soft/4727.htm" target="_blank">http://download.chinaitlab.com/soft/4727.htm</a><br /><br />JBuilder开发数据库应用程序<br /><a href="http://download.chinaitlab.com/soft/1701.htm" target="_blank">http://download.chinaitlab.com/soft/1701.htm</a><br /><br />Java开发指南--Servlets和JSP篇<br /><a href="http://download.chinaitlab.com/soft/9793.htm" target="_blank">http://download.chinaitlab.com/soft/9793.htm</a><br /><br />Java Servlets 编程指南<br /><a href="http://download.chinaitlab.com/soft/9098.htm" target="_blank">http://download.chinaitlab.com/soft/9098.htm</a><br /><br />Oreilly Java Servlet<br /><a href="http://download.chinaitlab.com/soft/6522.htm" target="_blank">http://download.chinaitlab.com/soft/6522.htm</a><br /><br />Java Servlet开发与实例<br /><a href="http://download.chinaitlab.com/soft/6029.htm" target="_blank">http://download.chinaitlab.com/soft/6029.htm</a><br /><br />深入Java Servlet 网络编程<br /><a href="http://download.chinaitlab.com/soft/9783.htm" target="_blank">http://download.chinaitlab.com/soft/9783.htm</a><br /><br />用JSP_Servlet构建三层式管理信息系统<br /><a href="http://download.chinaitlab.com/soft/6034.htm" target="_blank">http://download.chinaitlab.com/soft/6034.htm</a><br /><br />Java Servlet帮助文档<br /><a href="http://download.chinaitlab.com/soft/2981.htm" target="_blank">http://download.chinaitlab.com/soft/2981.htm</a><br /><br />JSP网站编程教程<br /><a href="http://download.chinaitlab.com/soft/11256.htm" target="_blank">http://download.chinaitlab.com/soft/11256.htm</a><br /><br />JSP语法分析<br /><a href="http://download.chinaitlab.com/soft/11257.htm" target="_blank">http://download.chinaitlab.com/soft/11257.htm</a><br /><br />JSP实用教程<br /><a href="http://download.chinaitlab.com/soft/10792.htm" target="_blank">http://download.chinaitlab.com/soft/10792.htm</a><br /><br />JSP语法（1）--HTML注释<br /><a href="http://download.chinaitlab.com/soft/10790.htm" target="_blank">http://download.chinaitlab.com/soft/10790.htm</a><br /><br />JSP应用开发详解<br /><a href="http://download.chinaitlab.com/soft/10025.htm" target="_blank">http://download.chinaitlab.com/soft/10025.htm</a><br /><br />JSP技术揭秘<br /><a href="http://download.chinaitlab.com/soft/9387.htm" target="_blank">http://download.chinaitlab.com/soft/9387.htm</a><br /><br />JSP技术大全<br /><a href="http://download.chinaitlab.com/soft/9388.htm" target="_blank">http://download.chinaitlab.com/soft/9388.htm</a><br /><br />JSP网上书店实例详解<br /><a href="http://download.chinaitlab.com/soft/9386.htm" target="_blank">http://download.chinaitlab.com/soft/9386.htm</a><br /><br />JSP动态网页新技术<br /><a href="http://download.chinaitlab.com/soft/8920.htm" target="_blank">http://download.chinaitlab.com/soft/8920.htm</a><br /><br />JSP 技术大全<br /><a href="http://download.chinaitlab.com/soft/7782.htm" target="_blank">http://download.chinaitlab.com/soft/7782.htm</a><br /><br />JSP高级开发与应用<br /><a href="http://download.chinaitlab.com/soft/7633.htm" target="_blank">http://download.chinaitlab.com/soft/7633.htm</a><br /><br />JSP 完全探索<br /><a href="http://download.chinaitlab.com/soft/7546.htm" target="_blank">http://download.chinaitlab.com/soft/7546.htm</a><br /><br />JSP 高级开发与应用<br /><a href="http://download.chinaitlab.com/soft/7116.htm" target="_blank">http://download.chinaitlab.com/soft/7116.htm</a><br /><br />JSP编程技巧<br /><a href="http://download.chinaitlab.com/soft/7114.htm" target="_blank">http://download.chinaitlab.com/soft/7114.htm</a><br /><br />JSP速成教程<br /><a href="http://download.chinaitlab.com/soft/6882.htm" target="_blank">http://download.chinaitlab.com/soft/6882.htm</a><br /><br />JSP网络编程技术<br /><a href="http://download.chinaitlab.com/soft/6880.htm" target="_blank">http://download.chinaitlab.com/soft/6880.htm</a><br /><br />JSP程序设计指南<br /><a href="http://download.chinaitlab.com/soft/6690.htm" target="_blank">http://download.chinaitlab.com/soft/6690.htm</a><br /><br />最新JSP入门与应用<br /><a href="http://download.chinaitlab.com/soft/6697.htm" target="_blank">http://download.chinaitlab.com/soft/6697.htm</a><br /><br />JSP快速入门<br /><a href="http://download.chinaitlab.com/soft/6636.htm" target="_blank">http://download.chinaitlab.com/soft/6636.htm</a><br /><br />JSP网页编程<br /><a href="http://download.chinaitlab.com/soft/6527.htm" target="_blank">http://download.chinaitlab.com/soft/6527.htm</a><br /><br />JSP 实用教程<br /><a href="http://download.chinaitlab.com/soft/6334.htm" target="_blank">http://download.chinaitlab.com/soft/6334.htm</a><br /><br />JSP入门与提高<br /><a href="http://download.chinaitlab.com/soft/6326.htm" target="_blank">http://download.chinaitlab.com/soft/6326.htm</a><br /><br />JSP语法<br /><a href="http://download.chinaitlab.com/soft/6116.htm" target="_blank">http://download.chinaitlab.com/soft/6116.htm</a><br /><br />掌握自定义JSP标签<br /><a href="http://download.chinaitlab.com/soft/6096.htm" target="_blank">http://download.chinaitlab.com/soft/6096.htm</a><br /><br />JSP 动态网站技术入门与提高<br /><a href="http://download.chinaitlab.com/soft/6019.htm" target="_blank">http://download.chinaitlab.com/soft/6019.htm</a><br /><br />JSP实例入门<br /><a href="http://download.chinaitlab.com/soft/4377.htm" target="_blank">http://download.chinaitlab.com/soft/4377.htm</a><br /><br />JSP教程之与数据库通信<br /><a href="http://download.chinaitlab.com/soft/3673.htm" target="_blank">http://download.chinaitlab.com/soft/3673.htm</a><br /><br />如何成为优秀的JSP 程序员<br /><a href="http://download.chinaitlab.com/soft/3002.htm" target="_blank">http://download.chinaitlab.com/soft/3002.htm</a><br /><br />JSP数据库编程指南<br /><a href="http://download.chinaitlab.com/soft/2946.htm" target="_blank">http://download.chinaitlab.com/soft/2946.htm</a><br /><br />JSP 高级编程<br /><a href="http://download.chinaitlab.com/soft/2635.htm" target="_blank">http://download.chinaitlab.com/soft/2635.htm</a><br /><br />JSP实用编程实例集锦<br /><a href="http://download.chinaitlab.com/soft/2154.htm" target="_blank">http://download.chinaitlab.com/soft/2154.htm</a><br /><br />JSP程序设计精彩实例<br /><a href="http://download.chinaitlab.com/soft/2151.htm" target="_blank">http://download.chinaitlab.com/soft/2151.htm</a><br /><br />JSP即时应用<br /><a href="http://download.chinaitlab.com/soft/1547.htm" target="_blank">http://download.chinaitlab.com/soft/1547.htm</a><br /><br />JSP程序设计精彩实例<br /><a href="http://download.chinaitlab.com/soft/1543.htm" target="_blank">http://download.chinaitlab.com/soft/1543.htm</a><br /><br />JSP实用编程实例集锦<br /><a href="http://download.chinaitlab.com/soft/1537.htm" target="_blank">http://download.chinaitlab.com/soft/1537.htm</a><br /><br />JSP基础<br /><a href="http://download.chinaitlab.com/soft/894.htm" target="_blank">http://download.chinaitlab.com/soft/894.htm</a><br /><br />Eclipse开发Servlet及JSP：<br /><br />Eclipse+Tomcat集成开发servle<br /><a href="http://download.chinaitlab.com/soft/6134.htm" target="_blank">http://download.chinaitlab.com/soft/6134.htm</a><br /><br />J2EE Jboss Ejb With Eclipse 2003<br /><a href="http://download.chinaitlab.com/soft/6045.htm" target="_blank">http://download.chinaitlab.com/soft/6045.htm</a></span><img src ="http://www.blogjava.net/konhon/aggbug/36685.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-21 20:27 <a href="http://www.blogjava.net/konhon/archive/2006/03/21/36685.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>JDBC编程学習</title><link>http://www.blogjava.net/konhon/archive/2006/03/21/36682.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Tue, 21 Mar 2006 12:18:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/21/36682.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/36682.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/21/36682.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/36682.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/36682.html</trackback:ping><description><![CDATA[<font size="4">连接oracle数据库的各种oracle jdbc驱动程序的细节。<br />这些细节包括：<br />1、导入jdbc包<br />2、注册oracle jdbc驱动程序<br />3、打开数据库连接<br />4、执行sql dml语句在数据库表中获取、添加、修改和删除行<br /></font>
		<p>
				<font size="4">一、jdbc驱动程序<br />共有有4种<br />1、thin驱动程序<br />thin驱动程序是所有驱动程序中资源消耗最小的，而且完全用java编写的。<br />该驱动程序只使用tcp/ip且要求oracle net。被称为第4类驱动程序。<br />它使用ttc协议与oracle数据库进行通信。能够在applet、application中使用。<br />2、oci驱动程序<br />oci驱动比thin需要资源要多，但性能通常好一点。oci驱动适合于部署在<br />中间层的软件，如web服务器。不能在applet中使用oci驱动。是第2类驱动程序。<br />不完全用java写的，还包含了c代码。该驱动有许多附加的性能增强特性，<br />包括高级的连接缓冲功能。<br /><font color="#ff0000">注意：</font>oci驱动要求在客户计算机上安装它。<br />3、服务器内部驱动程序<br />服务器内部驱动程序提供对数据库的直接访问，oracle jvm使用它与数据库进行通信。<br />oracle jvm是与数据库集成的java virtual machine，可以使用oracle jvm将<br />java类装载进数据库，然后公布和运行这个类中包含的方法。<br />4、服务器thin驱动程序<br />服务器端thin驱动程序也是由oracle jvm使用的，它提供对远程数据库的访问。<br />也是完全用java编写的。</font>
		</p>
		<br />
		<p>
				<font size="4">二、导入jdbc包<br />三、注册oracle jdbc驱动程序<br />必须先向java程序注册oracle jdbc驱动程序，然后才能打开数据库连接。<br />有两种注册oracle jdbc驱动程序的办法。<br />1、使用java.lang.class的forname()方法<br />例子：class.forname(oracle.jdbc.oracledriver);<br />2、使用jdbc drivermanager类的registerdriver()方法。<br />例子：drivermanager.registerdriver(new oracle.jdbc.oracledriver());<br />如果使用oracle8i jdbc驱动程序，那么需要导入oracle.jdbc.driver.oracledriver类，<br />然后注册这个类的实例。<br />例子：<br />import oracle.jdbc.driver.oracledriver;<br />drivermanager.registerdriver(new oracle.jdbc.oracledriver());<br /><font color="#ff0000">注意</font>：从jdbc2.0开始，只用jdbc驱动程序的更标准办法是通过数据源。<br />四、打开数据库连接<br />必须先打开数据库连接，然后才能在java程序中执行sql语句。打开数据库连接<br />的主要办法。<br />1、drivermanager类的getconnection()方法。<br />drivermanager.getconnection(url,<font color="#000000">username</font>,<font color="#000000">passwrod</font>);<br /><font color="#008000">url</font>:程序要连接的数据库，以及要使用的jdbc驱动程序<br />url的结构依赖于jdbc驱动程序的生产商。对于oracle jdbc驱动程序，数据库url的结构：<br /><br /><font color="#0000ff">driver_name</font>是程序使用的oracle jdbc驱动程序的名称。如：<br />jdbc:oracle:thin oracle jdbc thin驱动程序<br />jdbc:oracle:oci oracle jdbc oci驱动程序<br />jdbc:oracle:oci8 oracle jdbc oci驱动程序<br /><font color="#0000ff">driver_information</font>是连接数据库所需的驱动程序特有的信息。这依赖于使用的驱动程序。<br />对于oracle jdbc thin驱动程序，可以用<br />host_name:port:database_sid 或者 oracle net关键字-值对<br />(description=(address=(host=host_name)(protocol=tcp)(port=port()<br />(connect_data=(sid=database_sid)))<br />host_name: 运行数据库的机器的名称<br />port: net数据库监听器等待这个端口上的请求，默认是1521<br />database_sid: 要连接的数据库实例的oracle sid。<br /><font color="#006400">username</font>: 程序连接数据库时使用的数据库用户名<br /><font color="#006400">passwrod</font>: 用户名的口令<br />例子：<br />connection myconnection=drivermanager.getconnection(<br />jdbc:oracle:thin:@localhost:1521:orcl,<br />store_user,<br />store_password);<br />connection myconnection=drivermanager.getconnection(<br />jdbc:oracle:oci:@(description=(address=(host=localhost) <br />(protocol=tcp)(port=1521))(connect_data=(sid=orcl))),<br />store_user,<br />store_password);<br />2、使用oracle数据源对象，必须先创建这个对象，然后连接它。使用这种方法<br />采用了一种设置数据库连接信息的标准化方式，oracle数据源对象可以与<br />java naming and directory interface(java名字与目录接口，jndi)一起使用。</font>
		</p><img src ="http://www.blogjava.net/konhon/aggbug/36682.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-21 20:18 <a href="http://www.blogjava.net/konhon/archive/2006/03/21/36682.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>J2EE面试题集锦</title><link>http://www.blogjava.net/konhon/archive/2006/03/14/35163.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Tue, 14 Mar 2006 00:35:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/14/35163.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/35163.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/14/35163.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/35163.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/35163.html</trackback:ping><description><![CDATA[<P>/**<BR>&nbsp;* By metaphy 2005-11-12<BR>&nbsp;* Version: 0.01<BR>&nbsp;* 注:题目答案来源于metaphy过去的知识或网络,metaphy不能保证其正确或完整性,仅供参考<BR>**/</P>
<P><STRONG>一、基础问答</STRONG></P>
<P>　　<STRONG>1.下面哪些类可以被继承?</STRONG></P>
<P>　　　java.lang.Thread (T)<BR>　　　java.lang.Number (T)<BR>　　　java.lang.Double (F)<BR>　　　java.lang.Math&nbsp; (F)<BR>　　　java.lang.Void&nbsp; (F)<BR>　　　java.lang.Class&nbsp; (F)<BR>　　　java.lang.ClassLoader (T)</P>
<P>　　<STRONG>2.抽象类和接口的区别</STRONG></P>
<P>　　(1)接口可以被多重implements,抽象类只能被单一extends<BR>　　(2)接口只有定义,抽象类可以有定义和实现<BR>　　(3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"(本包可见)</P>
<P>　　<STRONG>3.Hashtable的原理,并说出HashMap与Hashtable的区别</STRONG></P>
<P>　　HashTable的原理:通过节点的关键码确定节点的存储位置,即给定节点的关键码k,通过一定的函数关系H(散列函数),得到函数值H(k),将此值解释为该节点的存储地址.<BR>HashMap 与Hashtable很相似,但HashMap 是非同步(unsynchronizded)和可以以null为关键码的.</P>
<P>　　<STRONG>4.forward和redirect的区别</STRONG></P>
<P>　　forward: an internal transfer in servlet<BR>　　redirect: 重定向,有2次request,第2次request将丢失第一次的attributs/parameters等</P>
<P>　　<STRONG>5.什么是Web容器?</STRONG></P>
<P>　　实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.</P>
<P>　　6.解释下面关于J2EE的名词</P>
<P>　　(1)JNDI:Java Naming &amp; Directory Interface,JAVA命名目录服务.主要提供的功能是：提供一个目录系统，让其它各地的应用程序在其上面留下自己的索引，从而满足快速查找和定位分布式应用程序的功能.<BR>　　(2)JMS：Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包括点对点和广播.<BR>　　(3)JTA：Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序只需调用其提供的接口即可.<BR>　　(4)JAF: <A title=Java HREF="/konhon/category/3016.html" target=_blank><a title="Java" href="http://www.blogjava.net/konhon/category/3016.html" target="_blank">Java</a></A> Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者通过各种部署和自定义实现自己的个性安全控制策略.<BR>　　(5)RMI:Remote Method Interface,远程方法调用</P>
<P>　　<STRONG>7.EJB是基于哪些技术实现的？并说 出SessionBean和EntityBean的区别，StatefulBean和StatelessBean的区别.</STRONG></P>
<P>　　EJB包括Session Bean、Entity Bean、Message Driven Bean，基于JNDI、RMI、JAT等技术实现.</P>
<P>　　SessionBean在J2EE应用程序中被用来完成一些服务器端的业务操作，例如访问数据库、调用其他EJB组件.EntityBean被用来代表应用系统中用到的数据.对于客户机，SessionBean是一种非持久性对象，它实现某些在服务器上运行的业务逻辑;EntityBean是一种持久性对象，它代表一个存储在持久性存储器中的实体的对象视图，或是一个由现有企业应用程序实现的实体.</P>
<P>　　Session Bean 还可以再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean都可以将系统逻辑放在 method之中执行，不同的是 Stateful Session Bean 可以记录呼叫者的状态，因此通常来说，一个使用者会有一个相对应的 Stateful Session Bean 的实体.Stateless Session Bean 虽然也是逻辑组件，但是他却不负责记录使用者状态，也就是说当使用者呼叫 Stateless Session Bean 的时候，EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来执行这个 method.换言之，很可能数个使用者在执行某个 Stateless Session Bean 的 methods 时，会是同一个 Bean 的 Instance 在执行.从内存方面来看， Stateful Session Bean 与 Stateless Session Bean 比较， Stateful Session Bean 会消耗 J2EE Server 较多的内存，然而 Stateful Session Bean 的优势却在于他可以维持使用者的状态.</P>
<P>　　<STRONG>8.XML的解析方法</STRONG></P>
<P>　　Sax,DOM,JDOM</P>
<P>　　<STRONG>9.什么是Web Service?</STRONG></P>
<P>　　Web Service就是为了使原来各孤立的站点之间的信息能够相互通信、共享而提出的一种接口。<BR>Web Service所使用的是Internet上统一、开放的标准，如HTTP、XML、SOAP（简单对象访问协议）、WSDL等，所以Web Service可以在任何支持这些标准的环境（Windows,Linux）中使用。</P>
<P>　　注：SOAP协议（Simple Object Access Protocal,简单对象访问协议）,它是一个用于分散和分布式环境下网络信息交换的基于XML的通讯协议。在此协议下，软件组件或应用程序能够通过标准的HTTP协议进行通讯。它的设计目标就是简单性和扩展性，这有助于大量异构程序和平台之间的互操作性，从而使存在的应用程序能够被广泛的用户访问。</P>
<P>　　优势：</P>
<P>　　(1).跨平台。<BR>　　(2).SOAP协议是基于XML和HTTP这些业界的标准的，得到了所有的重要公司的支持。<BR>　　(3).由于使用了SOAP，数据是以ASCII文本的方式而非二进制传输，调试很方便；并且由于这样，它的数据容易通过防火墙，不需要防火墙为了程序而单独开一个“漏洞”。<BR>　　(4).此外，WebService实现的技术难度要比CORBA和DCOM小得多。<BR>　　(5).要实现B2B集成，EDI比较完善与比较复杂；而用WebService则可以低成本的实现，小公司也可以用上。<BR>　　(6).在C/S的程序中，WebService可以实现网页无整体刷新的与服务器打交道并取数。</P>
<P>　　缺点：</P>
<P>　　(1).WebService使用了XML对数据封装，会造成大量的数据要在网络中传输。<BR>　　(2).WebService规范没有规定任何与实现相关的细节，包括对象模型、编程语言，这一点，它不如CORBA。</P>
<P>　　<STRONG>10.多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?</STRONG></P>
<P>　　答：多线程有两种实现方法，分别是继承Thread类与实现Runnable接口<BR>　　同步的实现方面有两种，分别是synchronized,wait与notify</P>
<P>　　<STRONG>11.JSP中动态INCLUDE与静态INCLUDE的区别？</STRONG> </P>
<P>　　动态INCLUDE用jsp:include动作实现</P>
<P>&lt;jsp:include page="included.jsp" flush="true"/&gt;</P>
<P>　　它总是会检查所含文件中的变化，适合用于包含动态页面，并且可以带参数</P>
<P>　　静态INCLUDE用include伪码实现,定不会检查所含文件的变化，适用于包含静态页面</P>
<P>　　&lt;%@ include file="included.htm" %&gt;</P><img src ="http://www.blogjava.net/konhon/aggbug/35163.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/konhon/" target="_blank">konhon 优华</a> 2006-03-14 08:35 <a href="http://www.blogjava.net/konhon/archive/2006/03/14/35163.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>上传图片的缩放处理 - 非常实用！（</title><link>http://www.blogjava.net/konhon/archive/2006/03/13/35030.html</link><dc:creator>konhon 优华</dc:creator><author>konhon 优华</author><pubDate>Mon, 13 Mar 2006 06:29:00 GMT</pubDate><guid>http://www.blogjava.net/konhon/archive/2006/03/13/35030.html</guid><wfw:comment>http://www.blogjava.net/konhon/comments/35030.html</wfw:comment><comments>http://www.blogjava.net/konhon/archive/2006/03/13/35030.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/konhon/comments/commentRss/35030.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/konhon/services/trackbacks/35030.html</trackback:ping><description><![CDATA[<DIV style="BORDER-RIGHT: #cccccc 1px solid; PADDING-RIGHT: 5px; BORDER-TOP: #cccccc 1px solid; PADDING-LEFT: 4px; FONT-SIZE: 13px; PADDING-BOTTOM: 4px; BORDER-LEFT: #cccccc 1px solid; WIDTH: 98%; WORD-BREAK: break-all; PADDING-TOP: 4px; BORDER-BOTTOM: #cccccc 1px solid; BACKGROUND-COLOR: #eeeeee"><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top><SPAN style="COLOR: #0000ff">import</SPAN><SPAN style="COLOR: #000000">&nbsp;java.io.File;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top></SPAN><SPAN style="COLOR: #0000ff">import</SPAN><SPAN style="COLOR: #000000">&nbsp;java.awt.image.BufferedImage;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top></SPAN><SPAN style="COLOR: #0000ff">import</SPAN><SPAN style="COLOR: #000000">&nbsp;java.awt.Image;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top></SPAN><SPAN style="COLOR: #0000ff">import</SPAN><SPAN style="COLOR: #000000">&nbsp;java.awt.image.AffineTransformOp;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top></SPAN><SPAN style="COLOR: #0000ff">import</SPAN><SPAN style="COLOR: #000000">&nbsp;javax.imageio.ImageIO;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top></SPAN><SPAN style="COLOR: #0000ff">import</SPAN><SPAN style="COLOR: #000000">&nbsp;java.awt.geom.AffineTransform;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/None.gif" align=top><BR><IMG id=Codehighlighter1_214_2550_Open_Image onclick="this.style.display='none'; Codehighlighter1_214_2550_Open_Text.style.display='none'; Codehighlighter1_214_2550_Closed_Image.style.display='inline'; Codehighlighter1_214_2550_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedBlockStart.gif" align=top><IMG id=Codehighlighter1_214_2550_Closed_Image style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_214_2550_Closed_Text.style.display='none'; Codehighlighter1_214_2550_Open_Image.style.display='inline'; Codehighlighter1_214_2550_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedBlock.gif" align=top></SPAN><SPAN style="COLOR: #0000ff">public</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #0000ff">class</SPAN><SPAN style="COLOR: #000000">&nbsp;UploadImg&nbsp;</SPAN><SPAN id=Codehighlighter1_214_2550_Closed_Text style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff"><IMG src="http://www.blogjava.net/images/dot.gif"></SPAN><SPAN id=Codehighlighter1_214_2550_Open_Text><SPAN style="COLOR: #000000">{<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;String&nbsp;fromdir;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;fromdir&nbsp;图片的原始目录</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000">&nbsp;&nbsp;&nbsp;&nbsp;String&nbsp;todir;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;todir&nbsp;处理后的图片存放目录</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000">&nbsp;&nbsp;&nbsp;&nbsp;String&nbsp;imgfile;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;imgfile&nbsp;原始图片</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000">&nbsp;&nbsp;&nbsp;&nbsp;String&nbsp;sysimgfile;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;sysimgfile&nbsp;处理后的图片文件名前缀</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000"><BR><IMG id=Codehighlighter1_516_644_Open_Image onclick="this.style.display='none'; Codehighlighter1_516_644_Open_Text.style.display='none'; Codehighlighter1_516_644_Closed_Image.style.display='inline'; Codehighlighter1_516_644_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align=top><IMG id=Codehighlighter1_516_644_Closed_Image style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_516_644_Closed_Text.style.display='none'; Codehighlighter1_516_644_Open_Image.style.display='inline'; Codehighlighter1_516_644_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;UploadImg(&nbsp;String&nbsp;fromdirNow,&nbsp;String&nbsp;todirNow,&nbsp;String&nbsp;imgfileNow,&nbsp;String&nbsp;sysimgfileNow&nbsp;)</SPAN><SPAN id=Codehighlighter1_516_644_Closed_Text style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff"><IMG src="http://www.blogjava.net/images/dot.gif"></SPAN><SPAN id=Codehighlighter1_516_644_Open_Text><SPAN style="COLOR: #000000">{<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fromdir&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;fromdirNow;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;todir&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;todirNow;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;imgfile&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;imgfileNow;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;sysimgfile&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;sysimgfileNow;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;}</SPAN></SPAN><SPAN style="COLOR: #000000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">public</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #0000ff">boolean</SPAN><SPAN style="COLOR: #000000">&nbsp;CreateThumbnail()&nbsp;</SPAN><SPAN style="COLOR: #0000ff">throws</SPAN><SPAN style="COLOR: #000000">&nbsp;Exception<BR><IMG id=Codehighlighter1_709_2025_Open_Image onclick="this.style.display='none'; Codehighlighter1_709_2025_Open_Text.style.display='none'; Codehighlighter1_709_2025_Closed_Image.style.display='inline'; Codehighlighter1_709_2025_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align=top><IMG id=Codehighlighter1_709_2025_Closed_Image style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_709_2025_Closed_Text.style.display='none'; Codehighlighter1_709_2025_Open_Image.style.display='inline'; Codehighlighter1_709_2025_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN id=Codehighlighter1_709_2025_Closed_Text style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff"><IMG src="http://www.blogjava.net/images/dot.gif"></SPAN><SPAN id=Codehighlighter1_709_2025_Open_Text><SPAN style="COLOR: #000000">{<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;fileExtNmae是图片的格式&nbsp;gif&nbsp;JPG&nbsp;或png<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;String&nbsp;fileExtNmae="";</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">double</SPAN><SPAN style="COLOR: #000000">&nbsp;Ratio&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #000000">0.0</SPAN><SPAN style="COLOR: #000000">;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;File&nbsp;F&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #0000ff">new</SPAN><SPAN style="COLOR: #000000">&nbsp;File(fromdir,imgfile);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">if</SPAN><SPAN style="COLOR: #000000">&nbsp;(&nbsp;</SPAN><SPAN style="COLOR: #000000">!</SPAN><SPAN style="COLOR: #000000">F.isFile()&nbsp;)<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">throw</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #0000ff">new</SPAN><SPAN style="COLOR: #000000">&nbsp;Exception(F</SPAN><SPAN style="COLOR: #000000">+</SPAN><SPAN style="COLOR: #000000">"</SPAN><SPAN style="COLOR: #000000">&nbsp;is&nbsp;not&nbsp;image&nbsp;file&nbsp;error&nbsp;in&nbsp;CreateThumbnail!</SPAN><SPAN style="COLOR: #000000">"</SPAN><SPAN style="COLOR: #000000">);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">首先判断上传的图片是gif还是JPG&nbsp;ImageIO只能将gif转换为png<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;if&nbsp;(isJpg(imgfile)){<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;&nbsp;&nbsp;&nbsp;fileExtNmae="jpg";<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;&nbsp;&nbsp;&nbsp;}<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">else{<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;&nbsp;&nbsp;&nbsp;fileExtNmae="png";&nbsp;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">&nbsp;&nbsp;&nbsp;&nbsp;}</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;File&nbsp;ThF&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #0000ff">new</SPAN><SPAN style="COLOR: #000000">&nbsp;File(&nbsp;todir,&nbsp;sysimgfile&nbsp;</SPAN><SPAN style="COLOR: #000000">+</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #000000">"</SPAN><SPAN style="COLOR: #000000">.jpg</SPAN><SPAN style="COLOR: #000000">"</SPAN><SPAN style="COLOR: #000000">&nbsp;);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;BufferedImage&nbsp;Bi&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;ImageIO.read(F);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #008000">//</SPAN><SPAN style="COLOR: #008000">假设图片宽&nbsp;高&nbsp;最大为120&nbsp;120</SPAN><SPAN style="COLOR: #008000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top></SPAN><SPAN style="COLOR: #000000">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Image&nbsp;Itemp&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;Bi.getScaledInstance&nbsp;(</SPAN><SPAN style="COLOR: #000000">120</SPAN><SPAN style="COLOR: #000000">,</SPAN><SPAN style="COLOR: #000000">120</SPAN><SPAN style="COLOR: #000000">,Bi.SCALE_SMOOTH);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<BR><IMG id=Codehighlighter1_1450_1618_Open_Image onclick="this.style.display='none'; Codehighlighter1_1450_1618_Open_Text.style.display='none'; Codehighlighter1_1450_1618_Closed_Image.style.display='inline'; Codehighlighter1_1450_1618_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align=top><IMG id=Codehighlighter1_1450_1618_Closed_Image style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_1450_1618_Closed_Text.style.display='none'; Codehighlighter1_1450_1618_Open_Image.style.display='inline'; Codehighlighter1_1450_1618_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">if</SPAN><SPAN style="COLOR: #000000">&nbsp;((Bi.getHeight()</SPAN><SPAN style="COLOR: #000000">&gt;</SPAN><SPAN style="COLOR: #000000">120</SPAN><SPAN style="COLOR: #000000">)&nbsp;</SPAN><SPAN style="COLOR: #000000">||</SPAN><SPAN style="COLOR: #000000">&nbsp;(Bi.getWidth()</SPAN><SPAN style="COLOR: #000000">&gt;</SPAN><SPAN style="COLOR: #000000">120</SPAN><SPAN style="COLOR: #000000">))</SPAN><SPAN id=Codehighlighter1_1450_1618_Closed_Text style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff"><IMG src="http://www.blogjava.net/images/dot.gif"></SPAN><SPAN id=Codehighlighter1_1450_1618_Open_Text><SPAN style="COLOR: #000000">{<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">if</SPAN><SPAN style="COLOR: #000000">&nbsp;(Bi.getHeight()</SPAN><SPAN style="COLOR: #000000">&gt;</SPAN><SPAN style="COLOR: #000000">Bi.getWidth())<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ratio&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #000000">120.0</SPAN><SPAN style="COLOR: #000000">/</SPAN><SPAN style="COLOR: #000000">Bi.getHeight();<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">else</SPAN><SPAN style="COLOR: #000000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Ratio&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #000000">120.0</SPAN><SPAN style="COLOR: #000000">/</SPAN><SPAN style="COLOR: #000000">Bi.getWidth();<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</SPAN></SPAN><SPAN style="COLOR: #000000"><BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;AffineTransformOp&nbsp;op&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN style="COLOR: #0000ff">new</SPAN><SPAN style="COLOR: #000000">&nbsp;AffineTransformOp(AffineTransform.getScaleInstance(Ratio,&nbsp;Ratio),&nbsp;</SPAN><SPAN style="COLOR: #0000ff">null</SPAN><SPAN style="COLOR: #000000">);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Itemp&nbsp;</SPAN><SPAN style="COLOR: #000000">=</SPAN><SPAN style="COLOR: #000000">&nbsp;op.filter(Bi,&nbsp;</SPAN><SPAN style="COLOR: #0000ff">null</SPAN><SPAN style="COLOR: #000000">);<BR><IMG id=Codehighlighter1_1786_1861_Open_Image onclick="this.style.display='none'; Codehighlighter1_1786_1861_Open_Text.style.display='none'; Codehighlighter1_1786_1861_Closed_Image.style.display='inline'; Codehighlighter1_1786_1861_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align=top><IMG id=Codehighlighter1_1786_1861_Closed_Image style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_1786_1861_Closed_Text.style.display='none'; Codehighlighter1_1786_1861_Open_Image.style.display='inline'; Codehighlighter1_1786_1861_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">try</SPAN><SPAN style="COLOR: #000000">&nbsp;</SPAN><SPAN id=Codehighlighter1_1786_1861_Closed_Text style="BORDER-RIGHT: #808080 1px solid; BORDER-TOP: #808080 1px solid; DISPLAY: none; BORDER-LEFT: #808080 1px solid; BORDER-BOTTOM: #808080 1px solid; BACKGROUND-COLOR: #ffffff"><IMG src="http://www.blogjava.net/images/dot.gif"></SPAN><SPAN id=Codehighlighter1_1786_1861_Open_Text><SPAN style="COLOR: #000000">{<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/InBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ImageIO.write((BufferedImage)Itemp,&nbsp;</SPAN><SPAN style="COLOR: #000000">"</SPAN><SPAN style="COLOR: #000000">jpg</SPAN><SPAN style="COLOR: #000000">"</SPAN><SPAN style="COLOR: #000000">,&nbsp;ThF);<BR><IMG src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockEnd.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}</SPAN></SPAN><SPAN style="COLOR: #000000"><BR><IMG id=Codehighlighter1_1892_1996_Open_Image onclick="this.style.display='none'; Codehighlighter1_1892_1996_Open_Text.style.display='none'; Codehighlighter1_1892_1996_Closed_Image.style.display='inline'; Codehighlighter1_1892_1996_Closed_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ExpandedSubBlockStart.gif" align=top><IMG id=Codehighlighter1_1892_1996_Closed_Image style="DISPLAY: none" onclick="this.style.display='none'; Codehighlighter1_1892_1996_Closed_Text.style.display='none'; Codehighlighter1_1892_1996_Open_Image.style.display='inline'; Codehighlighter1_1892_1996_Open_Text.style.display='inline';" src="http://www.blogjava.net/images/OutliningIndicators/ContractedSubBlock.gif" align=top>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</SPAN><SPAN style="COLOR: #0000ff">catch</SPAN