posts - 13, comments - 12, trackbacks - 0, articles - 0
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

2006年4月14日

  • RMI: java自身提供的用在分布时对象之间的通信机制。(类似于RPC) RMI-IIOP: RMI的可移植扩展,可以实现JAVA与CORBA的集成。
  • JDBC: 用于数据库访问的通用接口。
  • JTA,JTS: 用于提供事务处理的支持。
  • JMS: java消息服务。可以连接已有的面向消息的中间件,例如:MQSeries,MSMQ。 Java Servlet: 用来扩展Web服务器功能的网络组件。基于请求/响应机制。
  • JSP: Java与HTML混合编程,类似于ASP。
  • JavaIDL: Java对COBRA的实现,允许与其他预言集成。且能让分布式对象利用CORBA提供的全面服务。所以J2EE与CORBA完全兼容。
  • Java Mail: 平台无关,协议无关地发送邮件。
  • J2EE连接器架构: 自动管理现有系统和中间件之间的诸多细节。
  • JAXP: Java操作XML。
  • JAAS: Java的用户认证支持。
  • EJB: J2EE中最重要的部分,实现组件式开发的基础。可以在多层的分布式环境中部署的服务器端软件组件。
  • JNI: (Java Native Interface) 声明Native代码,用C/C++实现它。可以实现:          

         1、 使用标准JAVA不支持的功能,例如访问Win32API。 
         2、 重用其他语言编写的库或应用程序。例如大量的C库。 
         3、 需要用低级语言编程时,例如汇编。 Oracle所实现的C底层代码与Java的无缝集成,就是JNI
                  技术的很好例证。Oracle不单使用Java界面,还支持Java编写的存储过程。 

  • JNDI: 用于访问命令和目录系统。 JNDI为底层命名或目录服务提供统一的API。可支持任何服务器名称,标准服务有:LDAP,NDS,CORBA,LDAP活动目录等。 J2EE终,可用JNDI发布下列组件:EJB,数据源(数据库),JMS消息队列。

posted @ 2007-03-20 09:35 winder 阅读(223) | 评论 (0)编辑 收藏

近期遇到需要用JS脚本统一拦截一下页面中form的submit方法以在页面隐式提交时修改请求URL简单实现如下:
var oldSubmit;
var form = document.forms[0];
if(form != null && form != 'undefined'){
        
//备份submit函数
    form.oldSubmit = form.submit;
        
//覆盖submit函数以实现拦截
    form.submit = function (){
            
//提交前做的操作..
                //掉原函数来提交
        form.oldSubmit();
    }
 
}

上面的代码在页面载入时先执行就会实现拦截,对显示的用submit按钮来提交的可以监控onsubmit事件来实现,这个方法很多没什么太大问题。

posted @ 2006-12-23 10:37 winder 阅读(5039) | 评论 (11)编辑 收藏

< html >
   
< head >
      
< meta  http-equiv ="Refresh"  content ="0;URL=./pages/login.jsp" >
   
</ head >
   
< body ></ body >
</ html >

posted @ 2006-12-06 09:38 winder 阅读(240) | 评论 (0)编辑 收藏

Tomcat 5.5把common\lib下的jta.jar删除掉了,所以用hibernate时会报java.lang.NoClassDefFoundError: javax/transaction/Synchronization的错误。

posted @ 2006-11-30 12:20 winder 阅读(229) | 评论 (0)编辑 收藏

<! DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" >
< html >
< head >
< meta  http-equiv ="Content-Type"  content ="text/html; charset=gb2312" >
< title > 计时跳转 </ title >
</ head >

< body  leftmargin ="0"  topmargin ="0" >
< table  border ="0"  align ="center" >
< tr >
< td >
< br >
< table  width ="194"  height ="113"  border ="0"  cellpadding ="0"  cellspacing ="0"   >
  
< tr >
    
< td >< href ="#" >< img  src ="images/ydzj.jpg"  width ="397"  height ="265"  border ="0" ></ a ></ td >
  
</ tr >
  
< tr >
    
< td  align ="center" >< div  id ="view" ></ div ></ td >
        
< script >
            
var  time  =   5000 ;
            
var  cc  =  time / 1000 ;
            
