都市激情亚洲色图,亚洲国产成人私人影院tom,黄色大片在线看http://www.aygfsteel.com/ocean07000814/category/15457.html共同探討STRUTS#HIBERNATE#SPRING#EJB等技術zh-cnThu, 03 Mar 2011 11:38:44 GMTThu, 03 Mar 2011 11:38:44 GMT60Log4J的配置文件詳解http://www.aygfsteel.com/ocean07000814/articles/345458.html非洲小白臉非洲小白臉Wed, 02 Mar 2011 01:49:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/345458.htmlhttp://www.aygfsteel.com/ocean07000814/comments/345458.htmlhttp://www.aygfsteel.com/ocean07000814/articles/345458.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/345458.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/345458.htmlLog4J的配置文件(Configuration File)就是用來設置記錄器的級別、存放器和布局的,它可接key=value格式的設置或xml格式的設置信息。通過配置,可以創建出Log4J的運行環境。

1. 配置文件
Log4J配置文件的基本格式如下:

#配置根Logger
log4j.rootLogger  =   [ level ]   ,  appenderName1 ,  appenderName2 ,  …

#配置日志信息輸出目的地Appender
log4j.appender.appenderName  =  fully.qualified.name.of.appender.class
  log4j.appender.appenderName.option1  =  value1
  …
  log4j.appender.appenderName.optionN  =  valueN

#配置日志信息的格式(布局)
log4j.appender.appenderName.layout  =  fully.qualified.name.of.layout.class
  log4j.appender.appenderName.layout.option1  =  value1
  …
  log4j.appender.appenderName.layout.optionN  =  valueN 
其中 [level] 是日志輸出級別,共有5級:

FATAL       0 
ERROR      3 
WARN       4 
INFO         6 
DEBUG      7
 
Appender 為日志輸出目的地,Log4j提供的appender有以下幾種:

org.apache.log4j.ConsoleAppender(控制臺),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件),
org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件),
org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方)
Layout:日志輸出格式,Log4j提供的layout有以下幾種:


org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串),
org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息)
打印參數: Log4J采用類似C語言中的printf函數的打印格式格式化日志信息,如下:


    %m   輸出代碼中指定的消息
  %p   輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL
  %r   輸出自應用啟動到輸出該log信息耗費的毫秒數
  %c   輸出所屬的類目,通常就是所在類的全名
  %t   輸出產生該日志事件的線程名
  %n   輸出一個回車換行符,Windows平臺為“\r\n”,Unix平臺為“\n”
  %d   輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},輸出類似:2002年10月18日  22 : 10 : 28 , 921 
  %l   輸出日志事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(TestLog4.java: 10 ) 
2. 在代碼中初始化Logger:
1)在程序中調用BasicConfigurator.configure()方法:給根記錄器增加一個ConsoleAppender,輸出格式通過PatternLayout設為"%-4r [%t] %-5p %c %x - %m%n",還有根記錄器的默認級別是Level.DEBUG.
2)配置放在文件里,通過命令行參數傳遞文件名字,通過PropertyConfigurator.configure(args[x])解析并配置;
3)配置放在文件里,通過環境變量傳遞文件名等信息,利用log4j默認的初始化過程解析并配置;
4)配置放在文件里,通過應用服務器配置傳遞文件名等信息,利用一個特殊的servlet來完成配置。

3. 為不同的 Appender 設置日志輸出級別:
當調試系統時,我們往往注意的只是異常級別的日志輸出,但是通常所有級別的輸出都是放在一個文件里的,如果日志輸出的級別是BUG!?那就慢慢去找吧。
這時我們也許會想要是能把異常信息單獨輸出到一個文件里該多好啊。當然可以,Log4j已經提供了這樣的功能,我們只需要在配置中修改Appender的Threshold 就能實現,比如下面的例子:

[配置文件]


 ### set log levels ###
log4j.rootLogger = debug ,  stdout ,  D ,  E

### 輸出到控制臺 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n

### 輸出到日志文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG ## 輸出DEBUG級別以上的日志
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 保存異常信息到單獨文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/error.log ## 異常日志文件名
log4j.appender.D.Append = true
log4j.appender.D.Threshold = ERROR ## 只輸出ERROR級別以上的日志!!!
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
[代碼中使用]


  public   class  TestLog4j   {
     public   static   void  main(String[] args)   {
        PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " );
        Logger logger  =  Logger.getLogger(TestLog4j. class );
        logger.debug( " debug " );
        logger.error( " error " );
    }
}
運行一下,看看異常信息是不是保存在了一個單獨的文件error.log中

log4j.properties 使用
一.參數意義說明
輸出級別的種類
ERROR、WARN、INFO、DEBUG
ERROR 為嚴重錯誤 主要是程序的錯誤
WARN 為一般警告,比如session丟失
INFO 為一般要顯示的信息,比如登錄登出
DEBUG 為程序的調試信息
配置日志信息輸出目的地
log4j.appender.appenderName = fully.qualified.name.of.appender.class
1.org.apache.log4j.ConsoleAppender(控制臺)
2.org.apache.log4j.FileAppender(文件)
3.org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件)
4.org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件)
5.org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方)
配置日志信息的格式
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
1.org.apache.log4j.HTMLLayout(以HTML表格形式布局),
2.org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
3.org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串),
4.org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息)
控制臺選項
Threshold=DEBUG:指定日志消息的輸出最低層次。
ImmediateFlush=true:默認值是true,意謂著所有的消息都會被立即輸出。
Target=System.err:默認情況下是:System.out,指定輸出控制臺
FileAppender 選項
Threshold=DEBUF:指定日志消息的輸出最低層次。
ImmediateFlush=true:默認值是true,意謂著所有的消息都會被立即輸出。
File=mylog.txt:指定消息輸出到mylog.txt文件。
Append=false:默認值是true,即將消息增加到指定文件中,false指將消息覆蓋指定的文件內容。
RollingFileAppender 選項
Threshold=DEBUG:指定日志消息的輸出最低層次。
ImmediateFlush=true:默認值是true,意謂著所有的消息都會被立即輸出。
File=mylog.txt:指定消息輸出到mylog.txt文件。
Append=false:默認值是true,即將消息增加到指定文件中,false指將消息覆蓋指定的文件內容。
MaxFileSize=100KB: 后綴可以是KB, MB 或者是 GB. 在日志文件到達該大小時,將會自動滾動,即將原來的內容移到mylog.log.1文件。
MaxBackupIndex=2:指定可以產生的滾動文件的最大數。
log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n
日志信息格式中幾個符號所代表的含義:
 -X號: X信息輸出時左對齊;
 %p: 輸出日志信息優先級,即DEBUG,INFO,WARN,ERROR,FATAL,
 %d: 輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921
 %r: 輸出自應用啟動到輸出該log信息耗費的毫秒數
 %c: 輸出日志信息所屬的類目,通常就是所在類的全名
 %t: 輸出產生該日志事件的線程名
 %l: 輸出日志事件的發生位置,相當于%C.%M(%F:%L)的組合,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main (TestLog4.java:10)
 %x: 輸出和當前線程相關聯的NDC(嵌套診斷環境),尤其用到像java servlets這樣的多客戶多線程的應用中。
 %%: 輸出一個"%"字符
 %F: 輸出日志消息產生時所在的文件名稱
 %L: 輸出代碼中的行號
 %m: 輸出代碼中指定的消息,產生的日志具體信息
 %n: 輸出一個回車換行符,Windows平臺為"\r\n",Unix平臺為"\n"輸出日志信息換行
 可以在%與模式字符之間加上修飾符來控制其最小寬度、最大寬度、和文本的對齊方式。如:
 1)%20c:指定輸出category的名稱,最小的寬度是20,如果category的名稱小于20的話,默認的情況下右對齊。
 2)%-20c:指定輸出category的名稱,最小的寬度是20,如果category的名稱小于20的話,"-"號指定左對齊。
 3)%.30c:指定輸出category的名稱,最大的寬度是30,如果category的名稱大于30的話,就會將左邊多出的字符截掉,但小于30的話也不會有空格。
 4)%20.30c:如果category的名稱小于20就補空格,并且右對齊,如果其名稱長于30字符,就從左邊較遠輸出的字符截掉。
二.文件配置Sample1
log4j.rootLogger=DEBUG,A1,R
#log4j.rootLogger=INFO,A1,R
# ConsoleAppender 輸出
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n
# File 輸出 一天一個文件,輸出路徑可以定制,一般在根路徑下
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.File=blog_log.txt
log4j.appender.R.MaxFileSize=500KB
log4j.appender.R.MaxBackupIndex=10
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%c] [%p] - %m%n
文件配置Sample2
下面給出的Log4J配置文件實現了輸出到控制臺,文件,回滾文件,發送日志郵件,輸出到數據庫日志表,自定義標簽等全套功能。
log4j.rootLogger=DEBUG,CONSOLE,A1,im
#DEBUG,CONSOLE,FILE,ROLLING_FILE,MAIL,DATABASE
log4j.addivity.org.apache=true
###################
# Console Appender
###################
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.Threshold=DEBUG
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n
#####################
# File Appender
#####################
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=file.log
log4j.appender.FILE.Append=false
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
# Use this layout for LogFactor 5 analysis
########################
# Rolling File
########################
log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
log4j.appender.ROLLING_FILE.Threshold=ERROR
log4j.appender.ROLLING_FILE.File=rolling.log
log4j.appender.ROLLING_FILE.Append=true
log4j.appender.ROLLING_FILE.MaxFileSize=10KB
log4j.appender.ROLLING_FILE.MaxBackupIndex=1
log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
####################
# Socket Appender
####################
log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender
log4j.appender.SOCKET.RemoteHost=localhost
log4j.appender.SOCKET.Port=5001
log4j.appender.SOCKET.LocationInfo=true
# Set up for Log Facter 5
log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout
log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n
########################
# Log Factor 5 Appender
########################
log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000
########################
# SMTP Appender
#######################
log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
log4j.appender.MAIL.Threshold=FATAL
log4j.appender.MAIL.BufferSize=10
log4j.appender.MAIL.From=chenyl@yeqiangwei.com
log4j.appender.MAIL.SMTPHost=mail.hollycrm.com
log4j.appender.MAIL.Subject=Log4J Message
log4j.appender.MAIL.To=chenyl@yeqiangwei.com
log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
########################
# JDBC Appender
#######################
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
log4j.appender.DATABASE.user=root
log4j.appender.DATABASE.password=
log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n')
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=SampleMessages.log4j
log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
###################
#自定義Appender
###################
log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
log4j.appender.im.host = mail.cybercorlin.net
log4j.appender.im.username = username
log4j.appender.im.password = password
log4j.appender.im.recipient = corlin@yeqiangwei.com
log4j.appender.im.layout=org.apache.log4j.PatternLayout
log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
三.高級使用
實驗目的:
 1.把FATAL級錯誤寫入2000NT日志
 2. WARN,ERROR,FATAL級錯誤發送email通知管理員
 3.其他級別的錯誤直接在后臺輸出
實驗步驟:
 輸出到2000NT日志
 1.把Log4j壓縮包里的NTEventLogAppender.dll拷到WINNT\SYSTEM32目錄下
 2.寫配置文件log4j.properties
# 在2000系統日志輸出
 log4j.logger.NTlog=FATAL, A8
 # APPENDER A8
 log4j.appender.A8=org.apache.log4j.nt.NTEventLogAppender
 log4j.appender.A8.Source=JavaTest
 log4j.appender.A8.layout=org.apache.log4j.PatternLayout
 log4j.appender.A8.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
3.調用代碼:
 Logger logger2 = Logger.getLogger("NTlog"); //要和配置文件中設置的名字相同
 logger2.debug("debug!!!");
 logger2.info("info!!!");
 logger2.warn("warn!!!");
 logger2.error("error!!!");
 //只有這個錯誤才會寫入2000日志
 logger2.fatal("fatal!!!");
發送email通知管理員:
 1. 首先下載JavaMail和JAF,
  http://java.sun.com/j2ee/ja/javamail/index.html
  http://java.sun.com/beans/glasgow/jaf.html
 在項目中引用mail.jar和activation.jar。
 2. 寫配置文件
 # 將日志發送到email
 log4j.logger.MailLog=WARN,A5
 #  APPENDER A5
 log4j.appender.A5=org.apache.log4j.net.SMTPAppender
 log4j.appender.A5.BufferSize=5
 log4j.appender.A5.To=chunjie@yeqiangwei.com
 log4j.appender.A5.From=error@yeqiangwei.com
 log4j.appender.A5.Subject=ErrorLog
 log4j.appender.A5.SMTPHost=smtp.263.net
 log4j.appender.A5.layout=org.apache.log4j.PatternLayout
 log4j.appender.A5.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
 3.調用代碼:
 //把日志發送到mail
 Logger logger3 = Logger.getLogger("MailLog");
 logger3.warn("warn!!!");
 logger3.error("error!!!");
 logger3.fatal("fatal!!!");
在后臺輸出所有類別的錯誤:
 1. 寫配置文件
 # 在后臺輸出
 log4j.logger.console=DEBUG, A1
 # APPENDER A1
 log4j.appender.A1=org.apache.log4j.ConsoleAppender
 log4j.appender.A1.layout=org.apache.log4j.PatternLayout
 log4j.appender.A1.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
 2.調用代碼
 Logger logger1 = Logger.getLogger("console");
 logger1.debug("debug!!!");
 logger1.info("info!!!");
 logger1.warn("warn!!!");
 logger1.error("error!!!");
 logger1.fatal("fatal!!!");
--------------------------------------------------------------------
 全部配置文件:log4j.properties
 # 在后臺輸出
 log4j.logger.console=DEBUG, A1
 # APPENDER A1
 log4j.appender.A1=org.apache.log4j.ConsoleAppender
 log4j.appender.A1.layout=org.apache.log4j.PatternLayout
 log4j.appender.A1.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
# 在2000系統日志輸出
 log4j.logger.NTlog=FATAL, A8
 # APPENDER A8
 log4j.appender.A8=org.apache.log4j.nt.NTEventLogAppender
 log4j.appender.A8.Source=JavaTest
 log4j.appender.A8.layout=org.apache.log4j.PatternLayout
 log4j.appender.A8.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
# 將日志發送到email
 log4j.logger.MailLog=WARN,A5
 #  APPENDER A5
 log4j.appender.A5=org.apache.log4j.net.SMTPAppender
 log4j.appender.A5.BufferSize=5
 log4j.appender.A5.To=chunjie@yeqiangwei.com
 log4j.appender.A5.From=error@yeqiangwei.com
 log4j.appender.A5.Subject=ErrorLog
 log4j.appender.A5.SMTPHost=smtp.263.net
 log4j.appender.A5.layout=org.apache.log4j.PatternLayout
 log4j.appender.A5.layout.ConversionPattern=%-4r %-5p [%t] %37c %3x - %m%n
全部代碼:Log4jTest.java
 
/*
  * 創建日期 2003-11-13
  */
 package edu.bcu.Bean;
 import org.apache.log4j.*;
 //import org.apache.log4j.nt.*;
 //import org.apache.log4j.net.*;
 /**
  * @author yanxu
  */
 public class Log4jTest
 {
  public static void main(String args[])
  {
   PropertyConfigurator.configure("log4j.properties");
   //在后臺輸出
   Logger logger1 = Logger.getLogger("console");
   logger1.debug("debug!!!");
   logger1.info("info!!!");
   logger1.warn("warn!!!");
   logger1.error("error!!!");
   logger1.fatal("fatal!!!");
//在NT系統日志輸出
   Logger logger2 = Logger.getLogger("NTlog");
   //NTEventLogAppender nla = new NTEventLogAppender();
   logger2.debug("debug!!!");
   logger2.info("info!!!");
   logger2.warn("warn!!!");
   logger2.error("error!!!");
   //只有這個錯誤才會寫入2000日志
   logger2.fatal("fatal!!!");
//把日志發送到mail
   Logger logger3 = Logger.getLogger("MailLog");
   //SMTPAppender sa = new SMTPAppender();
   logger3.warn("warn!!!");
   logger3.error("error!!!");
   logger3.fatal("fatal!!!");
  }
 }

 

本文出處:http://blog.csdn.net/azheng270/archive/2008/03/12/2173430.aspx