function  count() {
                
if (cc  >   - 1 ) {
                    
var  vv  =  document.getElementById('view');
                    vv.innerHTML 
=  ' < font color = " #0066ff "  size = " 2 " >< font color = " red " > ' + cc + ' </ font > 秒后进入新页面 </ font > ';
                    cc
-- ;
                    setTimeout(
" count() " , 1000 ); // 1秒延时
                }
else {
                    goto();
// 进入新页面
                }

            }

            
function  goto() {
                location.href
= '#';
            }

            count();
        
</ script >
  
</ tr >
</ table >
</ td >
</ tr >
</ table >
</ body >
</ html >

posted @ 2006-11-28 15:15 winder 阅读(740) | 评论 (1)编辑 收藏

1、创建新用户

useradd  [username]

2、改变文件所属组

chown  [username:groupname] [filename]

3、改变文件权限

chmod [777] [filename]

chmod [u|g|o|a] [-r|-w|x] [filename]

4、环境变量导致的 -bash: command not found 问题解决

修正主目录下.bash_profile文件内容

posted @ 2006-11-16 10:33 winder 阅读(346) | 评论 (0)编辑 收藏

     摘要: 1 /**/ /*  2   name:        SimpleMap.js  3   version:    1.0.0  4   aut...  阅读全文

posted @ 2006-07-28 13:16 winder 阅读(1059) | 评论 (0)编辑 收藏

笔记本是一个信息管理类软件,集写字板的编辑功能和数据库的管理功能于一身,特别适合收藏大量的文字资料,是个人信息管理的得力助手。
http://www.sz1001.net/soft/1907.htm

posted @ 2006-04-30 13:27 winder 阅读(198) | 评论 (0)编辑 收藏

一、概述
 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件

、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式

;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一

个配置文件来灵活地进行配置,而不需要修改应用的代码。
  
  此外,通过Log4j其他语言接口,您可以在C、C++、.Net、PL/SQL程序中使用Log4j,其语法和用法与在Java程序中

一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通过使用各种第三方扩展,您可以很方便地将

Log4j集成到J2EE、JINI甚至是SNMP应用中。

二,使用前的准备。
 1、下载log4j 地址为:http://jakarta.apache.org/log4j/docs/download.html.
 2、你可能要用到的jar文件有:
  如果需要将日志发送到邮箱,则需要javamail API,JAF API (the JavaBeans Activation Framework)

下载地址:  http://java.sun.com/products/javamail/
 http://java.sun.com/beans/glasgow/jaf.html
  如果需要jms的支持,则需要jms API 下载地址为:

http://java.sun.com/products/jms/vendors.html
三, Log4j介绍
 Log4j由三个重要的组件构成:日志信息的优先级 priority,日志信息的输出目的地Appender,日志信息的输

出格式(布局)layout。
 1、日志的优先级,
 从低到高,依次有:DEBUG,INFO,WARN,ERROR,分别用来指定这条日志信息的重要程度;如果定义了了输入的级

别为INFO,则只有等于及高于这个级别的才进行处理,此时将输入INFO,WARN,ERROR。值得注意的是,级别中还有两个关

键字,
 ALL:打印所有的日志,
 OFF:关闭所有的日志输出。
 
 2、输出端 Appender

 log4j提供了以下几种常用的输出目的地:
 org.apache.log4j.ConsoleAppender,将日志信息输出到控制台
 org.apache.log4j.FileAppender,将日志信息输出到一个文件
 org.apache.log4j.DailyRollingFileAppender,将日志信息输出到一个,并且每天输出到一个新的日志文件,

按照不同的配置可以定义每月一个日志文件,或者每周,每天,每小时,每分钟等输出一个新的日志文件。
 org.apache.log4j.RollingFileAppender,将日志信息输出到一个文件,通过指定文件的的尺寸,当文件大小

到达指定尺寸的时候会自动把文件改名,如名为example.log的文件会改名为example.log.1,同时产生一个新的

example.log文件。如果新的文件再次达到指定尺寸,又会自动把文件改名为example.log.2,同时产生一个example.log

文件。依此类推,直到example.log. MaxBackupIndex,MaxBackupIndex的值可在配置文件中定义。
 org.apache.log4j.WriterAppender,将日志信息以流格式发送到任意指定的地方。
 org.apache.log4j.jdbc.JDBCAppender,通过JDBC把日志信息输出到数据库中。
 org.apache.log4j.net.SMTPAppender,将日志信息以邮件的方式发送到指定的邮箱。

 3、输出格式(布局)layout
 通过appender可以控制输出的目的地,而如果要控制输出的格式,就可通过log4j的layout组件来实现。通过配

置文件定义一个appender的输出格式,Log4j提供的布局模式有以下几种:
 org.apache.log4j.ConsoleAppender,输出到控制台
 org.apache.log4j.HTMLLayout,以HTML表格形式布局
 org.apache.log4j.PatternLayout,可以灵活地指定布局模式
 org.apache.log4j.SimpleLayout,包含日志信息的级别和信息字符串

 值得一提的是org.apache.log4j.PatternLayout 以Pattern方式的布局,使用Pattern的方式来指定布局。

pattern 的参数如下:ConversionPattern参数的格式含义
 格式名 含义
 %c 输出日志信息所属的类的全名
 %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd

HH:mm:ss },输出类似:2002-10-18- 22:10:28 ;比如 %d{HH:mm:ss,SSS} 或 %d{dd MMM yyyy HH:mm:ss,SSS}.
格式可以参考 java类 SimpleDateFormat,不过 按照此类的设置会影响速度。你可以选择更快的方式 %d{ISO8601},

%d{ABSOLUTE}, %d{RELATIVE}.或者使用log4j的ISO8601DateFormat, AbsoluteTimeDateFormat,

RelativeTimeDateFormat 和 DateTimeDateFormat 方式.
 %f 输出日志信息所属的类的类名
 %l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
 %m 输出代码中指定的信息,如log(message)中的message
 %M 输出日志信息中所发生的方法名。
 %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
 %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
 %r 输出自应用启动到输出该日志信息所耗费的毫秒数
 %t 输出产生该日志事件的线程名
四、使用
 4.1.1 SimpleLayout 和 FileAppender 方式
以下是以文件的输出方式Appender和简单的布局方式SimpleLayout的例子:

import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.SimpleLayout;
import org.apache.log4j.FileAppender;
public class simpandfile {
   static Logger logger = Logger.getLogger(simpandfile.class);
   public static void main(String args[]) {
      SimpleLayout layout = new SimpleLayout();

      FileAppender appender = null;
      try {
         appender = new FileAppender(layout,"output1.txt",false);
      } catch(Exception e) {}

      logger.addAppender(appender);
      logger.setLevel((Level) Level.DEBUG);

      logger.debug("Here is some DEBUG");
      logger.info("Here is some INFO");
      logger.warn("Here is some WARN");
      logger.error("Here is some ERROR");
      logger.fatal("Here is some FATAL");
   }
}
       
 首先实例化Logger对象。static Logger logger = Logger.getLogger(simpandfile.class);然后指定输出的方

式和布局 appender = new FileAppender(layout,"output1.txt",false);logger.addAppender(appender);
最后定义级别:logger.addAppender(appender);这样完成了log4j日志类的初始化.接着就可以进行日志输出了。这就是

log4j日志类的使用时的一般顺序。因以下程序比较简单,特别的地方将会有注释,将不再解释。


 4.1.2. HTMLLayout 和 WriterAppender


import java.io.*;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.HTMLLayout;
import org.apache.log4j.WriterAppender;
public class htmlandwrite {
   static Logger logger = Logger.getLogger(htmlandwrite.class);
   public static void main(String args[]) {
      HTMLLayout layout = new HTMLLayout();

      WriterAppender appender = null;
      try {
         FileOutputStream output = new FileOutputStream("output2.html");
         appender = new WriterAppender(layout,output);
      } catch(Exception e) {}

      logger.addAppender(appender);
      logger.setLevel((Level) Level.DEBUG);

      logger.debug("Here is some DEBUG");
      logger.info("Here is some INFO");
      logger.warn("Here is some WARN");
      logger.error("Here is some ERROR");
      logger.fatal("Here is some FATAL");
   }
}
       
 

4.1.3. PatternLayout and ConsoleAppender

import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.PatternLayout;
import org.apache.log4j.ConsoleAppender;
public class consandpatt {
   static Logger logger = Logger.getLogger(consandpatt.class);
   public static void main(String args[]) {

      // Note, %n is newline
      String pattern =  "Milliseconds since program start: %r %n";
             pattern += "Classname of caller: %C %n";
             pattern += "Date in ISO8601 format: %d{ISO8601} %n";
             pattern += "Location of log event: %l %n";
             pattern += "Message: %m %n %n";
     
      PatternLayout layout = new PatternLayout(pattern);
      ConsoleAppender appender = new ConsoleAppender(layout);

      logger.addAppender(appender);
      logger.setLevel((Level) Level.DEBUG);

      logger.debug("Here is some DEBUG");
      logger.info("Here is some INFO");
      logger.warn("Here is some WARN");
      logger.error("Here is some ERROR");
      logger.fatal("Here is some FATAL");
   }
}

4.2 使用配置文件来定义输出Appender和布局格式Layout
 log4j支持两种方式的配置方式,.properties 二进制文件和xml文件的方式。我们简单讲一下.properties的配

置方式后,将主要讨论xml文件的配置方式。
 
 4.2.1  我们将以.properties文件的格式定义两种输出方式,一种是输出到文件中,另一种是输出到数据库中


 
 首先定义simple.properties文件,文件定义如下:
 
 #定义了两个输出端
 log4j.rootLogger = INFO,f,db


 # 定义f输出到文件,并且文件是随着大小而增加的
 log4j.appender.f = org.apache.log4j.RollingFileAppender 
 log4j.appender.f.File = F:\\nepalon\\classes\\test1.log 
 log4j.appender.f.MaxFileSize = 1000KB 
 log4j.appender.f.MaxBackupIndex = 3 
 log4j.appender.f.layout = org.apache.log4j.PatternLayout
 
 log4j.appender.f.layout.ConversionPattern = %d{yyyy-MM-dd hh:mm:ss}:%p %t %c - %m%n

 #定义db输出到数据库
 log4j.appender.db = org.apache.log4j.jdbc.JDBCAppender
 log4j.appender.db.BufferSize = 40
 log4j.appender.db.Driver = com.microsoft.jdbc.sqlserver.SQLServerDriver
 log4j.appender.db.URL = jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=test
 log4j.appender.db.User = sa
 log4j.appender.db.Password =
 log4j.appender.db.layout = org.apache.log4j.PatternLayout
 log4j.appender.db.layout.ConversionPattern = INSERT INTO log4j (createDate, thread, priority,

category, message) values('%d{ISO8601}', '%t', '%-5p', '%c', '%m')

 然后程序中将引用这配置文件。定义如下:

 import org.apache.log4j.Logger;
 import org.apache.log4j.xml.DOMConfigurator;

 public class Test {
 
     static Logger logger = Logger.getLogger(Test.class);
     public static void main(String args[]) {
         //以property方式读到配置文件。
   PropertyConfigurator.configure ( "simple.properties" ) ;
 
         logger.debug("Here is some DEBUG");
         logger.info("Here is some INFO");
         logger.warn("Here is some WARN");
         logger.error("Here is some ERROR");
         logger.fatal("Here is some FATAL");
     }
 }


 4.2.2 以xml配置

 程序如下:
 import org.apache.log4j.Logger;
 import org.apache.log4j.xml.DOMConfigurator;

 public class Test {
 
     static Logger logger = Logger.getLogger(Test.class);
     public static void main(String args[]) {
         //以XML方式读到配置文件。
    DOMConfigurator.configure("xmllog4jconfig.xml");

 
         logger.debug("Here is some DEBUG");
         logger.info("Here is some INFO");
         logger.warn("Here is some WARN");
         logger.error("Here is some ERROR");
         logger.fatal("Here is some FATAL");
     }
 }


 xmllog4jconfig.xml 如下:

 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

 <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
       
   <appender name="appender" class="org.apache.log4j.FileAppender">
      <param name="File" value="Indentify-Log.txt"/>
      <param name="Append" value="false"/>
      <layout class="org.apache.log4j.PatternLayout">
         <param name="ConversionPattern" value="%d [%t] %p - %m%n"/>
      </layout>
   </appender>

   <root>
      <priority value ="debug"/>
      <appender-ref ref="appender"/>
   </root>

 </log4j:configuration>


 对比properties方式和xml方式,可以看出他们程序中,除了定义读取配置文件的方式不同外,其它的根本就没

有区别了,这也就是log4j的魅力所在了,不需要改变程序,只需要通过改变定义的配置文件,我们就可以控制日志的输

出方式,是否输出,输出格式。我们可以通过定义不同的xml文件来控制输出方式.以下是各种输出方式与布局的例子。
 
 4.2.3 比较简单的一个。
 <?xml version="1.0" encoding="gb2312" ?>
 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
 <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
 <!--
  配置输出的日志目录为在控制台。
  格式采用为PatternLoyout,并且样式为:%d{ISO8601} %r [%c :: %p %m]%n
 -->  
   <appender name="CA" class="org.apache.log4j.ConsoleAppender">   
      <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%d{ISO8601} %r [%c :: %p %m]%n"/>
      </layout>
   </appender>

   <root>
      <priority value ="debug"/>
     <appender-ref ref="CA"/>
   </root>

 </log4j:configuration>
 
 4.2.4 文件的输出 pattern的布局
 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

 <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
       
   <appender name="appender" class="org.apache.log4j.FileAppender">
      <param name="File" value="Indentify-Log.txt"/>
      <param name="Append" value="false"/>
      <layout class="org.apache.log4j.PatternLayout">
         <param name="ConversionPattern" value="%d [%t] %p - %m%n"/>
      </layout>
   </appender>

   <root>
      <priority value ="debug"/>
     <appender-ref ref="appender"/>
   </root>

 </log4j:configuration>

 4.2.5 控制台的输出 和简单的布局
 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

 <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
       
   <appender name="ConsoleAppender" class="org.apache.log4j.ConsoleAppender">
      <layout class="org.apache.log4j.SimpleLayout"/>
   </appender>

   <root>
     <priority value ="debug" />
      <appender-ref ref="ConsoleAppender"/>
   </root>

 </log4j:configuration>

 4.2.6 定义三种输出方式,按照不同的级别,选择不同的输出方式.debug,info,级别通过System.out来打印。
 WARN,FATAL通过System.err来输出。ERROR,FATAL发送到邮箱。

 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
 <log4j:configuration>
     <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
         <param name="Target" value="System.out" />
         <layout class="org.apache.log4j.PatternLayout">
              <param name="ConversionPattern" value="[%d{ISO8601}] %-5p %c %m %n" />
          </layout>
         <filter class="org.apache.log4j.varia.LevelRangeFilter">
              <param name="LevelMin" value="DEBUG"/>
              <param name="LevelMax" value="INFO"/>
         </filter>
     </appender>
     <appender name="STDERR"  class="org.apache.log4j.ConsoleAppender">
         <param name="Target" value="System.err" />
         <layout class="org.apache.log4j.PatternLayout">
              <param name="ConversionPattern" value="[%d{ISO8601}] %-5p %c %m %n" />
         </layout>
         <filter class="org.apache.log4j.varia.LevelRangeFilter">
              <param name="LevelMin" value="WARN"/>
             <param name="LevelMax" value="FATAL"/>
         </filter>
     </appender>

     <!--                          -->
     <!-- Declare the SMTPAppender -->
     <!--                          -->
     <appender name="EMAIL"  class="org.apache.log4j.net.SMTPAppender">
         <param name="BufferSize" value="512" />
         <param name="SMTPHost" value="mail.suiyuanwu.com" />
         <param name="From" value="log4j@server5" />
         <param name="To" value="web@suiyuanwu.com" />
         <param name="Subject" value="[SMTPAppender] Application message" />
         <layout class="org.apache.log4j.PatternLayout">
              <param name="ConversionPattern" value="[%d{ISO8601}]%n%n%-5p%n%n%c%n%n%m%n%n" />
         </layout>
         <filter class="org.apache.log4j.varia.LevelRangeFilter">
              <param name="LevelMin" value="ERROR"/>
              <param name="LevelMax" value="FATAL"/>
         </filter>
     </appender>

     <!--                           -->
     <!-- setup log4j's root logger -->
     <!--                           -->
     <root>
         <level value="all" />
         <appender-ref ref="STDOUT"/>
         <appender-ref ref="STDERR"/>
         <appender-ref ref="EMAIL" />
     </root>
 </log4j:configuration>
   
五、参考资料
 1.http://www.vipan.com/htdocs/log4jhelp.html
         Don't Use System.out.println! Use Log4j - Vipan Singla
 2.http://jakarta.apache.org/log4j/docs/manual.html
  Short introduction to log4j - Ceki Gülcü - March 2002
 3.http://www-128.ibm.com/developerworks/cn/java/jw-log4j/
 log4j提供了对日志记录的控制
 4.http://logging.apache.org/log4j/docs/documentation.html
 log4j提供的文档。

posted @ 2006-04-24 10:34 winder 阅读(363) | 评论 (0)编辑 收藏

1,全英文名电子书网站
http://lab.lpicn.org/pub/books/

2,中国IT实验室的JAVA下载
http://download.chinaitlab.com/special/javaebook.htm

3,Java爱好者
http://www.javafan.net/download.jsp?ClassID=1

4,爱书吧
http://www.ibook8.com

5,   太阳花
http://www.javadown.com.cn

posted @ 2006-04-16 10:27 winder 阅读(685) | 评论 (0)编辑 收藏

为什么GenericServlet在init(ServletConfig config)基础上增加了一个init()方法? 
 
  init()方法被GenericServlet.init(ServletConfig config)方法调用。
  
  init()方法方便了开发人员定制Servlet的初始化,而无须去维护ServletConfig对象的存储工作。
  
  重写GenericServlet.init(ServletConfig config)必须要显示的调用super.init(config)方法。
  
  ServletContext.getContect(java.lang.String uripath)的作用是什么?
  
  返回同一Server中指定的path对应的ServletContext对象,通过该对象可以实现与Server中的其他Context打交道。
  
  uripath必须是以"/"开始(该路径的含义是相对于整个Servlet文档的根路径,而不是当前ServletContext的根路径)。
  
  Servlet生命周期是什么?
  
  一般的Servlet(GenericServlet,即与协议无关的Servlet)的生命周期:init() --> GenericServlet.service(ServletRequest req, ServletResponse res) --> destroy.
  
  HttpServlet的生命周期: init() --> GenericServlet.service(ServletRequest req, ServletResponse res)---> service(HttpServletRequest req, HttpServletResponse resp) --> doXXXX()-->destroy.
  
  有没有必要重写GenericServlet.service()方法?
  
  对于HttpServlet来说没有必要。只需要重写它的doXXXX()方法就可以了。HttpServlet中service()方法会自动的根据用户请求类型把请求转发给相应的doXXXX()方法(例如doGet()方法)。
  
  ServletRequest.getReader()和ServletRequest.getInputStream()如何使用?
  
  注意两个方法不能同时使用。
  
  ServletRequest.getRealPath(String path)方法已经不推荐使用。
  
  请使用ServletContext.getRealPath(String path)方法。
  
  ServletResponse缺省的字符集(charset)是什么?

  ServletResponse缺省的字符集(charset)是ISO-8859-1,可以通过setContentType(java.lang.String)方法改变新的字符集。
  
  例如:setContentType("text/html; charset=Shift_JIS").
  
  关于字符集信息,可以浏览RFC 2045
  
  HttpServletRequest.getRequestURI()和HttpServletRequest.getRequestURL()区别是什么? 
 
  request.getRequestURI() 返回值类似:/xuejava/requestdemo.jsp
  
  request.getRequestURL() 返回值类似:http://localhost:8080/xuejava/requestdemo.jsp
  
  HttpServletRequest.encodeURL()和HttpServletRequest.encodeRedirectURL(()区别是什么?为什么要有两个不同的方法呢?
  
  当用URL-rewriting方式来管理Session的时候,需要用到以上的两个方法。
  
  两个方法的不同点是:两个方法确定是否需要包含session ID的逻辑不同。
  
  在调用HttpServletResponse.sendRedirect前,应该先调用encodeRedirectURL()方法,否则可能会丢失Sesssion信息。 ...
  
  如何使你的Servlet或者JSP实现Single Thread Model?  

  对于Servlet实现javax.single.SingleThreadModel接口。
  
  对于JSP,在Page Directive中写如下的语句<%@ page isThreadSafe="false" %>
  
  JSP Tag 和 JSP XML-based Tag
  
  ...
  
  如何把某一个JSP Page定义成为Error Page?为什么要这样做?
  
  实现方法: <%@ page isErrorPage="true" %>
  
  为什么? 因为需要获取Exception 对象(缺省情况下,在JSP Page中是不能直接使用“隐含对象” exception的)。
  
  JSP Page的执行顺序是如何的?
  
  JSP Page的执行顺序如下:
  
  JSP Page Translation. JSP Page --> Servlet source code.
  JSP Page Compilation. Servlet source code --> Servlet class.
  Load Class(First time or the server restarted)
  
  Create instance(可能会很多次,如果JSP Page中声明了<%@ page isThreadSafe="false" %>)
  
  Call jspInit method(一般的JSP Page都没有重写这个方法,重写需要在声明语句段中)。
  
  Call _jspService method(类似与一般HttpServlet的doGet和doPost方法,但是可以同时用来处理Post和Getq请求)。
  
  Call jspDestroy method(Server在卸载Servet的时候,例如当Servlet很久没有使用的情况)。
  
  JSP Page中有哪些隐含对象(Implicity Object)?各自的类型和作用是什么?
  
  request --
  reponse --
  session --
  application --
  out --
  page --
  pagecontext --
  exception -- 只有在当前JSP Page为Error Page的时候才有效。
  config --
  
  <jsp:include page="/foo/foo.jsp" %> 和 <@ include file="/foo/foo.jsp" %>的区别是什么?
  
  <jsp:include ... -- request time.
  <@ include ... -- Page translation time.
  
  Servlets/JSP Container(Engine)有几种运行方式?
  
  Standalone
  Tomcat standalone mode
  In-process
  Tomcat running inside Apache Web Server.
  Out-of-process
  Apache + mod_jk + Tomcat
  
  Servlet,Servlet开发人员,Servlet API, Servlet Container的关系是什么?
  
  Servlet,Servlet开发人员 --->Servlet API --> Servlet Container
  The parts of an HTTP message
  
  Message part Description
  The initial line: Specifies the purpose of the request or response message
  例子:GET /reports/sales/index.html HTTP/1.0
  The header section:Specifies the meta-information, such as size, type, and encoding,
  about the content of the message
  A blank line:
  An optional message body: The main content of the request or response message
  
  下面是一个Response的例子:
  
  HTTP/1.0 200 OK
  Date: Tue, 01 Dec 2001 23:59:59 GMT
  Content-Type: text/html
  Content-Length: 52
  
  <html>
  <body>
  <h1>Hello, John!</h1>
  </body>
  </html>
  
  HTTP规范中定义了哪些方法?各自有什么用途?
  
  GET
  HEAD
  POST
  从 Http 1.1规范开始,增加了以下的方法:
  
  PUT
  OPTIONS
  TRACE
  DELETE
  CONNECT
  
  ServetRequest中为什么要定义:getContentType(),getContentLength()方法。
  
  根据HTTP协议规范,Request 和 Response一样也有这些必不可少的内容!
  
  所以需要首先了解 HTTP Message的概念和其内容的格式,这些东西对于Request和Reponse是一样的。
  
  对于GET方式发送的请求,其内容类型为:null
  
  对于POST方式发送的请求,其内容类型为:application/x-www-form-urlencoded
  
  POST方式发送请求的内容类似于:username=xuejava.
  
  RequestDispatcher.forward()和HttpServletResponse.sendRedirect()的区别是什么?
  
  RequestDispatcher.forward()是在服务器端运行;HttpServletResponse.sendRedirect()是通过向客户浏览器发送命令来完成。
  
  所以RequestDispatcher.forward()对于浏览器来说是“透明的”;而HttpServletResponse.sendRedirect()则不是。
  
  另外,还要注意RequestDispatcher.forward()在调用的时候Response不能已经Commit了(Response.isCommitted())。
  
  ServletContext.getRequestDispatcher(String url)和ServletRequest.getRequestDispatcher(String url)的区别是什么?为什么?
  
  ServletContext.getRequestDispatcher(String url)中的url只能使用绝对路径;而ServletRequest.getRequestDispatcher(String url)中的url可以使用相对路径。
  
  因为ServletRequest具有相对路径的概念;而ServletContext对象无次概念。
  
  如何把请求转移到另外一个Web App中的某个地址?
  
  ServletContext.getRequestDispatcher(String url)和ServletRequest.getRequestDispatcher(String url)只能把请求转移到同一个Web App中的地址。
  
  如果需要把请求转移到另外一个Web App中的某个地址,可以按下面的做法:
  
  1. 获得另外一个Web App的ServletConext对象(currentServletContext.getContext(uripath)).
  
  2. 调用ServletContext.getRequestDispatcher(String url)方法。

posted @ 2006-04-15 22:00 winder 阅读(114) | 评论 (0)编辑 收藏

     摘要: 1 定义头和根元素部署描述符文件就像所有XML文件一样,必须以一个XML头开始。这个头声明可以使用的XML版本并给出文件的字符编码。DOCYTPE声明必须立即出现在此头之后。这个声明告诉服务器适用的servlet规范的版本(如2.2或2.3)并指定管理此文件其余部分内容的语法的DTD(Document Type Definition,文档类型定义)。所有部署描述符文件的顶层(根)元素为web-ap...  阅读全文

posted @ 2006-04-14 09:13 winder 阅读(655) | 评论 (0)编辑 收藏