非洲小白臉 2011-03-02 09:49 發表評論
]]>
POI通過讀取Excel模板生成Excel文件http://www.aygfsteel.com/ocean07000814/articles/344865.html非洲小白臉非洲小白臉Tue, 22 Feb 2011 09:48:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/344865.htmlhttp://www.aygfsteel.com/ocean07000814/comments/344865.htmlhttp://www.aygfsteel.com/ocean07000814/articles/344865.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/344865.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/344865.html/**  
  •      * 導出  
  •      * @param mapping  
  •      * @param form  
  •      * @param request  
  •      * @param response  
  •      * @return  
  •      */  
  •     public ActionForward export(ActionMapping mapping, ActionForm form,   
  •             HttpServletRequest request, HttpServletResponse response) {   
  •            
  •         String checkBoxValueList = request.getParameter("ckv");   
  •         if(!CommonUtil.isNotNullorEmtry(checkBoxValueList)) {   
  •             this.saveMessages(request, "export.fail");   
  •             return mapping.findForward("export.fail");   
  •         }   
  •         List<Order> listOrder = orderService.exportOrderList(checkBoxValueList);   
  •            
  •         try {   
  • //          SimpleDateFormat sf = new SimpleDateFormat("yyyyMMddhhmm");   
  • //          Calendar calendar = Calendar.getInstance();   
  •                
  •             ServletOutputStream os = response.getOutputStream(); //獲得輸出流   
  •             response.reset();   //清空輸出流   
  •             String fileName = new String("訂單列表".getBytes("gb2312"), "ISO8859-1") +".xls";   
  •             response.setHeader("Content-disposition""attachment; filename="+ fileName); //設定輸出文件頭   
  •             response.setContentType("application/msexcel"); //定義輸出類型   
  •   
  •             String filePath = request.getSession().getServletContext().getRealPath("/excel/model/order.xls");   
  •   
  •             HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(filePath));    //讀取excel模板   
  •             try {   
  •                 HSSFSheet sheet = workbook.getSheetAt(0);   //讀取第一個工作簿   
  •                 HSSFRow row;   
  •                 HSSFCell cell = null;   
  •                 int rownum = 3//添加的起始行   
  •                 HSSFCellStyle style = this.getStyle(workbook);   
  •                 Iterator<Order> it = listOrder.iterator();   
  •                 Order order = null;   
  •                                    
  •                 while(it.hasNext()) {   
  •                     order = new Order();   
  •                     order = it.next();   
  •                        
  •                     row = sheet.createRow(rownum);   
  •                        
  •                     myCreateCell(1, String.valueOf(rownum-2), row, cell, style);    //列1   
  •                     myCreateCell(2, order.getAdName(), row, cell, style);   //列2   
  •                     myCreateCell(3, order.getSmallAreaName(), row, cell, style);    //列1       
  •                                            
  •                     rownum++;   
  •                 }   
  •                                    
  •                 workbook.write(os);   
  •                 os.flush();   
  •                 os.close();   
  •             } catch (Exception e) {   
  •                 e.printStackTrace();   
  •             }   
  •         } catch (IOException e) {   
  •             e.printStackTrace();   
  •         }   
  •         return null;   
  •     }   
  •        
  •     private void myCreateCell(int cellnum, String value, HSSFRow row, HSSFCell cell, HSSFCellStyle style) {   
  •         cell = row.createCell((short) cellnum);   
  •         cell.setCellValue(new HSSFRichTextString(value));   
  •         cell.setCellStyle(style);   
  •     }   
  •        
  •     public HSSFCellStyle getStyle(HSSFWorkbook workbook) {   
  •         //設置字體;   
  •         HSSFFont font = workbook.createFont();   
  •         //設置字體大小;   
  •         font.setFontHeightInPoints((short10);   
  •         //設置字體名字;   
  •         font.setFontName("宋體");   
  •         //font.setItalic(true);   
  •         //font.setStrikeout(true);   
  •         //設置樣式;   
  •         HSSFCellStyle style = workbook.createCellStyle();   
  •         //設置底邊框;   
  •         style.setBorderBottom(HSSFCellStyle.BORDER_THIN);   
  •         //設置底邊框顏色;   
  •         style.setBottomBorderColor(HSSFColor.BLACK.index);   
  •         //設置左邊框;   
  •         style.setBorderLeft(HSSFCellStyle.BORDER_THIN);   
  •         //設置左邊框顏色;   
  •         style.setLeftBorderColor(HSSFColor.BLACK.index);   
  •         //設置右邊框;   
  •         style.setBorderRight(HSSFCellStyle.BORDER_THIN);   
  •         //設置右邊框顏色;   
  •         style.setRightBorderColor(HSSFColor.BLACK.index);   
  •         //設置頂邊框;   
  •         style.setBorderTop(HSSFCellStyle.BORDER_THIN);   
  •         //設置頂邊框顏色;   
  •         style.setTopBorderColor(HSSFColor.BLACK.index);   
  •         //在樣式用應用設置的字體;   
  •         style.setFont(font);   
  •         //設置自動換行;   
  •         style.setWrapText(false);   
  •         //設置水平對齊的樣式為居中對齊;   
  •         style.setAlignment(HSSFCellStyle.ALIGN_CENTER);   
  •         //設置垂直對齊的樣式為居中對齊;   
  •         style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);   
  •         return style;   
  •     } 

  • EXCEL模板加載出錯的問題:
    可能是因為模板中某些格式存在問題,或者模板中存在EXCEL的某些高級功能,【POI】無法加載導致出錯。
    解決辦法:自己一步步從最簡單的excel文件開始,繪制模板。



    非洲小白臉 2011-02-22 17:48 發表評論
    ]]>
    物化視圖http://www.aygfsteel.com/ocean07000814/articles/342428.html非洲小白臉非洲小白臉Thu, 06 Jan 2011 07:08:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/342428.htmlhttp://www.aygfsteel.com/ocean07000814/comments/342428.htmlhttp://www.aygfsteel.com/ocean07000814/articles/342428.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/342428.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/342428.html CREATE MATERIALIZED VIEW mv_test_pk
      --如果可以快速刷新則進行快速刷新,否則完全刷新refresh force on demand 
     REFRESH FAST on demand
      start with to_date('24-11-2008 18:00:10', 'dd-mm-yyyy hh24:mi:ss') --第一次刷新時間
      next TRUNC(SYSDATE+1)+18/24 --刷新時間間隔
         AS select * from t_test;

    也可以手動刷新物化視圖:dbms_mview('mv_emp_pk');



    非洲小白臉 2011-01-06 15:08 發表評論
    ]]>
    String中特殊字符的替換http://www.aygfsteel.com/ocean07000814/articles/342394.html非洲小白臉非洲小白臉Thu, 06 Jan 2011 01:00:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/342394.htmlhttp://www.aygfsteel.com/ocean07000814/comments/342394.htmlhttp://www.aygfsteel.com/ocean07000814/articles/342394.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/342394.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/342394.html   System.out.println(str);
      
      str = str.replaceAll("[']", "B");
      str = str.replaceAll("[\"]", "B");
      str = str.replaceAll("[\\\\]", "B");
      str = str.replaceAll("[/]", "B");
      str = str.replaceAll("[&]", "B");
      str = str.replaceAll("[$]", "B");
      str = str.replaceAll("[#]", "B");
      str = str.replaceAll("[<]", "B");
      str = str.replaceAll("[>]", "B");

    兩處輸出內容:
    abc'"\&/$#<>
    abcBBBBBBBBB

    非洲小白臉 2011-01-06 09:00 發表評論
    ]]>
    Velocity學習http://www.aygfsteel.com/ocean07000814/articles/335784.html非洲小白臉非洲小白臉Thu, 21 Oct 2010 06:46:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/335784.htmlhttp://www.aygfsteel.com/ocean07000814/comments/335784.htmlhttp://www.aygfsteel.com/ocean07000814/articles/335784.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/335784.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/335784.htmlVelocity用戶手冊---中文版(學習修改版) Velocity的能力遠不止web站點開發這個領域,例如,它可以從模板(template)產生SQL和PostScript、XML,它也可以被當 作一個獨立工具來產生源代碼和報告,或者作為其他系統的集成組件使用。Velocity也可以為Turbine web開發架構提供模板服務(template service)。Velocity+Turbine提供一個模板服務的方式允許一個web應用以一個真正的MVC模型進行開發。

    Velocity能為我們作什么?
    The Mud Store Example
    假設你是一家專門出售Mud的在線商店的頁面設計人員,讓我們暫且稱它為“在線MUD商店”。你們的業務很旺,客戶下了各種類型和數量的mud訂 單。他們都是通過輸入用戶名和密碼后才登陸到你的網站,登陸后就允許他們查看訂單并購買更多的mud。現在,一種非常流行的mud正在打折銷售。另外有一 些客戶規律性的購買另外一種也在打折但是不是很流行的Bright Red Mud,由于購買的人并不多所以它被安置在頁面的邊緣。所有用戶的信息都是被跟蹤并存放于數據庫中的,所以某天有一個問題可能會冒出來:為什么不使用 velocity來使用戶更好的瀏覽他們感興趣的商品呢?
    Velocity使得web頁面的客戶化工作非常容易。作為一個web site的設計人員,你希望每個用戶登陸時都擁有自己的頁面。
    你會見了一些公司內的軟件工程師,你發現他們每個人都同意客戶應該擁有具有個性化的信息。那讓我們把軟件工程師應該作的事情發在一邊,看一看你應該作些什么吧。
    你可能在頁面內嵌套如下的VTL聲明:
    Java代碼
    1. <html>  
    2. <body>  
    3. Hello $customer.Name!  
    4. <table>  
    5. #foreach( $mud in $nudsOnSpecial );   
    6. #if ( $customer.hasPurchased( $mud ); );   
    7. <tr><td>$flogger.getPromo( $mud );</td></tr>  
    8. #end  
    9. #end  
    10. </table>  

    Velocity Template Language(VTL):AN introduction
    VTL意味著提供最簡單、最容易并且最整潔的方式合并頁面動態內容。
    VTL使用references來在web site內嵌套動態內容,一個變量就是一種類型的reference。變量是某種類型的refreence,它可以指向java代碼中的定義,或者從當前 頁面內定義的VTL statement得到值。下面是一個VTL statement的例子,它可以被嵌套到HTML代碼中:
    Java代碼
    1. #set ( $a = “Velocity” );  

    和所有的VTL statement一樣,這個statement以#字符開始并且包含一個directive:set。當一個在線用戶請求你的頁面時,Velocity Templating Engine將查詢整個頁面以便發現所有#字符,然后確定哪些是VTL statement,哪些不需要VTL作任何事情。
    #字符后緊跟一個directive:set時,這個set directive使用一個表達式(使用括號封閉)――一個方程式分配一個值給變量。變量被列在左邊,而它的值被列在右邊,最后他們之間使用=號分割。
    在上面的例子中,變量是$a,而它的值是Velocity。和其他的references一樣以$字符開始,而值總是以雙引號封閉。Velocity中僅有String可以被賦值給變量。
    記住以下的規則:
    使用$字符開始的references用于得到什么;使用#字符開始的directives用于作些什么。
    Hello Velocity World!
    一旦某個變量被分配了一個值,那么你就可以在HTML文件的任何地方引用它。在下面的例子中,一個值被分配給$foo變量,并在其后被引用。
    <html>
    <body>
    #set ( $foo = “Velocity” )
    Hello $foo World!
    </body>
    </html>
    上面的實現結果是在頁面上打印“Hello Velocity World!”
    為了使包含VTL directives的statement更具有可讀性,我們鼓勵你在新行開始每個VTL statement,盡管你不是必須這么作。Set directive將在后面詳細描述。
    注釋
    單行注釋:
      ## This is a single line comment.
    多行注釋:
      #*
       Thus begins a multi-line comment. Online visitors won’t
       see this text because the Velocity Templating Engine will
    ignore it.
      *#
    文檔格式:
      #**
       This is a VTL comment block and
       may be used to store such information
    as the document author and versioning
       information:
       @version 5
       @author
      *#

    References
    在VTL中有三種類型的references:變量(variables)、屬性(properties)、方法(methods)。作為一個使 用VTL的頁面設計者,你和你的工程師必須就references的名稱達成共識,以便你可以在你的template中使用它們。
    Everything coming to and from a reference被作為一個String對象處理。如果有一個對象$foo是一個Integer對象,那么Velocity將調用它的toString()方法將這個對象轉型為String類型。
      變量
      格式要求同java。
      屬性
      例子:
        $customer.Address
        $purchase.Total
    $customer.Address有兩種含義。它可以表示:查找hashtable對象customer中以Address為關鍵字的值;也可 以表示調用customer對象的getAddress()方法。當你的頁面被請求時,Velocity將確定以上兩種方式選用那種,然后返回適當的值。
    方法
    一個方法就是被定義在java中的一段代碼,并且它有完成某些有用工作的能力,例如一個執行計算和判斷條件是否成立、滿足等。方法是一個由$開始并跟隨VTL標識符組成的References,一般還包括一個VTL方法體。例如:
      $customer.getAddress()
      $purchase.getTotal()
      $page.setTitle( “My Home Page” )
      $person.setAttributes( [“Strange”, “Weird”, “Excited”] )
    前兩個例子$customer.getAddress()和$purchase.getTotal()看起來挺想上面的屬性$customer.Address 和 $purchase.Total。如果你覺得他們之間有某種聯系的話,那你是正確的。
    VTL屬性可以作為VTL方法的縮寫。$customer.Address屬性和使用$customer.getAddress()方法具有相同的效果。如果可能的話使用屬性的方式是比較合理的。屬性和方法的不同點在于你能夠給一個方法指定一個參數列表。
    正式reference標記
    reference的正是格式如下:
      ${mudSlinger}        變量
      ${customer.Address}    屬性
      ${purchase.getTotal()}    方法
    非正是格式更見常用,但是有時還是使用正是格式比較適合。例如:你希望通過一個變量$vice來動態的組織一個字符串。
      Jack is a $vicemaniac.
    本來變量是$vice現在卻變成了$vicemaniac,這樣Veloctiy就不知道您到底要什么了。所以,應該使用正是格式書寫
      Jack is a ${vice}maniac
    現在Velocity知道變量是$vice而不是$vicemaniac。
    Quiet reference notation
    例如:
      <input type=”text” name=”email” value=”$email” />
    當頁面的form被初始加載時,變量$email還沒有值,這時你肯定是希望它能夠顯示一個blank text來代替輸出”$email”這樣的字段。那么使用quiet reference notation就比較合適。
      <input type=”text” name=”email” value=”$!email”/>
    這樣文本框的初始值就不會是email而是空值了。
    正式和quiet格式的reference notation也可一同使用,像下面這樣:
      <input type=”text” name=”email” value=”$!{email}”/>
    Getting literal
    Velocity使用特殊字符$和#來幫助它工作,所以如果要在template里使用這些特殊字符要格外小心。本節將討論$字符。
      貨幣字符
    在VTL中使用$2.5這樣的貨幣標識是沒有問題得的,VTL不會將它錯認為是一個reference,因為VTL中的reference總是以一個大寫或者小寫的字母開始。
    Escaping valid VTL reference
    VTL中使用“\”作為逃逸符。
    例如:
      #set( $email = “foo” )
      $email
      \$email
      \\$email
      \\\$email
    將render為:
      foo
      $email
      \foo
      \\$email
    如果email變量沒有被定義則
      $email
      \$email
      \\$email
      \\\$email
    將被render為:
      $email
      \$email
      \\$email
      \\\$email
    注意:VTL中未被定義的變量將被認為是一個字符串,所以以下例子:
      #set( $foo = “gibbous” )
      $moon = $foo
    的輸出結果是:
    $moon = gibbous
    Case substitution
    現在你已經對reference比較熟悉了,你可以將他們高效的應用于你的template了。Velocity利用了很多java規范以方便了設計人員的使用。例如:
      $foo
      $foo.getBar()
      ## is the same as
      $foo.Bar

      $data.getUser(“jon”)
      ## is the same as
      $data.User(“jon”)

      $data.getRequest().getServerName()
      # is the same as
      $data.Request.ServerName
      ## is the same as
      ${data.Request.ServerName}
    但是,注意VTL中不會將reference解釋為對象的實例變量。例如:$foo.Name將被解釋為Foo對象的getName()方法,而不是Foo對象的Name實例變量。
    Directives
    Reference允許設計者使用動態的內容,而directive使得你可以應用java代碼來控制你的顯示邏輯,從而達到你所期望的顯示效果。
      #set
      #set directive被用于設置一個reference的值。例如:
        #set ( $primate = “monkey” )
        #set ( $customer.Behavior = $primate )
    賦值左側的(LHS)必須是一個變量或者屬性reference。右側(RHS)可以是以下類型中一種:
    l  變量reference
    l  String literal
    l  屬性reference
    l  方法reference
    l  number literal
    l  ArrayList
    下面是應用各種類型的RHS的例子:
      #set ( $monkey = $bill ) ##變量reference
      #set ( $monkey.Friend = “monica” ) ##String literal
      #set ( $monkey.Blame = $whitehouse.Leak )##屬性reference
      #set ( $monkey.Plan = $spindoctor.weave($web) )##方法reference
      #set ( $monkey.Number = 123 )##Number literal
      #set ( $monkey.Say = [“Not”, $my, “fault”] )##ArrayList
    注意:最后一個例子的取值方法為:$monkey.Say.get(0)
    RHS也可以是一個簡單的算術表達式:
      #set ( $value = $foo + 1 )
      #set ( $value = $bar -1 )
    #set ( $value = $foo * $bar )
    #set ( $value = $foo / $bar )
    如果你的RHS是一個null,VTL的處理將比較特殊:它將指向一個已經存在的reference,這對初學者來講可能是比較費解的。例如:
      #set ( $resut = $query.criteria(“name”) )
      The result of the first query is $result

      #set ( $resut = $query.criteria(“address”) )
      The result of the second query is $result
    如果$query.criteria(“name”)返回一個“bill”,而$query.criteria(“address”)返回的是null,則顯示的結果如下:
      The result of the first query is bill
      The result of the first query is bill
    看看下面的例子:
      #set( $criteria = ["name", "address"] )
    #foreach( $criterion in $criteria )
    #set( $result = $query.criteria($criterion) )
      #if( $result )
      Query was successful
         #end
    #end
    在上面的例子中,程序將不能智能的根據$result的值決定查詢是否成功。在$result被#set后(added to the context),它不能被設置回null(removed from the context)。打印的結果將顯示兩次查詢結果都成功了,但是實際上有一個查詢是失敗的。
    為了解決以上問題我們可以通過預先定義的方式:
      #set( $criteria = [“name”, “address”] )
      #foreach( $criterion in $criteria )
        #set( $result = false )
        #set( $result = $query.criteria( $criterion ) )
        #if( $result )
          Query was successful
        #end
      #end
      String Literals
      當你使用#set directive,String literal封閉在一對雙引號內。
        #set ( $directoryRoot = “www” )
        #set ( $templateName = “index.vm” )
        #set ( $template = “$directoryRoot/$tempateName” )
        $template
      上面這段代碼的輸出結果為:www/index.vm
      但是,當string literal被封裝在單引號內時,它將不被解析:
        #set ( $foo = “bar” )
        $foo
        #set ( $blargh = ‘$foo’ )
      結果:
        bar
        $foo
      上面這個特性可以通過修改velocity.properties文件的stringliterals.interpolate = false的值來改變上面的特性是否有效。
    條件語句
      if/elseif/else
    當一個web頁面被生成時使用Velocity的#if directrive,如果條件成立的話可以在頁面內嵌入文字。例如:
      #if ( $foo )
        <strong>Velocity!</strong>
      #end
    上例中的條件語句將在以下兩種條件下成立:
    l  $foo是一個boolean型的變量,且它的值為true
    l  $foo變量的值不為null
    這里需要注意一點:Velocity context僅僅能夠包含對象,所以當我們說“boolean”時實際上代表的時一個Boolean對象。即便某個方法返回的是一個boolean值,Velocity也會利用內省機制將它轉換為一個Boolean的相同值。
    如果條件成立,那么#if和#end之間的內容將被顯示。
    #elseif和#else元素可以同#if一同使用。例如:
      #if( $foo < 10 )
        <strong> Go North </strong>
      #elseif( $foo == 10 )
        <strong> Go East </strong>
      #elseif( $foo == 6 )
        <strong> Go South </strong>
      #else
        <strong> Go West </strong>
      #end
    注意這里的Velocity的數字是作為Integer來比較的――其他類型的對象將使得條件為false,但是與java不同它使用“==”來比較兩個值,而且velocity要求等號兩邊的值類型相同。
    關系、邏輯運算符
    Velocity中使用等號操作符判斷兩個變量的關系。例如:
    #set ( $foo = “deoxyribonucleic acid” )
    #set ( $bar = “ribonucleic acid” )
    #if ( $foo == $foo )
      In this case it’s clear they aren’t equivalent.So…
    #else
      They are not equivalent and this will be the output.
    #end

    Velocity有AND、OR和NOT邏輯運算符。下面是一些例子:
      ## logical AND
      #if( $foo && $bar )
        <strong> This AND that </strong>
      #end

      ## logical OR
      #if ( $foo || $bar )
        <strong>This OR That </strong>
      #end

      ##logical NOT
      #if ( !$foo )
        <strong> NOT that </strong>
      #end
    循環
      Foreach循環
      例子:
        <ul>
          #foreach ( $product in $allProducts )
            <li> $product </li>
          #end
        </ul>
      每次循環$allProducts中的一個值都會賦給$product變量。
    $allProducts可以是一個Vector、Hashtable或者Array。分配給$product的值是一個java對象,并且可以 通過變量被引用。例如:如果$product是一個java的Product類,并且這個產品的名字可以通過調用他的getName()方法得到。
    現在我們假設$allProducts是一個Hashtable,如果你希望得到它的key應該像下面這樣:
    <ul>
    #foreach ( $key in $allProducts.keySet() )
    <li>Key: $key -> Value: $allProducts.get($key) </li>
    #end
    </ul>

    Velocity還特別提供了得到循環次數的方法,以便你可以像下面這樣作:
    <table>
    #foreach ( $customer in $customerList )
    <tr><td>$velocityCount</td><td>$customer.Name</td></tr>
    #end
    </table>
    $velocityCount變量的名字是Velocity默認的名字,你也可以通過修改velocity.properties文件來改變它。 默認情況下,計數從“1”開始,但是你可以在velocity.properties設置它是從“1”還是從“0”開始。下面就是文件中的配置:
      # Default name of loop counter
      # variable reference
      directive.foreach.counter.name = velocityCount

      # Default starting value of the loop
      # counter variable reference
      directive.foreach.counter.initial.value = 1

    include
    #include script element允許模板設計者引入本地文件。被引入文件的內容將不會通過模板引擎被render。為了安全的原因,被引入的本地文件只能在TEMPLATE_ROOT目錄下。
      #inclued ( “one.txt” )
    如果您需要引入多個文件,可以用逗號分隔就行:
      #include ( “one.gif”, “two.txt”, “three.htm” )
    在括號內可以是文件名,但是更多的時候是使用變量的:
      #inclue ( “greetings.txt”, $seasonalstock )

    parse
    #parse script element允許模板設計者一個包含VTL的本地文件。Velocity將解析其中的VTL并render模板。
      #parse( “me.vm” )
    就像#include,#parse接受一個變量而不是一個模板。任何由#parse指向的模板都必須包含在TEMPLATE_ROOT目錄下。與#include不同的是,#parse只能指定單個對象。
    你可以通過修改velocity.properties文件的parse_direcive.maxdepth的值來控制一個template可以包含的最多#parse的個數――默認值是10。#parse是可以遞歸調用的,例如:如果dofoo.vm包含如下行:
      Count down.
      #set ( $count = 8 )
      #parse ( “parsefoo.vm” )
      All done with dofoo.vm!
    那么在parsefoo.vm模板中,你可以包含如下VTL:
      $count
      #set ( $count = $count – 1 )
      #if ( $count > 0 )
        #parse( “parsefoo.vm” )
      #else
        All done with parsefoo.vm!
      #end
    的顯示結果為:
      Count down.
      8
      7
      6
      5
      4
      3
      2
      1
      0
      All done with parsefoo.vm!
    All done with dofoo.vm!

    Stop
    #stop script element允許模板設計者停止執行模板引擎并返回。把它應用于debug是很有幫助的。
      #stop

    Velocimacros
    #macro script element允許模板設計者定義一段可重用的VTL template。例如:
      #macro ( d )
      <tr><td></td></tr>
      #end
    在上面的例子中Velocimacro被定義為d,然后你就可以在任何VTL directive中以如下方式調用它:
      #d()
    當你的template被調用時,Velocity將用<tr><td></td></tr>替換為#d()。
    每個Velocimacro可以擁有任意數量的參數――甚至0個參數,雖然定義時可以隨意設置參數數量,但是調用這個Velocimacro時必須指定正確的參數。下面是一個擁有兩個參數的Velocimacro,一個參數是color另一個參數是array:
      #macro ( tablerows $color $somelist )
      #foreach ( $something in $somelist )
        <tr><td bgcolor=$color>$something</td</tr>
      #end
      #end
    調用#tablerows Velocimacro:
      #set ( $greatlakes = [ “Superior”, “Michigan”, “Huron”, “Erie”, “Ontario” ] )
      #set ( $color = “blue” )
      <table>
        #tablerows( $color $greatlakes )
      </table>
    經過以上的調用將產生如下的顯示結果:
      <table>
        <tr><td bgcolor=” blue”> Superior </td></tr>
        <tr><td bgcolor=” blue”> Michigan </td></tr>
        <tr><td bgcolor=” blue”> Huron </td></tr>
        <tr><td bgcolor=” blue”> Erie </td></tr>
        <tr><td bgcolor=” blue”> Ontario </td></tr>
      </table>
    Velocimacros可以在Velocity模板內實現行內定義(inline),也就意味著同一個web site內的其他Velocity模板不可以獲得Velocimacros的定義。定義一個可以被所有模板共享的Velocimacro顯然是有很多好處 的:它減少了在一大堆模板中重復定義的數量、節省了工作時間、減少了出錯的幾率、保證了單點修改。
    上面定義的#tablerows( $color $list )Velocimacro被定義在一個Velocimacros模板庫(在velocity.properties中定義)里,所以這個macro可以在 任何規范的模板中被調用。它可以被多次應用并且可以應用于不同的目的。例如下面的調用:
      #set ( $parts = [ “volva”, “stipe”, “annulus”, “gills”, “pileus” ] )
      #set ( $cellbgcol = “#CC00FF” )
      <table>
        #tablerows( $cellbgcol $parts )
      </table>
    上面VTL將產生如下的輸出:
      <table>
        <tr><td bgcolor=”#CC00FF”> volva </td</tr>
        <tr><td bgcolor=”#CC00FF”> stipe </td</tr>
        <tr><td bgcolor=”#CC00FF”> annulus </td</tr>
        <tr><td bgcolor=”#CC00FF”> gills </td</tr>
        <tr><td bgcolor=”#CC00FF”> pileus </td</tr>
      </table>
      Velocimacro arguments
      Velocimacro可以使用以下任何元素作為參數:
    l  Reference:任何以$開頭的reference
    l  String literal:
    l  Number literal:
    l  IntegerRange:[1….3]或者[$foo….$bar]
    l  對象數組:[“a”,”b”,”c”]
    l  boolean值:true、false
    當將一個reference作為參數傳遞給Velocimacro時,請注意reference作為參數時是以名字的形式傳遞的。這就意味著參數 的值在每次Velocimacro內執行時才會被產生。這個特性使得你可以將一個方法調用作為參數傳遞給Velocimacro,而每次 Velocimacro執行時都是通過這個方法調用產生不同的值來執行的。例如:
      #macro ( callme $a )
        $a $a $a
      #end
      #callme( $foo.bar() )
    執行的結果是:reference $foo的bar()方法被執行了三次。
    如果你不需要這樣的特性可以通過以下方法:
      #set ( $myval = $foo.bar() )
      #callme ( $myval )

    Velocimacro properties
    Velocity.properties文件中的某幾行能夠使Velocimacros的實現更加靈活。注意更多的內容可以看Developer Guide。
    Velocity.properties文件中的velocimacro.libraary:一個以逗號分隔的模板庫列表。默認情況下,velocity查找唯一的一個庫:VM_global_library.vm。你可以通過配置這個屬性來指定自己的模板庫。
    Velocity.properties文件中的velocimacro.permissions.allow.inline屬性:有兩個可選的 值true或者false,通過它可以確定Velocimacros是否可以被定義在regular template內。默認值是ture――允許設計者在他們自己的模板中定義Velocimacros。
    Velocity.properties文件中的
    velocimacro.permissions.allow.inline.replace.global屬性有兩個可選值true和 false,這個屬性允許使用者確定inline的Velocimacro定義是否可以替代全局Velocimacro定義(比如在 velocimacro.library屬性中指定的文件內定義的Velocimacro)。默認情況下,此值為false。這樣就阻止本地 Velocimacro定義覆蓋全局定義。
    Velocity.properties文件中的
    velocimacro.permissions.allow.inline.local.scale屬性也是有true和false兩個可選 值,默認是false。它的作用是用于確定你inline定義的Velocimacros是否僅僅在被定義的template內可見。換句話說,如果這個 屬性設置為true,一個inline定義的Velocimacros只能在定義它的template內使用。你可以使用此設置實現一個奇妙的VM敲 門:a template can define a private implementation of the second VM that will be called by the first VM when invoked by that template. All other templates are unaffected。
    Velocity.properties文件中的velocimacro.context.localscope屬性有true和false兩 個可選值,默認值為false。當設置為true時,任何在Velocimacro內通過#set()對context的修改被認為是針對此 velocimacro的本地設置,而不會永久的影響內容。
    Velocity.properties文件中的velocimacro.library.autoreload屬性控制 Velocimacro庫的自動加載。默認是false。當設置為ture時,對于一個Velocimacro的調用將自動檢查原始庫是否發生了變化,如 果變化將重新加載它。這個屬性使得你可以不用重新啟動servlet容器而達到重新加載的效果,就像你使用regular模板一樣。這個屬性可以使用的前 提就是resource loader緩存是off狀態(file.resource.loader.cache = false)。注意這個屬性實際上是針對開發而非產品的。
    Velocimacro Trivia
    Velocimacro必須被定義在他們被使用之前。也就是說,你的#macro()聲明應該出現在使用Velocimacros之前。
    特別要注意的是,如果你試圖#parse()一個包含#macro()的模板。因為#parse()發生在運行期,但是解析器在 parsetiem決定一個看似VM元素的元素是否是一個VM元素,這樣#parse()-ing一組VM聲明將不按照預期的樣子工作。為了得到預期的結 果,只需要你簡單的使用velocimacro.library使得Velocity在啟動時加載你的VMs。
    Escaping VTL directives
    VTL directives can be escaped with “\”號,使用方式跟VTL的reference使用逃逸符的格式差不多。
      ## #include( “a.txt” ) renders as <ontents of a.txt>(注釋行)
      #include( “a.txt” )

      ## \#include( “a.txt” ) renders as \#include( “a.txt” )
      \#include( “a.txt” )

      ## \\#include ( “a.txt” ) renders as \<contents of a.txt>
      \\#include( “a.txt” )
    在對在一個directive內包含多個script元素的VTL directives使用逃逸符時要特別小心(比如在一個if-else-end statement內)。下面是VTL的if-statement的典型應用:
      #if ( $jazz )
        Vyacheslav Ganelin
      #end
    如果$jazz是ture,輸出將是:
      Vyacheslav Ganelin
    如果$jazz是false,將沒有輸出。使用逃逸符將改變輸出。考慮一下下面的情況:
      \#if ( $jazz )
        Vyacheslav Ganelin
      \#end
    現在無論$jazz是true還是false,輸出結果都是:
      #if ( $jazz )
        Vyacheslav Ganelin
      #end
    事實上,由于你使用了逃逸符,$jazz根本就沒有被解析為boolean型值。在逃逸符前使用逃逸符是合法的,例如:
      \\#if ( $jazz )
        Vyacheslav Ganelin
      \\#end
    以上程序的顯示結果為:
      \ Vyacheslav Ganelin
      \
    但是如果$jazz為false,那么將沒有輸出。(書上說會沒有輸出,但是我覺得應該還有有“\”字符被輸出。)
    VTL:Formatting issues
    盡管在此用戶手冊中VTL通常都開始一個新行,如下所示:
      #set ( $imperial = [ “Munetaka”, “Koreyasu”, “Hisakira”, “Morikune” ] )
      #foreach ( $shogun in $imperial )
        $shogun
      #end
    但是像下面這種寫法也是可以的:
      Send me #set($foo = [“$10 and”,”a cake”])#foreach($a in $foo)$a #end please.
    上面的代碼可以被改寫為:
      Send me
      #set ( $foo = [“$10 and “,”a cake”] )
      #foreach ( $a in $foo )
        $a
      #end
      please.
    或者
      Send me
      #set($foo = [“$10 and “,”a cake”])
            #foreach ($a in $foo )$a
          #end please.
    這兩種的輸出結構將一樣。
    其他特性和雜項
      math   在模板中可以使用Velocity內建的算術函數,如:加、減、乘、除
        #set ( $foo = $bar + 3 )
        #set ( $foo = $bar - 4 )
        #set ( $foo = $bar * 6 )
        #set ( $foo = $bar / 2 )
      當執行除法時將返回一個Integer類型的結果。而余數你可以使用%來得到:
        #set ( $foo = $bar % 5 )
    在Velocity內使用數學計算公式時,只能使用像-n,-2,-1,0,1,2,n這樣的整數,而不能使用其它類型數據。當一個非整型的對象被使用時它將被logged并且將以null作為輸出結果。
    Range Operator
    Range operator可以被用于與#set和#foreach statement聯合使用。對于處理一個整型數組它是很有用的,Range operator具有以下構造形式:
      [n..m]
    m和n都必須是整型,而m是否大于n則無關緊要。例子:
      First example:
      #foreach ( $foo in [1..5] )
        $foo
      #end

      Second example:
      #foreach ( $bar in [2..-2] )
        $bar
      #end

      Third example:
      #set ( $arr = [0..1] )
      #foreach ( $i in $arr )
        $i
      #end

      Fourth example:
      [1..3]
    上面四個例子的輸出結果為:
      First example:
      1 2 3 4 5

      Second example:
      2 1 0 -1 -2

      Third example:
      0 1

      Fourth example:
      [1..3]
    注意:range operator只在#set和#foreach中有效。
    Advanced Issue:Escaping and!
    當一個reference被“!”分隔時,并且在它之前有逃逸符時,reference將以特殊的方式處理。注意這種方式與標準的逃逸方式時不同的。對照如下:
    #set ( $foo = “bar” )
    特殊形式  標準格式
    Render前  Render后  Render前  Render后
    $\!foo  $!foo  \$foo  \$foo
    $\!{foo}  $!{foo}  \$!foo  \$!foo
    $\\!foo  $\!foo  \$!{foo}  \$!{foo}
    $\\\!foo  $\\!foo  \\$!{foo}  \bar
    Velocimacro雜記
      Can I user a directive or another VM as an argument to a VM?
      例如:#center ( #bold( “hello” ) )
      不可以。一個directive的參數使用另外一個directive是不合法的。
      但是,還是有些事情你可以作的。最簡單的方式就是使用雙引號:
        #set ( $stuff = “#bold( ‘hello’ )” )
        #center ( $stuff )
      上面的格式也可以縮寫為一行:
        #center ( “#bold( ‘hello’ ) )
    請注意在下面的例子中參數被evaluated在Velocimacro內部,而不是在calling level。例子:
      #macro ( inner $foo )
        inner : $foo
      #end

      #macro ( outer $foo )
        #set ( $bar = “outerlala” )
        outer : $foo
      #end
     
      #set ( $bar = ‘calltimelala’ )
      #outer( “#inner($bar)” )
    輸出結果為:
      outer : inner : outerlala
    記住Veloctiy的特性:參數的傳遞是By Name的。例如:
      #macro ( foo $color )
        <tr bgcolor = $color ><td>Hi</td></tr>
        <tr bgcolor = $color ><td>There</td></tr>
      #end

      #foo ( $bar.rowColor() )
    以上代碼將導致rowColor()方法兩次調用,而不是一次。為了避免這種現象的出現,我們可以按照下面的方式執行:
      #set ( $color = $bar.rowColor() )
      #foo ( $color )
    can I register velocimacros via #parse()?
    目前,Velocimacros必須在第一次被模板調用前被定義。這就意味著你的#macro()聲明應該出現在使用Velocimacros之前。
    如果你試圖#parse()一個包含#macro() directive的模板,這一點是需要牢記的。因為#parse()發生在運行期,但是解析器在parsetiem決定一個看似VM元素的元素是否是一 個VM元素,這樣#parse()-ing一組VM聲明將不按照預期的樣子工作。為了得到預期的結果,只需要你簡單的使用 velocimacro.library使得Velocity在啟動時加載你的VMs。
    What is velocimacro autoreloading?
    velocimacro.library.autoreload是專門為開發而非產品使用的一個屬性。此屬性的默認值是false。
    String concatenation
    開發人員最常問的問題是我如何作字符拼接?在java中是使用“+”號來完成的。
    在VTL里要想實現同樣的功能你只需要將需要聯合的reference放到一起就行了。例如:
    #set ( $size = “Big” )
    #set ( $name = “Ben” )
    The clock is $size$name.
    輸出結果將是:The clock is BigBen.。更有趣的情況是:
      #set ( $size = “Big” )
      #set ( $name = “Ben” )
      #set ( $clokc = “$size$name” )
      The clock is $clock.
    上例也會得到同樣的結果。最后一個例子,當你希望混合固定字段到你的reference時,你需要使用標準格式:
      #set ( $size = “Big” )
      #set ( $name = “Ben” )
      #set ( $clock = “${size}Tall$name” )
      The clock is $clock.
    輸出結果是:The clock is BigTallBen.。使用這種格式主要是為了使得$size不被解釋為$sizeTall。

    幾個寫法匯總:
    Java代碼
    1. --關于鏈接的寫法--  
    2. <a href="abc.jsp?num=$var">url</a>


    非洲小白臉 2010-10-21 14:46 發表評論
    ]]>
    在Tomcat中部署Java Web應用程序(jar命令打war包)http://www.aygfsteel.com/ocean07000814/articles/331694.html非洲小白臉非洲小白臉Fri, 10 Sep 2010 09:47:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/331694.htmlhttp://www.aygfsteel.com/ocean07000814/comments/331694.htmlhttp://www.aygfsteel.com/ocean07000814/articles/331694.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/331694.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/331694.html讓大家久等了。今天給大家介紹怎樣在Tomcat5.5.9中部署Java Web應用程序。本文的重點是如何部署,所以暫且先不介紹怎樣開發Web應用程序和怎樣啟動Tomcat服務器,也不考慮使用的什么開發工具,總之在練習本文所說的例子之前,你應該有一個Java Web應用程序。本文假定Web應用程序的根目錄為PetWeb。而且存放在F:\下。下文中$CATALINA_HOME指的是Tomcat目錄。

        在Tomcat中部署Java Web應用程序有兩種方式:靜態部署和動態部署。
    一、靜態部署
         靜態部署指的是我們在服務器啟動之前部署我們的程序,只有當服務器啟動之后,我們的Web應用程序才能訪問。以下3中方式都可以部署:
        1、將PetWeb目錄拷貝到
    $CATALINA_HOME\webapps下,然后啟動服務器就可以了。這種方式比較簡單,訪問地址如下:http://localhost:8080/PetWeb/
       2、這種方式可以不必將PetWeb目錄拷貝到webapps下,直接在F:\部署。方法如下,更改$CATALINA_HOME\conf\server.xml文件,在<host>標簽內添加<Context>標簽,內容如下:
    <Context docBase="F:/PetWeb" reloadable="false" path="/Pet"/>
    其 中reloadable="false"表示當應用程序中的內容發生更改之后服務器不會自動加載,這個屬性在開發階段通常都設為true,方便開發,在發 布階段應該設置為false,提高應用程序的訪問速度。docBase為路徑,可以使用絕對路徑,也可以使用相對路徑,相對路徑相對于webapps。 path屬性的值是訪問時的根地址。訪問地址如下:
    http://localhost:8080/Pet/
       3、這種方式和第二種方式差不多,但是不是在Server.xml文件中添加Context標簽,而是在$CATALINA_HOME\conf\Catalina\localhost中添加一個xml文件,如Pet.xml,內容如下:
    <Context docBase="F:/PetWeb" reloadable="false" />大家可能發現和第二種方式差不多,但是缺少了path屬性,這種方式服務器會使用.xml的名字作為path屬性的值。訪問地址如下:http://localhost:8080/Pet/
       
        我們剛才是將PetWeb文件夾部署在了服務器中,我們知道可以將Web應用程序的內容打成.war
    包,然后在部署在服務器上。打包請參考如下步驟:
        1、打開命令提示符(Start-->Run-->cmd)
        2、設置jdk環境變量(如果我教過的學生不會配置,以后別說孫老師教過你)
        3、在命令提示符中進入F:\PetWeb文件后,鍵入如下命令:
    jar cvf Pet.war */.  這樣在當前目錄下該有Pet.war文件。其中..表示當前目錄的父目錄。
        部 署Pet.war文件非常簡單,將剛才有docBase="F:\PetWeb"更改為docBase="F:\Pet.war"或者直接將其拷貝到 webapps下也可以。重新啟動服務器就可以將Pet.war部署為一個Web應用程序了。如果你夠細心的話你會發現,服務器將Pet.war文件解 開,并且在webapps下面又生成了一個Pet文件夾,然后把Pet.war的內容拷貝到里面去了。我們可以通過以下方式取消自動解包,配置方式如下:
    <Context docBase="F:/PetWeb" reloadable="false" unpackWAR="false"/>    讓大家久等了。今天給大家介紹怎樣在Tomcat5.5.9中部署Java Web應用程序。本文的重點是如何部署,所以暫且先不介紹怎樣開發Web應用程序和怎樣啟動Tomcat服務器。我們現在不考慮使用的什么開發工具,總之在練習本文所說的例子之前,你應該有一個Java Web應用程序。本文假定Web應用程序的根目錄為PetWeb
        在Tomcat中部署Java Web應用程序有兩種方式:靜態部署和動態部署。
    一、靜態部署
         靜態部署指的是我們在服務器啟動之前部署我們的程序,只有當服務器啟動之后,我們的Web應用程序才能訪問。以下3中方式都可以部署:
        1、將PetWeb目錄拷貝到    讓大家久等了。今天給大家介紹怎樣在Tomcat5.5.9中部署Java Web應用程序。本文的重點是如何部署,所以暫且先不介紹怎樣開發Web應用程序和怎樣啟動Tomcat服務器。我們現在不考慮使用的什么開發工具,總之在練習本文所說的例子之前,你應該有一個Java Web應用程序。本文假定Web應用程序的根目錄為PetWeb。而且存放在F:\下。
        在Tomcat中部署Java Web應用程序有兩種方式:靜態部署和動態部署。在下文中$CATALINA_HOME指的是Tomcat目錄。
    一、靜態部署
         靜態部署指的是我們在服務器啟動之前部署我們的程序,只有當服務器啟動之后,我們的Web應用程序才能訪問。以下3中方式都可以部署:
        1、將PetWeb目錄拷貝到
    $CATALINA_HOME\webapps下,然后啟動服務器就可以了。這種方式比較簡單,但是web應用程序必須在webapps目錄下。訪問地址如下:
    http://localhost:8080/PetWeb/
       2、這種方式可以不必將PetWeb目錄拷貝到webapps下,直接在F:\部署。方法如下,更改$CATALINA_HOME\conf\server.xml文件,在<host>標簽內添加<Context>標簽,內容如下:
    <Context docBase="F:/PetWeb" reloadable="false" path="/Pet"/>
    其 中reloadable="false"表示當應用程序中的內容發生更改之后服務器不會自動加載,這個屬性在開發階段通常都設為true,方便開發,在發 布階段應該設置為false,提高應用程序的訪問速度。docBase為路徑,可以使用絕對路徑,也可以使用相對路徑,相對路徑相對于webapps。 path屬性的值是訪問時的根地址。訪問地址如下:
    http://localhost:8080/Pet/
       3、這種方式和第二種方式差不多,但是不是在Server.xml文件中添加Context標簽,而是在$CATALINA_HOME\conf\Catalina\localhost中添加一個xml文件,如Pet.xml,內容如下:
    <Context docBase="F:/PetWeb" reloadable="false" />大家可能發現和第二種方式差不多,但是缺少了path屬性,這種方式服務器會使用.xml的名字作為path屬性的值。訪問地址如下:http://localhost:8080/Pet/
       
        我們剛才是將PetWeb文件夾部署在了服務器中,我們知道可以將Web應用程序的內容打成.war
    包,然后在部署在服務器上。打包請參考如下步驟:
        1、打開命令提示符(Start-->Run-->cmd)
        2、設置jdk環境變量(如果我教過的學生不會配置,以后別說孫老師教過你)
        3、在命令提示符中進入F:\PetWeb文件后,鍵入如下命令:
    jar cvf Pet.war */.  這樣在當前目錄下應該有Pet.war文件。其中..表示當前目錄的父目錄。
        部 署Pet.war文件非常簡單,將剛才有docBase="F:\PetWeb"更改為docBase="F:\Pet.war"或者直接將其拷貝到 webapps下也可以。重新啟動服務器就可以將Pet.war部署為一個Web應用程序了。如果你夠細心的話你會發現,服務器將Pet.war文件解 開,并且在webapps下面又生成了一個Pet文件夾,然后把Pet.war的內容拷貝到里面去了。我們可以通過以下方式取消自動解壓縮,配置方式如 下:
    <Context docBase="F:/PetWeb" reloadable="false" unpackWAR="false"/>
    二、動態部署
        動態部署是指可以在服務器啟動之后部署web應用程序,而不用重新啟動服務器。動態部署要用到服務器提供的manager.war文件,如果在
    $CATALINA_HOME\webapps\下沒有該文件,你必須去重新下載tomcat,否則不能完成以下的功能。要想使用該管理程序必須首先編輯$CATALINA_HOME\conf\tomcat-users.xml文件,內容如下:關于這個文件的更多內容,請參考Java Web應用程序的安全模型二
    <tomcat-users>
      <role rolename="tomcat"/>
      <role rolename="role1"/>
      <role rolename="manager"/>
      <user username="coresun" password="coresun" roles="manager"/>

      <user username="tomcat" password="tomcat" roles="tomcat"/>
      <user username="both" password="tomcat" roles="tomcat,role1"/>
      <user username="role1" password="tomcat" roles="role1"/>
    </tomcat-users>
    然后在瀏覽器中鍵入如下地址:
    http://localhost:8080/應該看到一個漂亮的加菲貓了吧。點擊左邊的Tomcat Manager鏈接,提示輸入用戶名和密碼,本文都是coresun,然后可以看到以下頁面:
    在Context Path(option):中輸入/Pet
    XML Configration file URL中要指定一個.xml文件,比如我們在F:\下建立一個Pet.xml文件,內容如下:
    <Context reloadable="false" />docBase不用寫了,因為在下一個文本框中填入。或者更簡單點,這個文本框什么都不填。
    在WAR or Directory URL:中鍵入F:\PetWet或者F:\Pet.war都可以,然后點擊Deploy按鈕,看看上面是不是已經看到了你web應用程序,名字就是你Context Path(option):中的名字。

    如果你部署.war文件還有更加簡單的方式,下面還有個Select WAR file uploae點擊瀏覽選擇.war文件,然后點擊Deploy也可以。

       



    非洲小白臉 2010-09-10 17:47 發表評論
    ]]>
    用Eclipse調試時不能用查看器查看iter.next()http://www.aygfsteel.com/ocean07000814/articles/327507.html非洲小白臉非洲小白臉Thu, 29 Jul 2010 12:50:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/327507.htmlhttp://www.aygfsteel.com/ocean07000814/comments/327507.htmlhttp://www.aygfsteel.com/ocean07000814/articles/327507.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/327507.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/327507.html for(Iterator iter = coolection.iterator(); iter.hasNext(); ) {
        Object o = iter.next(); // 在這里添加了一個斷點
        o.doSomething();
    }

        在程序跑到斷點那里的時候,我用Expression查看了一下iter.next(),結果這個值和預期的值并不一樣,而是向后偏移了一個位置,也就是 說Expression查看器在查看iter.next()的時候實際上是對原來的iter又進行了一次.next()方法的調用,調試過程干擾了程序的 正常運行。所以在調試情況下程序總是不能正常運行,而實際上程序并沒有任何問題。

    非洲小白臉 2010-07-29 20:50 發表評論
    ]]>
    JProbe 下載http://www.aygfsteel.com/ocean07000814/articles/310879.html非洲小白臉非洲小白臉Tue, 26 Jan 2010 08:01:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/310879.htmlhttp://www.aygfsteel.com/ocean07000814/comments/310879.htmlhttp://www.aygfsteel.com/ocean07000814/articles/310879.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/310879.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/310879.html

    JProbe Version: 8.1.0

    軟件簡介:一款Java代碼、內存和覆蓋率分析工具。

    主要特性:覆蓋瀏覽器和源代碼視圖-快速分離未檢測代碼和死代碼;

    批處理模式-能以批處理模式運行,方便的集成建立/測試系統;

    報表-以XML、純文本、CSV或者HTML格式輸出覆蓋范圍報告,用以定制分析;

    快照合并-合并多個平臺運行的整個覆蓋數據;

    Eclipse IDE集成,提供了Eclipse插件,可在Eclipse中直接進行內存分析和代碼覆蓋率測試。

     

    下載:

    JProbe for AIX - BIN Format

    JProbe for Linux for x86 and x64 - BIN Format

    JProbe for Solaris - BIN Format

    JProbe for Solaris x86 - BIN Format

    JProbe for Windows - EXE Format

    JProbe Plugins for Eclipse

     

    JProbe Installation Guide

    JProbe Release Notes

    JProbe User Guide

    JProbe Reference Guide

    JProbe Plugins for Eclipse Guide

    JProbe Demos and Tutorials

     

    破解方法(請使用正版軟件)

    安裝Jprobe后,

    方法1:替換client-support.jar目錄中的\com\sitraka\licensing\ValidateSignature.class文件。

    方法2:替換client-support.jar目錄中的\com\sitraka\licensing\ LicenseProperties.class文件。

     

    破解文件:

    Jprobe_v8.0.0_Crack

    JProbe.Suite.v8.1.0.Cracked-FALLEN



    非洲小白臉 2010-01-26 16:01 發表評論
    ]]>
    java內存監控--JConsole 監控應用http://www.aygfsteel.com/ocean07000814/articles/305567.html非洲小白臉非洲小白臉Fri, 11 Dec 2009 06:55:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/305567.htmlhttp://www.aygfsteel.com/ocean07000814/comments/305567.htmlhttp://www.aygfsteel.com/ocean07000814/articles/305567.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/305567.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/305567.html 使用 JDK 6 中的 JConsole 監控應用(轉載)

    其實在 JDK 5 中已經新加入了這個功能了. 現在的 JDK 已經內置了對 VM 的監控功能. JDK 6 中這個工具變的更加好用了. 關于 JDK 5 中如何使用這個工具可以參考這里: http://java.sun.com/developer/technicalArticles/J2SE/jconsole.html

    http://java.sun.com/j2se/1.5.0/docs/guide/management/jconsole.html

    jconsole 可以很方便的監控本機的所有 Java 應用和遠程的應用.

    監控本地應用

     首先就是啟動您要監控的應用, 例如我用 JDK 1.6 來啟動了 Tomcat, 或者 Eclipse 也可以, 可以在任務管理器(Ctrl+Alt+Del可以調出來, 或者在任務欄點擊右鍵)里看到進程ID, 例如我這里是 6132.

    接著在 JDK 安裝目錄中(<JDK_HOME>/bin/jconsole.exe)啟動 jconsole.exe (雙擊或者在 cmd 里面敲入 jconsole), 主界面會提示您建立一個新連接:

    可以看到進程ID, 選擇它, 然后點擊"連接". 這些 ID 必須都是用 JDK 1.6 的 java.exe 啟動的, 否則在列表里看不到.

    JConsle 能監控內存,線程,類的數目和CPU然后點擊各個 Tab 可以看到詳細的輸出, 詳細的輸出包括:
    內存: 堆/非堆, 峰值, 內存的各個部分, 例如 Perm, Eden 等的大小曲線圖.
    線程: 峰值, 所有線程的列表, 堆棧跟蹤(哪個對象中的線程)等. 還可以強制執行GC.
    類: 峰值, 類總數曲線圖.
    MBean: 一些 JVM 參數的詳細 MBean 信息.

    監控遠程進程

    首先需要在運行的應用上啟用遠程管理, 參數如下(簡單期間就不加用戶驗證了):
    java -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -jar ../demo/jfc/Java2D/Java2Demo.jar

    然后連接的時候選擇遠程進程, 地址輸入:

    localhost:1090

    即可.當然在別的電腦上(一般是局域網)可以輸入那個電腦的IP.

    綜 述: 使用 JConsole 可以簡單的監控 Server 狀態, 但是本身要占一定的資源, 不過 JVM 自帶的監控, 理論上講應該是占資源很小很小的, 可以用它來方便的了解 Web 服務器應用進程的狀態. 如果要調優應用, 還是使用 JProfiler 等工具更好一些, 當然它們占的資源也更大.

    后記:

    jdk1.6.0\demo\management\MemoryMonitor

    這里帶了個很好的畫內存曲線圖的例子... 大家改改就可以實現同時監控多臺 Server 的內存曲線了....



    非洲小白臉 2009-12-11 14:55 發表評論
    ]]>
    FireBug 調試JS入門 —如何調試JS(轉載保存)http://www.aygfsteel.com/ocean07000814/articles/303900.html非洲小白臉非洲小白臉Fri, 27 Nov 2009 07:19:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/303900.htmlhttp://www.aygfsteel.com/ocean07000814/comments/303900.htmlhttp://www.aygfsteel.com/ocean07000814/articles/303900.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/303900.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/303900.html  安裝就不用說了,很簡單,在FireFox上插件庫里找到FireBug就Ok了。下圖是FireBug Debug 窗口。

         FireBug美工用的非常普遍,公司美工妹妹用的非常熟練 呵呵,而對于我們開發人員,主要用它來Debug JS。看看官方對Debug功能的介紹。
     Firebug includes a powerful JavaScript debugger that lets you pause execution at any time and see what each variable looked like at that moment. If your code is a little sluggish, use the JavaScript profiler to measure performance and find bottlenecks fast.
          簡而言之,FireBug 可以讓我們在任何時候debugJS 并查看變量,同時可以通過它找出JS中性能瓶頸。
          下圖是如何找到Web應用的JS,激活Firebug,點Script,然后在All 旁邊選擇你要Debug的JS。

    下圖是如何打斷點 基本跟Eclipse一樣,點擊行號就Ok了。
    下圖是如何在斷點上設定條件,如果條件符合,就進入斷點,這個功能很不錯,特別是Debug很復雜的Function時候。
     下圖是如何單步調試,跟Eclipse一樣 F11單步
    下圖是查看調用的Stack,對以復雜的JS Debug很有幫助。

    下圖是查看變量 基本跟EclipseDebug 一樣。


    下圖是在斷點處查看變量。


    有個很好用的功能,代碼行之間快速調轉,使得對上千行的JS調試很輕松。
    下圖就是Performance 測試結果,使用很簡單 點Profile

    還有一個Log功能比較實用,看下圖 如果你不想每次都進入斷點,用這個就再好不過了。
           基本用法就這些了,希望對大家有幫助。


    非洲小白臉 2009-11-27 15:19 發表評論
    ]]>
    java中Collections.sort()函數的用法(多字段)http://www.aygfsteel.com/ocean07000814/articles/297940.html非洲小白臉非洲小白臉Mon, 12 Oct 2009 09:44:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/297940.htmlhttp://www.aygfsteel.com/ocean07000814/comments/297940.htmlhttp://www.aygfsteel.com/ocean07000814/articles/297940.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/297940.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/297940.html用Collections.sort方法對list排序有兩種方法
    第一種是list中的對象實現Comparable接口,如下:
    /**
    * 根據order對User排序
    */
    public class User implements Comparable<User>{
        private String name;
        private Integer order;
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public Integer getOrder() {
            return order;
        }
        public void setOrder(Integer order) {
            this.order = order;
        }
        public int compareTo(User arg0) {
            return this.getOrder().compareTo(arg0.getOrder());
        }

    }
    測試一下:
    public class Test{

        public static void main(String[] args) {
            User user1 = new User();
            user1.setName("a");
            user1.setOrder(1);
            User user2 = new User();
            user2.setName("b");
            user2.setOrder(2);
            List<User> list = new ArrayList<User>();
            //此處add user2再add user1
            list.add(user2);
            list.add(user1);
            Collections.sort(list);
            for(User u : list){
                System.out.println(u.getName());
            }

        }
    }
    輸出結果如下
    a
    b

    第二種方法是根據Collections.sort重載方法來實現,例如:
    /**
    * 根據order對User排序
    */
    public class User { //此處無需實現Comparable接口
        private String name;
        private Integer order;
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public Integer getOrder() {
            return order;
        }
        public void setOrder(Integer order) {
            this.order = order;
        }
    }
    主類中這樣寫即可:
    public class Test{
        public static void main(String[] args) {
            User user1 = new User();
            user1.setName("a");
            user1.setOrder(1);
            User user2 = new User();
            user2.setName("b");
            user2.setOrder(2);
            List<User> list = new ArrayList<User>();
            list.add(user2);
            list.add(user1);
           
            Collections.sort(list,new Comparator<User>(){
                public int compare(User arg0, User arg1) {
                    return arg0.getOrder().compareTo(arg1.getOrder());
                }
            });
            for(User u : list){
                System.out.println(u.getName());
            }

        }
    }
    輸出結果如下
    a
    b

    前者代碼結構簡單,但是只能根據固定的屬性排序,后者靈活,可以臨時指定排序項,但是代碼不夠簡潔

    多字段的場合:
    Collections.sort(list,new Comparator<User>(){
                public int compare(User arg0, User arg1) {
     //            第一次比較專業
                    int i = arg0.getOrder().compareTo(arg1.getOrder());

    //            如果專業相同則進行第二次比較
                if(i==0){
    //                第二次比較
                    int j=arg0.getXXX().compareTo(arg1.getXXX());
    //                如果學制相同則返回按年齡排序
                    if(j==0){
                        return arg0.getCCC().compareTo(arg1.getCCC());
                    }
                    return j;
                }
                return i;
                }
            });



    非洲小白臉 2009-10-12 17:44 發表評論
    ]]>
    Eclipse中RMI plugin的實現(調試配置)http://www.aygfsteel.com/ocean07000814/articles/296926.html非洲小白臉非洲小白臉Tue, 29 Sep 2009 09:09:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/296926.htmlhttp://www.aygfsteel.com/ocean07000814/comments/296926.htmlhttp://www.aygfsteel.com/ocean07000814/articles/296926.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/296926.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/296926.html
  •        現在Eclipse使用的比較多,而其功能的可擴展性也是超級強大,可以將多種工具和開發技術通過插件包的形式融合進來。這里說一下怎么通過RMI Plugin在Eclipse里面調試RMI程序。

  • 一、準備安裝包
  •        Eclipse的下載地址這里就不說了,可以參考我的blog中《Eclipse開發struts指南》一文。這里提供RMI Plugin for Eclipse 的下載地址:        http://www.genady.net/rmi/v16/index.html?/rmi/v16/main.html&MAIN16

  •        破解版下載地址:http:        我 們下載適合eclipse3.1的1.6.5版本,得到net.genady.rmi_1.6.5.zip安裝包。        這里使用的是 Eclipse3.1版本,如果是2.x版本的請下載1.6.0版本的安裝包。同時需要JDK1.4.2以上版本的支持,這里不講了,請自行下載安裝。//www.inspiresky.com/bbs/dispbbs.asp?boardID=13&ID=2160&page=1
  • 二、安裝插件包
  •        解壓縮安裝包net.genady.rmi_1.6.5.zip,將解壓后得到的features和plugins文件夾拷貝至Eclipse安裝根目錄下,覆蓋原有文件夾。

  •          啟動Eclipse(如果已經啟動,請重新啟動Eclipse),這時在工具欄上會發現多了一個工具圖標,里面有Registry的管理選項,這個就是RMI Registry的管理器。說明已經安裝成功了。

  • 三、設置開發環境
  •        在安裝好插件包后,我們來設置RMI開發環境。        啟動Eclipse,在菜單window->preferences對話框中,選中左邊樹菜單java->rmi,右邊窗口會出現RMI Plugin的默認設置信息。

  •        最上面的Path to RMI registry設置java的RMI Registry的路徑,如這里設置的是C:\Program Files\Java\jdk1.5.0_05\bin\rmiregistry.exe,一般不用管它。下面的一個框是RMI的服務端口,默認是 1099,這個類似tomcat的服務端口8080一樣,鏈接的時候需要找到對應的端口才能鏈接上。其實RMI的最低層是socket。

  •        這里需要特別指出的是RMI Plugin是個收費的Eclipse插件,有15天的免費試用期。而RMI屬性中最大的窗口就是填使用授權信息的。我的網站論壇提供破解版本的下載供個人研究之用。

  •        開發環境到這里也只是基本的設計完成,其他的還要在具體的項目中進行設置,下面我們就開發一個簡單的演示項目。

  • 四、開發演示項目
  •        這里偷一下懶,引用別人的一篇文章的實例,大家可以比照在eclipse中創建該項目;也可以順便了解一下RMI的基本機制,和不用工具的開發方法。

  •  文章地址: http://www.inspiresky.com/bbs/dispbbs.asp?boardID=22&ID=1687&page=1
  •        這里采用第五樓文章中的例子。如果你對RMI沒有什么太多了解請一定先看此文章。              這里我們一步一步來在eclipse中創建我們的演示項目:         
  •        1、啟動eclipse,新建項目
  •        菜單file->new->projects->java projects,點擊next,projects name 為RMITest。其他默認,點擊next,點擊finish。OK,新項目建成。

  •         2、新建服務器包
  •        左邊樹中右鍵項目RMITest,new->package,新建包com.inspiresky.rmi.server。

  •         3、創建遠程對象接口類
  •        右鍵點擊剛才創建的包,new->Interface,新建接口I_Hello。然后編輯我們新建的接口,代碼如下所示:      

  •          package com.inspiresky.rmi.server;

  •         import java.rmi.Remote;  
  •         import java.rmi.RemoteException;

  •         /*
  •       * Junsan        */

  •         public interface I_Hello extends Remote{                public String SayHello() throws RemoteException;         }

  •       4、定義一個實現該接口的類
  •        右鍵點擊剛才創建的包,new->class,新建類文件Hello。然后編輯我們新建的接口,代碼如下所示:      

  •           package com.inspiresky.rmi.server;

  •         import java.rmi.RemoteException;         import java.rmi.server.UnicastRemoteObject;
  •         /*
  •       * Junsan
  •       */
  •         public class Hello extends UnicastRemoteObject implements I_Hello{       
  •                private static final long serialVersionUID = -8868676826752697887L;
  •                public Hello() throws RemoteException
  •             {
  •            }
  •             public String SayHello()      //這個是實現I_Hello接口的方法
  •             {
  •                  return "Hello world !!";
  •             }
  •         }       
  •        好了到此,已經完成了主要服務對象的編寫工作。       
  •         5、生成程序的存根文件
  •        右鍵點擊工程名稱 RMITest,RMI->Enable Stubs Generations。選中后,在我們工程文件夾RMITest/bin下的相應的包中 com\inspiresky\rmi\server下就自動生成了Hello_Stub.class類。
  •         6、創建RMI服務器類
  •        同4中的過程,新建類RMI_Server,并編輯器代碼為:      
  •         package com.inspiresky.rmi.server;
  •         import java.rmi.Naming;
  •         /*
  •        * Junsan
  •        */
  •         public class RMI_Server {
  •                public RMI_Server() {
  •                }
  •                public static void main(String[] args) {
  •                       try {
  •                              Hello hello = new Hello();
  •                              Naming.rebind("RMI_Hello", hello);
  •                              System.out.println("=== Hello server Ready === ");
  •                       } catch (Exception exception) {
  •                              exception.printStackTrace();
  •                       }
  •                }
  •         }
  •         7、新建客戶端包
  •        方法同2,包名com.inspiresky.rmi.client。
  •         8、創建客戶端
  •        在新建的包中同4過程,創建類RMI_Client。并編輯代碼如下:      
  •        package com.inspiresky.rmi.client;
  •         import java.rmi.Naming;
  •         import com.inspiresky.rmi.server.I_Hello;
  •         /*
  •        * Junsan
  •        */
  •         public class RMI_Client {
  •                public RMI_Client() {
  •                       super();
  •                }
  •                public static void main(String[] args) {
  •                       try {
  •                              I_Hello hello = (I_Hello) Naming.lookup("RMI_Hello");
  •                              System.out.println(hello.SayHello());
  •                       } catch (Exception e) {
  •                              e.printStackTrace();
  •                       }
  •                }
  •         }
  •         OK,到這里我們就可以準備調試運行我們的程序了。
  • 五、運行調試項目
  •        在運行之前需要進行一下設置,否則,會提示錯誤信息,說找不到stub類。
  •         1、啟動RMIRegistry
  •         Eclipse菜單window->show view->others,在彈出菜單中選擇RMI Views->RMI Registry Inspector,這是會多出來一個窗口,這里可以顯示已經注冊的RMI應用。
  •        點擊工具條上的RMI Plugin圖標,在菜單中選擇Start Local Registry。
  •        注意這個只需要啟動一次,除非你把它關掉。
  •         2、配置運行RMI服務
  •        右鍵點擊左邊樹中的RMI_Server.java文件,菜單Debug As ->RMI Application。在彈出對話框中找到RMI Properties標簽頁。
  •        這時這里前兩項顯示紅色。
  •        選中java.security.police項的value框,點擊選擇按鈕會出現文件選擇對話框,我們這里設置成C:\Program Files\Java\jre1.5.0_05\lib\security\java.security。就是jre的安全策略配置文件,要選擇成泥當前用的jdk的側略文件。
  •        選中第二項java.rmi.server.codebase的value項,這里選擇編譯后類包所在的文件夾。點擊 選擇按鈕->add按鈕->pick from workspace,選擇當前工程RMITest的bin文件夾。這里是file:/E: /workspace/RMITest/bin/。
  • (這里有點要補充一下,還可以 點擊選擇按鈕->add按鈕->compute from classpath)
  •        點擊apply按鈕。
  •        點擊debug按鈕。
  •        這時Eclipse的console窗口中出現
  •        === Hello server Ready ===
  •     表示RMI服務已經運行。   
  •         3、設置調試信息
  •        打開Hello.java文件,在       
  •         return "Hello world !!";       
  •        處設置斷點。
  •         4、運行客戶端,調試程序
  •        工程樹中,右鍵點擊RMI_Client.java文件,Run As -> Java Application。
  •        我們點擊后,窗口一閃而過,停止后,會發現光標已經停止在我們設定斷點的地方。這里程序沒有錯誤,我們按F6鍵繼續,會進入程序下一步的運行文件,調試的時候就是這樣子一步一步調試下去。這里我們按F8直接運行完代碼,在console窗口中會顯示
  •        Hello world !!
  •        表示程序已經運行成功。


  • 非洲小白臉 2009-09-29 17:09 發表評論
    ]]>
    CentOS 下 ftp 的配置介紹http://www.aygfsteel.com/ocean07000814/articles/292150.html非洲小白臉非洲小白臉Fri, 21 Aug 2009 10:37:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/292150.htmlhttp://www.aygfsteel.com/ocean07000814/comments/292150.htmlhttp://www.aygfsteel.com/ocean07000814/articles/292150.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/292150.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/292150.html CentOS 下 ftp 的配置介紹

    首先,安裝的時候要勾選ftp服務,centos會幫你裝上vsftpd這個ftp服務器并把它標為系統服務。
    啟動命令:/etc/rc.d/init.d/vsftpd start
    這時候可以使用ftp客戶端連接。
    vsftpd的權限貌似和系統權限有掛鉤。

    下面是抄來的配置解釋vsftpd的配置
    vsftpd.ftpusers:位于/etc目錄下。它指定了哪些用戶賬戶不能訪問FTP服務器,例如root等。
    vsftpd.user_list:位于/etc目錄下。該文件里的用戶賬戶在默認情況下也不能訪問FTP服務器,僅當vsftpd .conf配置文件里啟用userlist_enable=NO選項時才允許訪問。
    vsftpd.conf:位于/etc/vsftpd目錄下。來自定義用戶登錄控制、用戶權限控制、超時設置、服務器功能選項、服務器性能選項、服務器響應消息等FTP服務器的配置。

    (1)用戶登錄控制
    anonymous_enable=YES,允許匿名用戶登錄。
    no_anon_password=YES,匿名用戶登錄時不需要輸入密碼。
    local_enable=YES,允許本地用戶登錄。
    deny_email_enable=YES,可以創建一個文件保存某些匿名電子郵件的黑名單,以防止這些人使用Dos攻擊。
    banned_email_file=/etc/vsftpd.banned_emails,當啟用deny_email_enable功能時,所需的電子郵件黑名單保存路徑(默認為/etc/vsftpd.banned_emails)。

    (2)用戶權限控制
    write_enable=YES,開啟全局上傳權限。
    local_umask=022,本地用戶的上傳文件的umask設為022(系統默認是077,一般都可以改為022)。
    anon_upload_enable=YES,允許匿名用戶具有上傳權限,很明顯,必須啟用write_enable=YES,才可以使用此項。同時我們還必須建立一個允許ftp用戶可以讀寫的目錄(前面說過,ftp是匿名用戶的映射用戶賬號)。
    anon_mkdir_write_enable=YES,允許匿名用戶有創建目錄的權利。
    chown_uploads=YES,啟用此項,匿名上傳文件的屬主用戶將改為別的用戶賬戶,注意,這里建議不要指定root賬號為匿名上傳文件的屬主用戶!
    chown_username=whoever,當啟用chown_uploads=YES時,所指定的屬主用戶賬號,此處的whoever自然要用合適的用戶賬號來代替。
    chroot_list_enable=YES,可以用一個列表限定哪些本地用戶只能在自己目錄下活動,如果chroot_local_user=YES,那么這個列表里指定的用戶是不受限制的。
    chroot_list_file=/etc/vsftpd.chroot_list,如果chroot_local_user=YES,則指定該列表(chroot_local_user)的保存路徑(默認是/etc/vsftpd.chroot_list)。
    nopriv_user=ftpsecure,指定一個安全用戶賬號,讓FTP服務器用作完全隔離和沒有特權的獨立用戶。這是vsftpd系統推薦選項。
    async_abor_enable=YES,強烈建議不要啟用該選項,否則將可能導致出錯!
    ascii_upload_enable=YES;ascii_download_enable=YES,默認情況下服務器會假裝接受ASCⅡ模式請求但實際上是忽略這樣的請求,啟用上述的兩個選項可以讓服務器真正實現ASCⅡ模式的傳輸。
    注意:啟用ascii_download_enable選項會讓惡意遠程用戶們在ASCⅡ模式下用“SIZE/big/file”這樣的指令大量消耗FTP服務器的I/O資源。
    這些ASCⅡ模式的設置選項分成上傳和下載兩個,這樣我們就可以允許ASCⅡ模式的上傳(可以防止上傳腳本等惡意文件而導致崩潰),而不會遭受拒絕服務攻擊的危險。

    (3)用戶連接和超時選項
    idle_session_timeout=600,可以設定默認的空閑超時時間,用戶超過這段時間不動作將被服務器踢出。
    data_connection_timeout=120,設定默認的數據連接超時時間。

    (4)服務器日志和歡迎信息
    dirmessage_enable=YES,允許為目錄配置顯示信息,顯示每個目錄下面的message_file文件的內容。
    ftpd_banner=Welcome to blah FTP service,可以自定義FTP用戶登錄到服務器所看到的歡迎信息。
    xferlog_enable=YES,啟用記錄上傳/下載活動日志功能。
    xferlog_file=/var/log/vsftpd.log,可以自定義日志文件的保存路徑和文件名,默認是/var/log/vsftpd.log。



    非洲小白臉 2009-08-21 18:37 發表評論
    ]]>
    centos下postgresql的安裝與配置http://www.aygfsteel.com/ocean07000814/articles/292065.html非洲小白臉非洲小白臉Fri, 21 Aug 2009 03:45:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/292065.htmlhttp://www.aygfsteel.com/ocean07000814/comments/292065.htmlhttp://www.aygfsteel.com/ocean07000814/articles/292065.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/292065.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/292065.htmlcentos下postgresql的安裝與配置

    一、安裝(以root身份進行)

    1、檢出最新的postgresql的yum配置從http://yum.pgsqlrpms.org/reporpms/repoview/pgdg-centos.html

    然后根據版本選擇需要的rpm后執行下列命令

    rpm -Uvh http://yum.pgsqlrpms.org/reporpms/8.3/pgdg-centos-8.3-6.noarch.rpm

    2、安裝或者升級postgresql-libs

    yum upgrade postgresql-libs

    3、安裝postgresql

    yum install postgresql postgresql-server

    4、初始化數據庫以及啟動服務

    service postgresql initdb

    service postgresql start

    二、配置

    在配置之前需將postgresql的端口號5432在iptables下開放。

    yum安裝postgresql后的安裝路徑為:/var/lib/pgsql下,主要配置文件在其data文件夾下,進入data文件夾

    1、修改postgresql.conf文件

    如果想讓PostgreSQL監聽整個網絡的話,將listen_addresses前的#去掉,并將listen_addresses = 'localhost'改成listen_addresses = '*'

    2、修改pg_hba.conf

    這個文件最后有一個列表,它決定了分派了每一個用戶的權限,以及認證方式。格式是“Type Database User Address Method”,要注意的是method最好寫md5。

    在列表后追加一行:host    all         all         192.168.1.0/24        password

    3、修改postgres用戶密碼:passwd postgres

    4、暫時將pg_hba.conf中,本機的認證方式改為trust,切換當前用戶為postgres:su postgres

    5、用psql登錄PostgreSQL系統,“SELECT * FROM pg_shadow;”,發現這個表里的postgres這個用戶根本還沒有存儲密碼;于是,再“ALTER USER postgres PASSWORD '它的密碼';

    6、重啟服務/etc/init.d/postgresql restart,連接成功。



    非洲小白臉 2009-08-21 11:45 發表評論
    ]]>
    CentOS Samba 服務器的構建http://www.aygfsteel.com/ocean07000814/articles/292056.html非洲小白臉非洲小白臉Fri, 21 Aug 2009 01:48:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/292056.htmlhttp://www.aygfsteel.com/ocean07000814/comments/292056.htmlhttp://www.aygfsteel.com/ocean07000814/articles/292056.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/292056.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/292056.html[轉]CentOS Samba 服務器的構建

    前  言

    在我們使用 Windows 作為客戶機的時候,通常有文件、打印共享的需求。作為Windows 網絡功能之一,通常可以在 Windows 客戶機之間通過 Windows Network 固有的功能實現這些要求。然而,通過 Samba 我們也可以讓一臺 CentOS 主機來兼容 Windows 網絡,實現同樣的功能,進而充分發揮 CentOS 主機的可用性。

    本篇文檔主要介紹怎樣通過 Samba 服務器的構建實現 Windows 網絡中的文件共享。

    安裝 Samba

    首先,通過 yum 來在線安裝 Samba 。

    [root@sample ~]# yum -y install samba  ← 安裝 Samba

    Setting up Install Process
    Setting up repositories
    update 100% |=========================| 951 B 00:00
    base 100% |=========================| 1.1 kB 00:00
    addons 100% |=========================| 951 B 00:00
    extras 100% |=========================| 1.1 kB 00:00
    Reading repository metadata in from local files
    primary.xml.gz 100% |=========================| 73 kB 00:00
    update : ################################################## 212/212
    Added 212 new packages, deleted 0 old in 4.94 seconds
    primary.xml.gz 100% |=========================| 569 kB 00:00
    base : ################################################## 1500/1500
    Added 1500 new packages, deleted 0 old in 28.97 seconds
    primary.xml.gz 100% |=========================| 157 B 00:00
    Added 0 new packages, deleted 0 old in 0.03 seconds
    primary.xml.gz 100% |=========================| 32 kB 00:00
    extras : ################################################## 124/124
    Added 124 new packages, deleted 0 old in 1.93 seconds
    Parsing package install arguments
    Resolving Dependencies
    --> Populating transaction set with selected packages. Please wait.
    ---> Downloading header for samba to pack into transaction set.
    samba-3.0.10-1.4E.9.i386. 100% |=========================| 101 kB 00:00
    ---> Package samba.i386 0:3.0.10-1.4E.9 set to be updated
    --> Running transaction check
    --> Processing Dependency: samba-common = 0:3.0.10 for package: samba
    --> Restarting Dependency Resolution with new changes.
    --> Populating transaction set with selected packages. Please wait.
    ---> Downloading header for samba-common to pack into transaction set.
    samba-common-3.0.10-1.4E. 100% |=========================| 37 kB 00:00
    ---> Package samba-common.i386 0:3.0.10-1.4E.9 set to be updated
    --> Running transaction check Dependencies Resolved
    =============================================================================
    Package Arch Version Repository Size
    =============================================================================
    Installing:
    samba i386 3.0.10-1.4E.9 base 13 M
    Installing for dependencies:
    samba-common i386 3.0.10-1.4E.9 base 5.0 M
    Transaction Summary
    =============================================================================
    Install 2 Package(s)
    Update 0 Package(s)
    Remove 0 Package(s)
    Total download size: 18 M
    Downloading Packages:
    (1/2): samba-common-3.0.1 100% |=========================| 5.0 MB 00:04
    (2/2): samba-3.0.10-1.4E. 100% |=========================| 13 MB 00:11
    warning: rpmts_HdrFromFdno: V3 DSA signature: NOKEY, key ID 443e1821
    Public key for samba-common-3.0.10-1.4E.9.i386.rpm is not installed
    Retrieving GPG key from http://mirror.centos.org/centos/RPM-GPG-KEY-centos4
    Importing GPG key 0x443E1821 "CentOS-4 key <centos-4key@centos.org>"
    Key imported successfully
    Running Transaction Test
    Finished Transaction Test
    Transaction Test Succeeded
    Running Transaction
    Installing: samba-common ######################### [1/2]
    Installing: samba ######################### [2/2]
    Installed: samba.i386 0:3.0.10-1.4E.9
    Dependency Installed: samba-common.i386 0:3.0.10-1.4E.9
    Complete!

    配置 Samba
    然后,通過編輯 /etc/samba/smb.conf ,根據需求配置 Samba。在這里,本文的原則是只將文件共享應用于內網,并讓將要被共享的目錄擁有充分的讀寫權限屬性。
    [root@sample ~]# vi /etc/samba/smb.conf  ← 編輯 Samba 的配置文件

    #======================= Global Settings =====================================
    [global]   ← 找到這一行(全局設置標簽),在此行下面添加如下行:

    dos charset = GB2312  ← 將 Windows 客戶端的文字編碼設置為簡體中文 GB2312
    unix charset = GB2312  ← 指定 Samba 所在的 CentOS 服務端新建文件或目錄時的編碼為 GB2312
    display charset = GB2312  ← 指定使用 SWAT(一種通過瀏覽器控制Samba的工具)時頁面的默認文字編碼
    directory mask = 0777  ← 指定新建目錄的屬性(以下4行)
    force directory mode = 0777
    directory security mask = 0777
    force directory security mode = 0777
    create mask = 0777  ← 指定新建文件的屬性(以下4行)
    force create mode = 0777
    security mask = 0777
    force security mode = 0777

    workgroup = MYGROUP  ← 找到此行,將工作組名稱改為 Windows 網絡所定義的工作組名

    workgroup = WORKGROUP  ← 變為此狀態,這里以 Windows XP 默認的“WORKGROUP”為例

    ; hosts allow = 192.168.1. 192.168.2. 127.  ← 找到此行,去掉行首的“;”,并制定訪問限制

    hosts allow = 192.168.0. 127.  ← 變為此狀態,指定內網IP地址及本地,只允許這兩種情況的訪問

    然后在配置文件的末尾填如下幾行,定義公眾共享目錄:

    [public]
    comment = Public Stuff
    path = /home/samba  ← 指定共享目錄位置
    public = yes
    writable = yes  ← 賦予共享目錄寫入權限的屬性
    接下來,創建將要通過 Samba 共享給 Windows 網絡的專用目錄。
    [root@sample ~]# mkdir /home/samba  ← 建立共享文件專用目錄

    [root@sample ~]# chown -R nobody. /home/samba  ← 設置專用目錄歸屬為 nobody

    [root@sample ~]# chmod 777 /home/samba  ← 將專用目錄屬性設置為 777

    在進行到服務端的連接之前,需要預先對用于登錄 Samba 的用戶進行設置。這里我們以 CentOS 中 Samba 標準的 Samba 用戶數據庫管理工具“smbpasswd”為例,創建用于登錄 Samba 的用戶數據。這里需要注意的一點:用 smbpasswd 創建用戶的前提是,系統用戶中存在該用戶 -- 在基于系統用戶之上,才可以創建該用戶在 Samba 用戶數據庫中的信息。

    [root@sample ~]# smbpasswd -a centospub  ← 將系統用戶 centospub(例)加入到 Samba 用戶數據庫

    New SMB password:  ← 輸入該用戶用于登錄 Samba 的密碼
    Retype new SMB password:  ← 再次確認輸入該密碼
    Added user centospub.

    啟動 Samba 服務
    在啟動 Samba 服務之前,首先將防火墻設置中 Samba 所用到的端口進行開放。
    [root@sample ~]# vi /etc/sysconfig/iptables  ← 編輯 iptables 配置文件

    -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 25 -j ACCEPT  ← 找到此行,在下面添加如下行:
    -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 139 -j ACCEPT
    -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 445 -j ACCEPT
    -A RH-Firewall-1-INPUT -p udp -m udp --dport 137 -j ACCEPT
    -A RH-Firewall-1-INPUT -p udp -m udp --dport 138 -j ACCEPT

    [root@sample ~]# /etc/rc.d/init.d/iptables restart  ← 重新啟動 iptables ,使新的規則生效
    Flushing firewall rules:          [ OK ]
    Setting chains to policy ACCEPT: filter   [ OK ]
    Unloading iptables modules:       [ OK ]
    Applying iptables firewall rules:      [ OK ]
    最后,啟動 Samba 服務。
    [root@sample ~]# chkconfig smb on  ← 設置 Samba 自啟動

    [root@sample ~]# chkconfig --list smb  ← 確認 Samba 啟動標簽,確認 2-5 為 on 的狀態
    smb 0:off 1:off 2:on 3:on 4:on 5:on 6:off

    [root@sample ~]# /etc/rc.d/init.d/smb start  ← 啟動 Samba 服務
    Starting SMB services:       [ OK ]
    Starting NMB services:       [ OK ]

    從 Windows 客戶端連接到 Samba 服務器
    在服務端啟動 Samba 服務后,我們就可以從 Windows 客戶端通過 Windows 網絡連接到 Samba。這里以 Windows XP 為例,說明如下連接過程:

    1、從桌面打開“網上鄰居”,并點擊“查看工作組計算機”選項;



    2、確認出現 Samba 服務端的連接,并雙擊該連接;(本站文檔的主機名以 Sample 為例)



    3、輸入在服務端預先設置好的 Samba 用戶的用戶名及密碼;(用戶名同系統用戶名,密碼需要輸入在通過 smbpasswd 為該系統用戶設置的 Samba 專用的密碼。)



    4、然后確認能夠連接到 Samba 服務器,并出現根目錄及 Samba 專用共享目錄。



    最后,在相應目錄進行新建、修改以及刪除文件的操作,測試相應權限的可操作性。


    非洲小白臉 2009-08-21 09:48 發表評論
    ]]>
    native2ascii.exe -reverse file1.properties file2.propertieshttp://www.aygfsteel.com/ocean07000814/articles/283061.html非洲小白臉非洲小白臉Thu, 18 Jun 2009 07:37:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/283061.htmlhttp://www.aygfsteel.com/ocean07000814/comments/283061.htmlhttp://www.aygfsteel.com/ocean07000814/articles/283061.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/283061.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/283061.html

    非洲小白臉 2009-06-18 15:37 發表評論
    ]]>
    properties文件讀入http://www.aygfsteel.com/ocean07000814/articles/281776.html非洲小白臉非洲小白臉Fri, 12 Jun 2009 03:20:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/281776.htmlhttp://www.aygfsteel.com/ocean07000814/comments/281776.htmlhttp://www.aygfsteel.com/ocean07000814/articles/281776.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/281776.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/281776.htmlpackage test;

    import java.util.*;
    import java.io.*;


    public class test {

     
    public String getPara(String fileName) {
      Properties prop 
    = new Properties();
      
    try {
       InputStream is 
    = getClass().getResourceAsStream(fileName);
       prop.load(is);
       
    if (is != null)
        is.close();
      }
     catch (Exception e) {
       System.out.println(e 
    + "file " + fileName + " not found");
      }

      
    return prop.getProperty("db");
     }


     
    public static void main(String[] args) {
      test test 
    = new test();
      System.out.println(test.getPara(
    "db.properties"));
     }

    }


    java文件同級目錄下建立db.properties,
    內容  db=123445



    非洲小白臉 2009-06-12 11:20 發表評論
    ]]>
    Eclipse的遠程調試http://www.aygfsteel.com/ocean07000814/articles/256208.html非洲小白臉非洲小白臉Mon, 23 Feb 2009 05:52:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/256208.htmlhttp://www.aygfsteel.com/ocean07000814/comments/256208.htmlhttp://www.aygfsteel.com/ocean07000814/articles/256208.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/256208.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/256208.html
    在本地計算機上調試 Java™ 應用程序并不是惟一的選擇。學習如何使用構成遠程調試的不同連接類型進行遠程調試。本文概述了設置遠程應用程序調試的特性和示例。

    遠程調試對應用程序開發十分有用。例如,為不能托管開發平臺的低端機器開發程序,或在專用的機器上(比如服務不能中斷的 Web 服務器)調試程序。其他情況包括:運行在內存小或 CUP 性能低的設備上的 Java 應用程序(比如移動設備),或者開發人員想要將應用程序和開發環境分開,等等。

    先決條件

    啟動配置類型
    啟動配置 保存一組用于啟動程序的屬性。啟動配置類型是一種可以在 Eclipse 平臺上啟動的獨特程序。

    如果您還沒安裝該程序,請下載 Eclipse V3.4(Ganymede)。在 Ganymede 中,套接字(socket)監聽連接器被添加到 Remote Java Application 啟動配置類型。Eclipse 最新的套接字監聽連接器允許您打開 Java 調試器,它能夠監聽特定套接字上的連接。可以從命令行選項打開被調試的程序,并將其連接到調試器。在 Ganymede 發布之前,僅有一個連接套接字的連接器,被調試的程序所在的機器必須是一個與調試器相連的調試主機。由于受到內存和 CPU 不足的限制,要想讓移動設備充當主機是不現實的。

    為了進行遠程調試,必須使用 Java Virtual Machine (JVM) V5.0 或更新版本,比如 IBM® J9 或 Sun Microsystem 的 Java SE Development Kit(JDK)。本文主要討論遠程調試,而不是每個 Eclipse 調試特性的細節。查看 參考資料 獲得更多關于使用 Eclipse 進行調試的信息,并且可以找到上面提到的軟件。

    JPDA 簡介

    常用縮寫詞
    • JDI — Java 調試接口(Java Debug Interface)
    • JDT — Java 開發工具(Java Development Tools)
    • JDWP — Java 調試網絡協議(Java Debug Wire Protocol)
    • JPDA — Java 平臺調試器架構(Java Platform Debugger Architecture)
    • JVM — Java 虛擬機(Java Virtual Machine)
    • JVMDI — JVM 調試接口(JVM Debug Interface)
    • JVMTI — JVM 工具接口(JVM Tool Interface)
    • VM — 虛擬機(Virtual Machine)

    Sun Microsystem 的 Java Platform Debugger Architecture (JPDA) 技術是一個多層架構,使您能夠在各種環境中輕松調試 Java 應用程序。JPDA 由兩個接口(分別是 JVM Tool Interface 和 JDI)、一個協議(Java Debug Wire Protocol)和兩個用于合并它們的軟件組件(后端和前端)組成。它的設計目的是讓調試人員在任何環境中都可以進行調試。JPDA 不僅能夠用于桌面系統,而且能夠在嵌入式系統上很好地工作。

    JVM Tool Interface (JVMTI) 規定必須為調試提供 VM(編輯注:從 Java V5 開始,將用 JVMTI 代替 Java V1.4 中的 JVMDI)。Java Debug Wire Protocol (JDWP) 描述調試信息的格式,以及在被調試的進程和調試器前端之間傳輸的請求,調試器前端實現 JDI,比如 Eclipse、Borland JBuilder 等。根據 Sun 的 JPDA 規范,被調試的程序常常稱為 debuggee。JDI 是一個高級的接口,它定義用于遠程調試的信息和請求。下面給出了調試器的架構。


    清單 1. Java 平臺調試器架構
                Components                      Debugger Interfaces
                /    |--------------|
                /     |     VM       |
                debuggee -----(      |--------------|  <---- JVMTI - Java VM Tool Interface
                \     |   back-end   |
                \    |--------------|
                /           |
                comm channel --(            |  <------------ JDWP - Java Debug Wire Protocol
                \           |
                /    |--------------|
                /     |  front-end   |
                debugger -----(      |--------------|  <---- JDI - Java Debug Interface
                \     |      UI      |
                \    |--------------|
                

    因此,任何第三方工具和基于 JPDA 的 VM 應該都能協調工作。通過這個客戶機-服務器架構,您可以從運行該平臺的本地工作站調試 Java 程序,甚至還可以通過網絡進行遠程調試。

    在討論調試場景之前,我們先了解 JPDA 規范中的兩個術語:連接器和傳輸。連接器是一個 JDI 抽象,用來在調試器應用程序和目標 VM 之間建立連接。傳輸定義應用程序如何進行訪問,以及數據如何在前端和后端之間傳輸。連接器 “映射” 到可用的傳輸類型和連接模式。在 Sun 的 JPDA 參考實現中,為 Microsoft® Windows® 提供了兩個傳輸機制:套接字傳輸和共享內存傳輸。可用的連接器:

    • 連接套接字連接器
    • 連接共享內存連接器
    • 監聽套接字連接器
    • 監聽共享內存連接器
    • 啟動命令行連接器

    在調試器應用程序和目標 VM 之間建立連接時,有一端將用作服務器并監聽連接。隨后,另一端將連接到監聽器并建立一個連接。通過連接,調試器應用程序或目標 VM 都可以充當服務器。進程之間的通信可以在同一個機器或不同的機器上運行。

    要遠程調試 Java 程序,難點不是在調試器的前端,而是遠程 Java 后端。不幸的是,Eclipse 幫助系統中為這方面提供的信息并不多。事實上,JDI 和 JVMTI 是分別由 Eclipse 和 Java 運行時環境實現的。我們僅需要考慮 JDMP,因為它包含與 JVMTI 和 JDI 進行通信所需的信息。JDWP 包含許多參數,用于為遠程 Java 應用程序調用所需的程序。以下是本文用到的一些參數。

    -Xdebug
    啟用調試特性。
    -Xrunjdwp:<sub-options>
    在目標 VM 中加載 JDWP 實現。它通過傳輸和 JDWP 協議與獨立的調試器應用程序通信。下面介紹一些特定的子選項。

    從 Java V5 開始,您可以使用 -agentlib:jdwp 選項,而不是 -Xdebug 和 -Xrunjdwp。但如果連接到 V5 以前的 VM,只能選擇 -Xdebug 和 -Xrunjdwp。下面簡單描述 -Xrunjdwp 子選項。

    transport
    這里通常使用套接字傳輸。但是在 Windows 平臺上也可以使用共享內存傳輸。
    server
    如果值為 y,目標應用程序監聽將要連接的調試器應用程序。否則,它將連接到特定地址上的調試器應用程序。
    address
    這是連接的傳輸地址。如果服務器為 n,將嘗試連接到該地址上的調試器應用程序。否則,將在這個端口監聽連接。
    suspend
    如果值為 y,目標 VM 將暫停,直到調試器應用程序進行連接。

    要獲得每個調試設置的詳細解釋,請參考 JPDA 文檔(參見 參考資料)。

    清單 2 是一個示例,顯示如何在調試模式下啟動 VM 并監聽端口 8765 的套接字連接。


    清單 2. 作為調試服務器的目標 VM
                -Xdebug -Xrunjdwp:transport=dt_socket,server=y,address=8765
                

    清單 3 顯示如何使用位于 8000 端口的主機 127.0.0.1 上的套接字連接運行中的調試器應用程序。


    清單 3. 作為調試客戶機的目標 VM
                -Xdebug -Xrunjdwp:transport=dt_socket,address=127.0.0.1:8000
                





    Eclipse 中的遠程調試特性

    Eclipse 是一個圖形化 Java 調試器前端。JDI 在 org.eclipse.jdt.debug 包中實現。本文不詳細討論 JDI 實現。參見 參考資料 獲得關于 Eclipse JDT 和 Java JDI 技術的信息。

    我們首先應該知道要使用哪個 Eclipse 連接器。要了解 Eclipse 提供的遠程連接類型,您可以轉到 Eclipse 菜單并選擇 Run > Debug Configurations...,在 Remote Java Application 中添加一個啟動配置,然后從下拉列表中選擇連接器。在 Ganymede 中共有兩個連接器:

    • Socket Attach
    • Socket Listen

    對于監聽套接字的連接器,Eclipse VM 將是與遠程 Java 應用程序連接的主機。對于連接套接字的連接器,目標 VM 將作為主機。這兩種連接器對應用程序調試沒有影響,用戶可以任意選擇。但根據經驗,需要使用速度更快、更強大的計算機作為 VM 調試主機,因為需要計算的資源很多。

    在調試 Java 應用程序之前,需要確保已經為遠程應用程序啟用所有調試選項。如果選項信息不可用,您將收到一個錯誤信息,比如 “Debug information is not available” 或 “Unable to install breakpoint due to missing line number”。您可以通過更改 Eclipse 菜單上的 Window > Preferences > Java > Compiler 來修改設置。


    圖 1. Eclipse 中的調試選項
    Eclipse 中的調試選項





    遠程調試應用程序

    現在,我們已經準備好遠程調試應用程序。我們分步執行:

    1. 使用簡單類創建一個 Java 項目
    我們為調試創建一個簡單類。清單 4 給出了示例代碼。

    清單 4. 調試示例代碼
                package com.ibm.developerWorks.debugtest;
                public class test {
                public static void main(String[] args) {
                System.out.println("This is a test.");
                }
                }
                

    2. 設置一個斷點
    在代碼中設置一個斷點。在這個例子中,我們在 System.out.println("This is a test."); 這行中設置斷點。

    圖 2. 在 Eclipse 中設置斷點
    在 Eclipse 中設置斷點
    3. 從本地調試應用程序
    在調試應用程序之前,確保已經為項目啟用圖 1 中描述的調試選項。從本地調試應用程序是沒有必要的,但是這可以確保是否所有調試信息都可用。右鍵單擊 Java 項目,并選擇 Debug As,然后選擇 Java Application(參見圖 3)。如果應用程序在斷點處停止執行,則表明調試信息正確顯示。這時,可以繼續使用這些調試特性,比如顯示調試堆棧、變量或斷點管理等等。

    圖 3. 從本地調試應用程序
    從本地調試應用程序
    4. 導出 Java 項目
    我們將使用這個應用程序作為調試目標。右鍵單擊 Java 項目,選擇 Export,然后選擇 Java,最后選擇 JAR file 或 Runnable JAR file 導出項目。將在指定的位置生成 JAR 文件。注意,如果 Java 源代碼與目標應用程序不匹配,調試特性將不能正常工作。
    5. 手動運行 Java 應用程序
    打開控制臺手動啟動應用程序,確保正確配置了 Java 運行時環境。

    清單 5. 調用 Java 應用程序的示例
                java -jar test.jar
                

    6. 遠程調試應用程序
    將 JAR 文件復制到遠程計算機或同一臺計算機上的適當位置,調用調試服務器,然后為它添加一個客戶機。簡單的 Java 應用程序就可以充當調試服務器或客戶機。您可以在 Eclipse 中選擇 Socket Attach 或 Socket Listen 連接類型,這取決于特定的配置。接下來的兩個小節將學習如何將應用程序作為服務器或客戶機運行。

    作為調試服務器的目標 VM

    下面這個示例遠程調用 Java 應用程序作為調試服務器,并在端口 8000 監聽套接字連接。目標 VM 將暫停,直到調試器連接。


    清單 6. Eclipse 連接套接字模式下的 VM 調用示例
                java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,address="8000" -jar
                test.jar
                

    使用遠程啟動配置啟動 Eclipse,并指定遠程應用程序的目標 VM 地址。為此,單擊 Run > Debug Configurations,然后在 Eclipse 菜單中雙擊 Remote Java Application。從最新創建的啟動配置中為目標應用程序指定 IP 和端口。為了在同一臺機器上運行遠程應用程序,僅需將主機 IP 指定為 localhost 或 127.0.0.1。


    圖 4. 連接套接字連接的配置
    連接套接字連接的配置

    選擇 Allow termination of remote VM 選項終止在應用程序調試期間連接的 VM。


    圖 5. Eclipse 中的 Terminate 按鈕
    Eclipse 中的 Terminate 按鈕

    作為調試客戶機的目標 VM

    第二個示例使用一個簡單的 Java 應用程序作為調試客戶機,并且調試器前端作為調試服務器。Eclipse 使用套接字監聽模式連接類型進行監聽。必須先啟動調試前端來監聽特定的端口。圖 6 給出一個用于設置監聽的示例配置。


    圖 6. 監聽套接字連接的配置
    監聽套接字連接的配置

    單擊 Eclipse Debug 按鈕,狀態欄將顯示消息 “waiting for vm to connect at port 8000...”。看到這個消息后,啟動遠程應用程序。清單 7 顯示了如何將 Java 應用程序作為調試客戶機并調用它,然后使用端口 8000 上的主機 127.0.0.1 的套接字將其連接到一個正在運行的調試器應用程序。


    清單 7. Eclipse 監聽套接字連接模式中的 VM 調用示例
                java -Xdebug -Xrunjdwp:transport=dt_socket,address=127.0.0.1:8000,suspend=y
                -jar test.jar
                

    如果一切進行順利,將會顯示一個調試透視圖幫助調試應用程序,并且遠程 Java 應用程序將正常停止。這類似于步驟 3 中的本地調試(參見圖 3)。在這里,您可以使用標準的調試特性,比如設置斷點和值、單步執行等。




    注意:一定是自己編譯的src才可。即:src要與調試的程序一致。

    結束語

    本文演示如何使用 Eclipse 內置的遠程 Java 應用程序配置類型對應用程序執行遠程調試。介紹了如何設置 Java 應用程序以調用遠程調試,并幫助您理解 Eclipse 提供的連接器。最后,您還學習了如何將這些技術應用到項目中。



    非洲小白臉 2009-02-23 13:52 發表評論
    ]]>
    SP寫法實例——日期CHECKhttp://www.aygfsteel.com/ocean07000814/articles/254885.html非洲小白臉非洲小白臉Mon, 16 Feb 2009 06:13:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/254885.htmlhttp://www.aygfsteel.com/ocean07000814/comments/254885.htmlhttp://www.aygfsteel.com/ocean07000814/articles/254885.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/254885.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/254885.htmlSET QUOTED_IDENTIFIER ON
    GO
    SET ANSI_NULLS ON
    GO

    ALTER  PROCEDURE sp****(
     @a  AS VARCHAR(3),
     @b   AS VARCHAR(7),
     @c   AS CHAR(2),
     @d  AS VARCHAR(7)
    ) AS
    BEGIN
     DECLARE @NDTime varchar(50)
     DECLARE @aOD VARCHAR(8)
     DECLARE @dateDif  INT
     DECLARE @JRC VARCHAR(1)

     /* 現在日時取得SP(sp****NowDate)を使用して、日時を取得する。 */
     EXEC sp****NowDate @NDTime OUTPUT

     SELECT @aOD = 字段
     FROM  ****     
     WHERE 字段  = @a
     AND  字段  = @b
     AND  字段   =  @c
    AND  字段  = d
     
     SET @JRC= '1'
     if datediff(d,Convert(datetime,@aOD),Convert(datetime,@NDT)) >= 180 begin
      SET @JRC = '0'
     end
     SELECT @JRC ****
    END


    GO
    SET QUOTED_IDENTIFIER OFF
    GO
    SET ANSI_NULLS ON
    GO

     



    非洲小白臉 2009-02-16 14:13 發表評論
    ]]>
    如何在Eclipse 3.1.1上安裝jadclipse[java的反編譯工具] http://www.aygfsteel.com/ocean07000814/articles/241283.html非洲小白臉非洲小白臉Wed, 19 Nov 2008 01:30:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/241283.htmlhttp://www.aygfsteel.com/ocean07000814/comments/241283.htmlhttp://www.aygfsteel.com/ocean07000814/articles/241283.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/241283.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/241283.htmljad是java的反編譯工具,是命令行執行,反編譯出來的源文件可讀性較高。可惜用起來不太方便。還好

    找到eclipse下的插件,叫jadclipse,安裝好之后,只要雙擊.class文件,就能直接看源文件,包括jar

    包中的class文件,也可以直接反編譯。

    1.下載jad1.5.8
    http://www.kpdus.com/jad.html#download
    下載后解壓。解壓縮后將jad.exe拷貝到JRE的bin目錄下,如\Java\jre1.5.0_06\bin

    2.下載 jadclipse_3.1.0.jar
    http://jaist.dl.sourceforge.net/sourceforge/jadclipse/jadclipse_3.1.0.jar
    將jadclipse_3.1.0.jar復制到D:\Program Files\eclipse\myplugin\eclipse\plugins目錄下(用的是

    link方式安裝插件的)。

    這需要看你的Eclipse版本了
    最新版3.2.2(適用于Eclipse 3.2M5以上,包括3.4.x)在 http://prdownloads.sourceforge.net/jadclipse/jadclipse_3.2.2.jar?download

    3.啟動Eclipse后,在Windows-->Perference-->Java下面應該會多出一個JadClipse目錄,相關的設置可

    以在此修改
    配置jadclipse:設置path to decompiler為jad.exe的全路徑,如:F:\Java\jre1.5.0_06\bin\jad.exe

    ,在Directory for temporary files中指定臨時文件的路徑,如:G:\Java\eclipse-SDK-3.0-win32\temp
    4、在Eclipse的Windows-->Perference-->General->Editors->File Associations中修改“*.class”默

    認關聯的編輯器為“JadClipse Class File Viewer”
    5、安裝完成,雙擊class文件,Eclipse將自動反編譯了。


    自從eclipse升級到3.3以后jad插件就一直沒有成功的安裝上去,網上看了好多文章也是以前版本的安裝方法,3.3目前通過eclipse的software update的插件安裝方式已經不行了。

    目前安裝方式如下:
    1.從http://www.kpdus.com/jad.html#download地址下載最新的jad,我目前下載的是jadnt158.zip

    2.從http://nchc.dl.sourceforge.net/sourceforge/jadclipse/net.sf.jadclipse_3.3.0.jar地址下載jadclipse_3.3.0.jar,拷貝到eclipse的plugins目錄下。

    3.啟動或重起eclipse,修改window -> Preferences -> Java -> JadClipse 下的
    Path to decompiler 如:D:\eric\jadnt158\jad.exe(jadnt158.zip解壓后的目錄)

    4.Windows -> Perference -> General -> Editors -> File Associations中修改“*.class”默認關聯的編輯器為“JadClipse Class File Viewer”



    非洲小白臉 2008-11-19 09:30 發表評論
    ]]>
    Apache 2.x與WEBLOGIC 9集成-Windows篇http://www.aygfsteel.com/ocean07000814/articles/198856.html非洲小白臉非洲小白臉Wed, 07 May 2008 01:30:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/198856.htmlhttp://www.aygfsteel.com/ocean07000814/comments/198856.htmlhttp://www.aygfsteel.com/ocean07000814/articles/198856.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/198856.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/198856.html本文簡要介紹Apache2.x如何與WLS7.0如何集成,主要包括一下內容:
    軟件環境描述
    安裝Apache2.x
    安裝WLS9.0,配置WLS Domain
    Apache2.x與WLS集成

    軟件環境描述
    Windows XP Professional SP4
    Apache 2.0.47
    WebLogic Server 9.0 SP1

    安裝Apache2.x
    從Apache站點下載2.0.47版本的Apache HTTP Server,參考下載地址為:
    http://apache.linuxforum.net/dist/httpd/binaries/win32/apache_2.0.47-win32-x86-no_ssl.msi
    下載完畢后,開始安裝apache。雙擊apache_2.0.47-win32-x86-no_ssl.msi,安裝Apache,出現歡迎畫面,點擊"Next",然后出現協議頁面,選擇同意協議選擇,點擊"Next",出現說明頁面,點擊"Next",然后出現下面所示畫面:

    圖1 配置Apache
    填寫完畢后,點擊"Next",選擇典型安裝,點擊"Next",然后出現選擇安裝路徑,這里取默認值,點擊"Next",然后點擊"Install"按鈕。安裝完畢后,點擊"Finish"按鈕,退出安裝程序。這時候,你會發現在桌面的右下角出現apache的運行監視圖標。

    安裝WLS9.0,配置WLS Domain
    安裝WLS9.0,WLS7.0安裝參數概要如下:

    名稱
    BEA Home C:\bea
    Domain Name base_domain
    Domain類型 WLS Domain
    Domain Location C:\bea\user_projects\
    Server類型 Single Server(Standalone Server)
    Server Name myserver
    myserver的用戶名 weblogic
    myserver的口令 weblogic


    圖2 配置WebLogic

    Apache2.x與WLS集成
    1、 修改C:\WINDOWS\system32\drivers\etc目錄下面的hosts文件。在用記事本把文件打開,在文件的最后加上:127.0.0.1 www.synnex-china.com ,如下圖所示:

    圖3 配置 DNS文件
    2、登陸weblogic的控制臺,發布。然后啟動剛剛創建好的WebLogic Server,如果出現下圖所示的畫面,說明WebLogic Server啟動正常:

    圖4 WebLogic啟動歡迎畫面
    3、進入DOS界面,首先到C:\Program Files\Apache Group\Apache2\bin目錄下面,然后執行Apache -l命令,出現如下畫面:

    圖5 Apache -l命令
    mod_so.c表明當前的Apache HTTP Server是動態加載的模式,可以和WebLogic進行整合(因為Windows平臺下面的WebLogic Server7.0只支持Apache 2.x)。
    然后將附件中的mod_wl_20.so拷貝到C:\Program Files\Apache Group\Apache2\modules目錄下面。然后執行 Apache -t命令,出現如下畫面:

    圖6 Apache -t命令

    這表明Apache 的WebLogic Server plug-in安裝成功。

    4、修改C:\Program Files\Apache Group\Apache2\conf目錄下面的httpd.conf文件。
    首先添加新的和WebLogic相關的應用模塊,在httpd.conf文件的174行加入如下語句:
    #WebLogic Server Proxy Settings
    LoadModule weblogic_module modules/mod_wl_20.so
    <IfModule mod_weblogic.c>
    WebLogicHost www.synnex-china.com
    WebLogicPort 7001
    MatchExpression *.jsp
     MatchExpression *.js
     MatchExpression *.css
     MatchExpression *.do
     MatchExpression *.gif
     MatchExpression *.html
    </IfModule>

    圖7 為Apache 添加WebLogic相關的應用模塊
    然后把httpd.conf文件中的
    DocumentRoot "C:/Program Files/Apache Group/Apache2/htdocs"
    改為
    DocumentRoot "D:/desk/desk_project/src/jsp/desk"       (web項目所在的webapp目錄)
    ,把
    <Directory "C:/Program Files/Apache Group/Apache2/htdocs">
    改為
    <Directory "D:/desk/desk_project/src/jsp/desk">(web項目所在的webapp目錄)

    修改完畢后,重新啟動apache服務,如下圖所示:


    原來訪問地址:http://localhost:7001/desk/Menu.html
    這個時候,你就可以用http://localhost/desk/Menu.html來訪問頁面了  :-)



    非洲小白臉 2008-05-07 09:30 發表評論
    ]]>
    log4j使用說明 [轉] http://www.aygfsteel.com/ocean07000814/articles/86928.html非洲小白臉非洲小白臉Mon, 11 Dec 2006 08:04:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/86928.htmlhttp://www.aygfsteel.com/ocean07000814/comments/86928.htmlhttp://www.aygfsteel.com/ocean07000814/articles/86928.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/86928.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/86928.html
    ?

    1. 下載log4j解壓后在目錄jakarta-log4j-1.2.8dist\lib找到log4j-1.2.8.jar文件拷到

    <Catalina-home>/webapps/test/WEB-INF/lib目錄下

    2.?????? 創建log4j的配置文件log4j.properties,存于目錄:

    <Catalina-home>/webapps/test/WEB-INF

    ?????? 文件內容:

    ?????? log4j.rootLogger=DEBUG, consoleLogger, fileLogger

    log4j.appender.consoleLogger=org.apache.log4j.ConsoleAppender

    log4j.appender.consoleLogger.layout=org.apache.log4j.PatternLayout

    log4j.appender.consoleLogger.Threshold=DEBUG

    log4j.appender.consoleLogger.layout.ConversionPattern=%c{2} - %m%n

    log4j.appender.fileLogger=org.apache.log4j.RollingFileAppender

    log4j.appender.fileLogger.File=c:/tomcat/webapps/test/WEB-INF/blog.txt

    log4j.appender.fileLogger.MaxFileSize=1000KB

    # 保留5個舊的日志文件

    log4j.appender.fileLogger.MaxBackupIndex=5

    log4j.appender.fileLogger.layout=org.apache.log4j.PatternLayout

    # 日志格式按照WebSphere通用日志格式相似的方式記錄

    log4j.appender.fileLogger.layout.ConversionPattern=[%d] %t %c %-5p - %m%n

    3.?????? 創建Blog4jServlet.java

    import org.apache.log4j.Logger;

    import org.apache.log4j.PropertyConfigurator;

    public class BLog4jServlet extends HttpServlet {

    public void init(ServletConfig config) throws ServletException {???????

    ??????? try{

    ??????????? String path = config.getServletContext().getRealPath("/");

    ??????? ??? String propfile = path + config.getInitParameter("propfile");

    ??????????? PropertyConfigurator.configure(propfile);

    ??????? }catch(Exception e){

    ??????????? System.out.println(e.getMessage());

    ??????? }

    ??????? }

    }

    4.???? 修改web.xml,加入如下代碼:

    <servlet>

    ? ?? <servlet-name>log4j</servlet-name>

    <servlet-class>binclude.BLog4jServlet</servlet-class>

    <init-param>

    <param-name>propfile</param-name>

    <param-value>/WEB-INF/log4j.properties</param-value>

    </init-param>

    <load-on-startup>1</load-on-startup>

    </servlet>

    5.???? 在需要調用log的時候:

    import org.apache.log4j.*;

    static Logger logger = Logger.getLogger(DispatchServlet.class.getName());

    logger.debug("this is a log message from" + logger.getName());

    logger.info("info from" + logger.getName());

    logger.warn("warn " + logger.getName());

    logger.error("error" + logger.getName());





    非洲小白臉 2006-12-11 16:04 發表評論
    ]]>
    eclipse插件下載地址大全http://www.aygfsteel.com/ocean07000814/articles/70579.html非洲小白臉非洲小白臉Tue, 19 Sep 2006 09:21:00 GMThttp://www.aygfsteel.com/ocean07000814/articles/70579.htmlhttp://www.aygfsteel.com/ocean07000814/comments/70579.htmlhttp://www.aygfsteel.com/ocean07000814/articles/70579.html#Feedback0http://www.aygfsteel.com/ocean07000814/comments/commentRss/70579.htmlhttp://www.aygfsteel.com/ocean07000814/services/trackbacks/70579.html ?
    ?
    eclipse的插件下載地址大全
    Eclipse及其插件介紹和下載-?-Tag:?Eclipse????插件???????????????????????????????????????????
    0.Eclipse下載
    EMF,GEF?-?Graphical?Editor?Framework,UML2,VE?-?Visual?Editor都在這里下載
    ::URL::http://www.eclipse.org/downloads/index.php
    ?
    0.5.lomboz?J2EE插件,開發JSP,EJB
    ::URL::http://forge.objectweb.org/projects/lomboz
    1.MyEclipse?J2EE開發插件,支持SERVLET/JSP/EJB/數據庫操縱等?
    ::URL::http://www.myeclipseide.com
    ?
    2.Properties?Editor??編輯java的屬性文件,并可以自動存盤為Unicode格式?
    ::URL::http://propedit.sourceforge.jp/index_en.html ?
    ??
    3.Colorer?Take??為上百種類型的文件按語法著色?
    ::URL::http://colorer.sourceforge.net/ ?
    ??
    4.XMLBuddy?編輯xml文件
    ::URL::http://www.xmlbuddy.com ?
    ??
    5.Code?Folding??加入多種代碼折疊功能(比eclipse自帶的更多)?
    ::URL::http://www.coffee-bytes.com/servlet/PlatformSupport ?
    ??
    6.Easy?Explorer??從eclipse中訪問選定文件、目錄所在的文件夾?
    ::URL::http://easystruts.sourceforge.net/ ?
    ??
    7.Fat?Jar?打包插件,可以方便的完成各種打包任務,可以包含外部的包等?
    ::URL::http://fjep.sourceforge.net/ ?
    ??
    8.RegEx?Test?測試正則表達式?
    ::URL::http://brosinski.com/stephan/archives/000028.php ?
    ??
    9.JasperAssistant?報表插件(強,要錢的)?
    ::URL::http://www.jasperassistant.com/ ?
    ??
    10.Jigloo?GUI?Builder?JAVA的GUI編輯插件?
    ::URL::http://cloudgarden.com/jigloo/ ?
    ??
    11.Profiler?性能跟蹤、測量工具,能跟蹤、測量BS程序?
    ::URL::http://sourceforge.net/projects/eclipsecolorer/ ?
    ??
    12.AdvanQas?提供對if/else等條件語句的提示和快捷幫助(自動更改結構等)?
    ::URL::http://eclipsecolorer.sourceforge.net/advanqas/index.html ?
    ??
    13.Log4E?Log4j插件,提供各種和Log4j相關的任務,如為方法、類添加一個logger等?
    ::URL::http://log4e.jayefem.de/index.php/Main_Page ?
    ??
    14.VSSPlugin?VSS插件?
    ::URL::http://sourceforge.net/projects/vssplugin ?
    ??
    15.Implementors?提供跳轉到一個方法的實現類,而不是接中的功能(實用!)?
    ::URL::http://eclipse-tools.sourceforge.net/implementors/ ?
    ??
    16.Call?Hierarchy?顯示一個方法的調用層次(被哪些方法調,調了哪些方法)?
    ::URL::http://eclipse-tools.sourceforge.net/call-hierarchy/index.html ?
    ??
    17.EclipseTidy?檢查和格式化HTML/XML文件?
    ::URL::http://eclipsetidy.sourceforge.net/ ?
    ??
    18.Checkclipse?檢查代碼的風格、寫法是否符合規范?
    ::URL::http://www.mvmsoft.de/content/plugins/checkclipse/checkclipse.htm ?
    ??
    19.Hibernate?Synchronizer?Hibernate插件,自動映射等?
    ::URL::http://www.binamics.com/hibernatesync/ ?
    ??
    20.VeloEclipse??Velocity插件?
    ::URL::http://propsorter.sourceforge.net/ ?
    ??
    21.EditorList?方便的列出所有打開的Editor?
    ::URL::http://editorlist.sourceforge.net/ ?
    ??
    22.MemoryManager?內存占用率的監視?
    ::URL::http://cloudgarden.com/memorymanager/ ?
    ?
    23.swt-designer?java的GUI插件
    ::URL::http://www.swt-designer.com/
    ?
    24.TomcatPlugin?支持Tomcat插件?
    ::URL::http://www.sysdeo.com/eclipse/tomcatPlugin.html
    ?
    25.XML?Viewer?
    ::URL::http://tabaquismo.freehosting.net/ignacio/eclipse/xmlview/index.html
    ?
    26.quantum?數據庫插件
    ::URL::http://quantum.sourceforge.net/
    ?
    27.Dbedit?數據庫插件
    ::URL::http://sourceforge.net/projects/dbedit
    ?
    28.clay.core?可視化的數據庫插件?
    ::URL::http://www.azzurri.jp/en/software/index.jsp ?
    ::URL::http://www.azzurri.jp/eclipse/plugins
    ?
    29.hiberclipse?hibernate插件?
    ::URL::http://hiberclipse.sourceforge.net
    ::URL::http://www.binamics.com/hibernatesync
    ?
    30.struts-console?Struts插件
    ::URL::http://www.jamesholmes.com/struts/console/
    ?
    31.easystruts?Struts插件
    ::URL::http://easystruts.sourceforge.net ?
    ?
    32.veloedit?Velocity插件
    ::URL::http://veloedit.sourceforge.net/
    ?
    33.jalopy?代碼整理插件
    ::URL::http://jalopy.sourceforge.net/
    ?
    34.JDepend?包關系分析
    ::URL::http://andrei.gmxhome.de/jdepend4eclipse/links.html
    ?
    35.Spring?IDE?Spring插件
    ::URL::http://springide-eclip.sourceforge.net/updatesite/
    ?
    36.doclipse?可以產生xdoclet?的代碼提示
    ::URL::http://beust.com/doclipse/


    非洲小白臉 2006-09-19 17:21 發表評論
    ]]>
    主站蜘蛛池模板: 阿拉尔市| 临清市| 庆元县| 汶川县| 定西市| 澜沧| 肥东县| 富源县| 枣阳市| 洪湖市| 射洪县| 方正县| 招远市| 肇庆市| 阿坝县| 彰化市| 鄯善县| 三原县| 奎屯市| 万州区| 信宜市| 兰考县| 崇义县| 江都市| 藁城市| 乌拉特后旗| 砀山县| 永康市| 微博| 桑植县| 桐乡市| 崇左市| 临猗县| 个旧市| 东宁县| 遂溪县| 桂平市| 桑日县| 榆社县| 新龙县| 来宾市|