seasun  
          在不斷模仿、思考、總結中一步一步進步!
          公告
          •     我的blog中的部分資源是來自于網絡上,如果您認為侵犯了您的權利,請及時聯系我我會盡快刪除!E-MAIL:shiwenfeng@aliyun.com和QQ:281340916,歡迎交流。

          日歷
          <2010年1月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          導航

          常用鏈接

          隨筆分類

          good blog author

          積分與排名

          • 積分 - 81762
          • 排名 - 700

          最新評論

          閱讀排行榜

           

          2010年1月24日

          一、首先,模塊的組織更加的細致,從那么多的jar分包就看的出來:

           

          Spring的構建系統以及依賴管理使用的是Apache Ivy,從源碼包看出,也使用了Maven。

          Maven確實是個好東西,好處不再多言,以后希望能進一步用好它。

          二、新特性如下:

          Spring Expression Language (Spring表達式語言)

          IoC enhancements/Java based bean metadata (Ioc增強/基于Java的bean元數據)

          General-purpose type conversion system and UI field formatting system (通用類型轉換系統和UI字段格式化系統)

          Object to XML mapping functionality (OXM) moved from Spring Web Services project (對象到XML映射功能從Spring Web Services項目移出)

          Comprehensive REST support (廣泛的REST支持)

          @MVC additions (@MVC增強)

          Declarative model validation (聲明式模型驗證)

          Early support for Java EE 6 (提前對Java EE6提供支持)

          Embedded database support (嵌入式數據庫的支持)

          三、針對Java 5的核心API升級

          1、BeanFactory接口盡可能返回明確的bean實例,例如:

          T getBean(String name, Class requiredType)

          Map getBeansOfType(Class type)

          Spring3對泛型的支持,又進了一步。個人建議泛型應該多用,有百利而無一害!

          2、Spring的TaskExecutor接口現在繼承自java.util.concurrent.Executor:

          擴展的子接口AsyncTaskExecutor支持標準的具有返回結果Futures的Callables。

          任務計劃,個人還是更喜歡Quartz。

          3、新的基于Java5的API和SPI轉換器

          無狀態的ConversionService 和 Converters

          取代標準的JDK PropertyEditors

          類型化的ApplicationListener,這是一個實現“觀察者設計模式”使用的事件監聽器。

          基于事件的編程模式,好處多多,在項目中應該考慮使用,基于事件、狀態遷移的設計思路,有助于理清軟件流程,和減少項目的耦合度。

          四、Spring表達式語言

          Spring表達式語言是一種從語法上和統一表達式語言(Unified EL)相類似的語言,但提供更多的重要功能。它可以在基于XML配置文件和基于注解的bean配置中使用,并作為基礎為跨Spring portfolio平臺使用表達式語言提供支持。

          接下來,是一個表達式語言如何用于配置一個數據庫安裝中的屬性的示例:

          <bean class="mycompany.RewardsTestDatabase">
              <property name="databaseName"
                  value="#{systemProperties.databaseName}"/>
              <property name="keyGenerator"
                  value="#{strategyBean.databaseKeyGenerator}"/>
          </bean>
          如果你更愿意使用注解來配置你的組件,那么這種功能同樣可用:

          @Repository public class RewardsTestDatabase {
                @Value("#{systemProperties.databaseName}")
                public void setDatabaseName(String dbName) { … }
               
                @Value("#{strategyBean.databaseKeyGenerator}")
                public voidsetKeyGenerator(KeyGenerator kg) { … }
          }

          又多一種表達式語言,造輪子的運動還在繼續中!

          五、基于Java的bean元數據

          JavaConfig項目中的一些核心特性已經集成到了Spring中來,這意味著如下這些特性現在已經可用了:

          @Configuration

          @Bean

          @DependsOn

          @Primary

          @Lazy

          @Import

          @Value

          又來一堆的注解,無語了,感覺還是配置文件方便!:(

          這兒有一個例子,關于一個Java類如何使用新的JavaConfig特性提供基礎的配置信息:

          package org.example.config;

          @Configuration
          public class AppConfig {
              private @Value("#{jdbcProperties.url}") String jdbcUrl;
              private @Value("#{jdbcProperties.username}") String username;
              private @Value("#{jdbcProperties.password}") String password;

              @Bean
              public FooService fooService() {
                  return new FooServiceImpl(fooRepository());
              }

              @Bean
              public FooRepository fooRepository() {
                  return new HibernateFooRepository(sessionFactory());
              }

              @Bean
              public SessionFactory sessionFactory() {
                  // wire up a session factory
                  AnnotationSessionFactoryBean asFactoryBean =
                      new AnnotationSessionFactoryBean();
                  asFactoryBean.setDataSource(dataSource());
                  // additional config
                  return asFactoryBean.getObject();
              }

              @Bean
              public DataSource dataSource() {
                  return new DriverManagerDataSource(jdbcUrl, username, password);
              }
          }為了讓這段代碼開始生效,我們需要添加如下組件掃描入口到最小化的應用程序上下文配置文件中:

          <context:component-scan base-package="org.example.config"/>
          <util:properties id="jdbcProperties" location="classpath:org/example/config/jdbc.properties"/>

          六、在組件中定義bean的元數據

          感覺Spring提供了越來越多的注解、元數據,復雜性已經超出了當初帶來的方便本身!

          七、通用類型轉換系統和UI字段格式化系統

          Spring3加入了一個通用的類型轉換系統,目前它被SpEL用作類型轉換,并且可能被一個Spring容器使用,用于當綁定bean的屬性值的時候進行類型轉換。

          另外,還增加了一個UI字段格式化系統,它提供了更簡單的使用并且更強大的功能以替代UI環境下的JavaBean的PropertyEditors,例如在SpringMVC中。

          這個特性要好好研究下,通用類型轉換系統如果果如所言的話,帶來的好處還是很多的。

          八、數據層

          對象到XML的映射功能已經從Spring Web Services項目移到了Spring框架核心中。它位于org.springframework.oxm包中。

          OXM?研究下!時間真不夠!

          九、Web層

          在Web層最激動人心的新特性莫過于新增的對構件REST風格的web服務和web應用的支持!另外,還新增加了一些任何web應用都可以使用的新的注解。

          服務端對于REST風格的支持,是通過擴展既有的注解驅動的MVC web框架實現的。

          客戶端的支持則是RestTemplate類提供的。

          無論服務端還是客戶端REST功能,都是使用HttpConverter來簡化對HTTP請求和應答過程中的對象到表現層的轉換過程。

          MarshallingHttpMessageConverter使用了上面提到的“對象到XML的映射機制”。

          十、@MVC增強

          新增了諸如@CookieValue 和 @RequestHeaders這樣的注解等。

          十一、聲明式模型驗證

          支持JSR 303,使用Hibernate Validator作為實現。

          十二、提前對Java EE6提供支持

          提供了使用@Async注解對于異步方法調用的支持(或者EJB 3.1里的 @Asynchronous)

          另外,新增對JSR 303, JSF 2.0, JPA 2.0等的支持。

          十三、嵌入式數據庫的支持

          對于嵌入式的Java數據庫引擎提供了廣泛而方便的支持,諸如HSQL, H2, 以及Derby等。

          這是不是代表一種潮流呢?數據庫向越來越小型化發展,甚至小型化到嵌入式了,我認為這在桌面級應用上還是很有市場的。

           

          本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/abigfrog/archive/2009/10/30/4748685.aspx

          posted @ 2010-01-25 17:26 shiwf 閱讀(4711) | 評論 (0)編輯 收藏
           
          請查看此blog: http://conkeyn.javaeye.com/category/35770

          HQL: Hibernate查詢語言

          Hibernate配備了一種非常強大的查詢語言,這種語言看上去很像SQL。但是不要被語法結構上的相似所迷惑,HQL是非常有意識的被設計為完全面向對象的查詢,它可以理解如繼承、多態 和關聯之類的概念。

          1.大小寫敏感性問題

          除了Java類與屬性的名稱外,查詢語句對大小寫并不敏感。 所以 SeLeCT sELEct 以及 SELECT 是相同的,但是 org.hibernate.eg.FOO 并不等價于 org.hibernate.eg.Foo 并且 foo.barSet 也不等價于 foo.BARSET

          本手冊中的HQL關鍵字將使用小寫字母. 很多用戶發現使用完全大寫的關鍵字會使查詢語句 的可讀性更強, 但我們發現,當把查詢語句嵌入到Java語句中的時候使用大寫關鍵字比較難看。

          2.from子句

          Hibernate中最簡單的查詢語句的形式如下:

          from eg.Cat
          
          

          該子句簡單的返回eg.Cat 類的所有實例。通常我們不需要使用類的全限定名, 因為 auto-import (自動引入) 是缺省的情況。所以我們幾乎只使用如下的簡單寫法:

          from Cat
          
          

          大多數情況下, 你需要指定一個別名 , 原因是你可能需要 在查詢語句的其它部分引用到Cat

          from Cat as cat
          
          

          這個語句把別名cat 指定給類Cat 的實例, 這樣我們就可以在隨后的查詢中使用此別名了。關鍵字as 是可選的,我們也可以這樣寫:

          from Cat cat
          
          

          子句中可以同時出現多個類, 其查詢結果是產生一個笛卡兒積或產生跨表的連接。

          from Formula, Parameter
          
          
          from Formula as form, Parameter as param
          
          

          查詢語句中別名的開頭部分小寫被認為是實踐中的好習慣, 這樣做與Java變量的命名標準保持了一致 (比如,domesticCat )。

          3.關聯(Association)與連接(Join)

          我們也可以為相關聯的實體甚至是對一個集合中的全部元素指定一個別名, 這時要使用關鍵字join

          from Cat as cat
          inner join cat.mate as mate
          left outer join cat.kittens as kitten
          
          
          from Cat as cat left join cat.mate.kittens as kittens
          
          
          from Formula form full join form.parameter param
          
          

          受支持的連接類型是從ANSI SQL中借鑒來的。

          • inner join (內連接)

          • left outer join (左外連接)

          • right outer join (右外連接)

          • full join (全連接,并不常用)

          語句inner join , left outer join 以及 right outer join 可以簡寫。

          from Cat as cat
          join cat.mate as mate
          left join cat.kittens as kitten
          
          

          還有,一個"fetch"連接允許僅僅使用一個選擇語句就將相關聯的對象或一組值的集合隨著他們的父對象的初始化而被初始化,這種方法在使用到集合的情況下尤其有用,對于關聯和集合來說,它有效的代替了映射文件中的外聯接與延遲聲明(lazy declarations). 查看 第20.1節 “ 抓取策略(Fetching strategies) ” 以獲得等多的信息。

          from Cat as cat
          inner join fetch cat.mate
          left join fetch cat.kittens
          
          

          一個fetch連接通常不需要被指定別名, 因為相關聯的對象不應當被用在 where 子句 (或其它任何子句)中。同時,相關聯的對象并不在查詢的結果中直接返回,但可以通過他們的父對象來訪問到他們。

          注意fetch 構造變量在使用了scroll() iterate() 函數的查詢中是不能使用的。最后注意,使用full join fetch right join fetch 是沒有意義的。

          如果你使用屬性級別的延遲獲取(lazy fetching)(這是通過重新編寫字節碼實現的),可以使用 fetch all properties 來強制Hibernate立即取得那些原本需要延遲加載的屬性(在第一個查詢中)。

          from Document fetch all properties order by name
          
          
          from Document doc fetch all properties where lower(doc.name) like '%cats%'
          
          

          4.select子句

          select 子句選擇將哪些對象與屬性返回到查詢結果集中. 考慮如下情況:

          select mate
          from Cat as cat
          inner join cat.mate as mate
          
          

          該語句將選擇mate s of other Cat s。(其他貓的配偶) 實際上, 你可以更簡潔的用以下的查詢語句表達相同的含義:

          select cat.mate from Cat cat
          
          

          查詢語句可以返回值為任何類型的屬性,包括返回類型為某種組件(Component)的屬性:

          select cat.name from DomesticCat cat
          where cat.name like 'fri%'
          
          
          select cust.name.firstName from Customer as cust
          
          

          查詢語句可以返回多個對象和(或)屬性,存放在 Object[] 隊列中,

          select mother, offspr, mate.name
          from DomesticCat as mother
          inner join mother.mate as mate
          left outer join mother.kittens as offspr
          
          

          或存放在一個List 對象中,

          select new list(mother, offspr, mate.name)
          from DomesticCat as mother
          inner join mother.mate as mate
          left outer join mother.kittens as offspr
          
          

          也可能直接返回一個實際的類型安全的Java對象,

          select new Family(mother, mate, offspr)
          from DomesticCat as mother
          join mother.mate as mate
          left join mother.kittens as offspr
          
          

          假設類Family 有一個合適的構造函數.

          你可以使用關鍵字as 給“被選擇了的表達式”指派別名:

          select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as n
          from Cat cat
          
          

          這種做法在與子句select new map 一起使用時最有用:

          select new map( max(bodyWeight) as max, min(bodyWeight) as min, count(*) as n )
          from Cat cat
          
          

          該查詢返回了一個Map 的對象,內容是別名與被選擇的值組成的名-值映射。

          5.聚集函數

          HQL查詢甚至可以返回作用于屬性之上的聚集函數的計算結果:

          select avg(cat.weight), sum(cat.weight), max(cat.weight), count(cat)
          from Cat cat
          
          

          受支持的聚集函數如下:

          • avg(...), sum(...), min(...), max(...)

          • count(*)

          • count(...), count(distinct ...), count(all...)

          你可以在選擇子句中使用數學操作符、連接以及經過驗證的SQL函數:

          select cat.weight + sum(kitten.weight)
          from Cat cat
          join cat.kittens kitten
          group by cat.id, cat.weight
          
          
          select firstName||' '||initial||' '||upper(lastName) from Person
          
          

          關鍵字distinct all 也可以使用,它們具有與SQL相同的語義.

          select distinct cat.name from Cat cat
          select count(distinct cat.name), count(cat) from Cat cat
          
          

          6.多態查詢

          一個如下的查詢語句:

          from Cat as cat
          
          

          不僅返回Cat 類的實例, 也同時返回子類 DomesticCat 的實例. Hibernate 可以在from 子句中指定任何 Java 類或接口. 查詢會返回繼承了該類的所有持久化子類的實例或返回聲明了該接口的所有持久化類的實例。下面的查詢語句返回所有的被持久化的對象:

          from java.lang.Object o
          
          

          接口Named 可能被各種各樣的持久化類聲明:

          from Named n, Named m where n.name = m.name
          
          

          注意,最后的兩個查詢將需要超過一個的SQL SELECT .這表明order by 子句 沒有對整個結果集進行正確的排序. (這也說明你不能對這樣的查詢使用Query.scroll() 方法.)

          7.where子句

          where 子句允許你將返回的實例列表的范圍縮小. 如果沒有指定別名,你可以使用屬性名來直接引用屬性:

          from Cat where name='Fritz'
          
          

          如果指派了別名,需要使用完整的屬性名:

          from Cat as cat where cat.name='Fritz'
          
          

          返回名為(屬性name等于)'Fritz'的Cat 類的實例。

          select foo
          from Foo foo, Bar bar
          where foo.startDate = bar.date
          
          

          將返回所有滿足下面條件的Foo 類的實例:存在如下的bar 的一個實例,其date 屬性等于 Foo startDate 屬性。 復合路徑表達式使得where 子句非常的強大,考慮如下情況:

          from Cat cat where cat.mate.name is not null
          
          

          該查詢將被翻譯成為一個含有表連接(內連接)的SQL查詢。如果你打算寫像這樣的查詢語句

          from Foo foo
          where foo.bar.baz.customer.address.city is not null
          
          

          在SQL中,你為達此目的將需要進行一個四表連接的查詢。

          = 運算符不僅可以被用來比較屬性的值,也可以用來比較實例:

          from Cat cat, Cat rival where cat.mate = rival.mate
          
          
          select cat, mate
          from Cat cat, Cat mate
          where cat.mate = mate
          
          

          特殊屬性(小寫)id 可以用來表示一個對象的唯一的標識符。(你也可以使用該對象的屬性名。)

          from Cat as cat where cat.id = 123
          from Cat as cat where cat.mate.id = 69
          
          

          第二個查詢是有效的。此時不需要進行表連接!

          同樣也可以使用復合標識符。比如Person 類有一個復合標識符,它由country 屬性 與medicareNumber 屬性組成。

          from bank.Person person
          where person.id.country = 'AU'
          and person.id.medicareNumber = 123456
          
          
          from bank.Account account
          where account.owner.id.country = 'AU'
          and account.owner.id.medicareNumber = 123456
          
          

          第二個查詢也不需要進行表連接。

          同樣的,特殊屬性class 在進行多態持久化的情況下被用來存取一個實例的鑒別值(discriminator value)。 一個嵌入到where子句中的Java類的名字將被轉換為該類的鑒別值。

          from Cat cat where cat.class = DomesticCat
          
          

          你也可以聲明一個屬性的類型是組件或者復合用戶類型(以及由組件構成的組件等等)。永遠不要嘗試使用以組件類型來結尾的路徑表達式(path-expression_r)(與此相反,你應當使用組件的一個屬性來結尾)。 舉例來說,如果store.owner 含有一個包含了組件的實體address

          store.owner.address.city    // 正確
          store.owner.address         // 錯誤!
          
          

          一個“任意”類型有兩個特殊的屬性id class , 來允許我們按照下面的方式表達一個連接(AuditLog.item 是一個屬性,該屬性被映射為<any> )。

          from AuditLog log, Payment payment
          where log.item.class = 'Payment' and log.item.id = payment.id
          
          

          注意,在上面的查詢與句中,log.item.class payment.class 將涉及到完全不同的數據庫中的列。

          8.表達式

          where 子句中允許使用的表達式包括大多數你可以在SQL使用的表達式種類:

          • 數學運算符+, -, *, /

          • 二進制比較運算符=, >=, <=, <>, !=, like

          • 邏輯運算符and, or, not

          • in , not in , between , is null , is not null , is empty , is not empty , member of and not member of

          • "簡單的" case, case ... when ... then ... else ... end ,和 "搜索" case, case when ... then ... else ... end

          • 字符串連接符...||... or concat(...,...)

          • current_date() , current_time() , current_timestamp()

          • second(...) , minute(...) , hour(...) , day(...) , month(...) , year(...) ,

          • EJB-QL 3.0定義的任何函數或操作:substring(), trim(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length()

          • coalesce() nullif()

          • cast(... as ...) , 其第二個參數是某Hibernate類型的名字,以及extract(... from ...) ,只要ANSI cast() extract() 被底層數據庫支持

          • 任何數據庫支持的SQL標量函數,比如sign() , trunc() , rtrim() , sin()

          • JDBC參數傳入 ?

          • 命名參數:name , :start_date , :x1

          • SQL 直接常量 'foo' , 69 , '1970-01-01 10:00:01.0'

          • Java public static final 類型的常量 eg.Color.TABBY

          關鍵字in between 可按如下方法使用:

          from DomesticCat cat where cat.name between 'A' and 'B'
          
          
          from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )
          
          

          而且否定的格式也可以如下書寫:

          from DomesticCat cat where cat.name not between 'A' and 'B'
          
          
          from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )
          
          

          同樣, 子句is null is not null 可以被用來測試空值(null).

          在Hibernate配置文件中聲明HQL“查詢替代(query substitutions)”之后,布爾表達式(Booleans)可以在其他表達式中輕松的使用:

          <property name="hibernate.query.substitutions">true 1, false 0</property>
          
          

          系統將該HQL轉換為SQL語句時,該設置表明將用字符 1 0 來 取代關鍵字true false :

          from Cat cat where cat.alive = true
          
          

          你可以用特殊屬性size , 或是特殊函數size() 測試一個集合的大小。

          from Cat cat where cat.kittens.size > 0
          
          
          from Cat cat where size(cat.kittens) > 0
          
          

          對于索引了(有序)的集合,你可以使用minindex maxindex 函數來引用到最小與最大的索引序數。同理,你可以使用minelement maxelement 函數來引用到一個基本數據類型的集合中最小與最大的元素。

          from Calendar cal where maxelement(cal.holidays) > current date
          
          
          from Order order where maxindex(order.items) > 100
          
          
          from Order order where minelement(order.items) > 10000
          
          

          在傳遞一個集合的索引集或者是元素集(elements indices 函數) 或者傳遞一個子查詢的結果的時候,可以使用SQL函數any, some, all, exists, in

          select mother from Cat as mother, Cat as kit
          where kit in elements(foo.kittens)
          
          
          select p from NameList list, Person p
          where p.name = some elements(list.names)
          
          
          from Cat cat where exists elements(cat.kittens)
          
          
          from Player p where 3 > all elements(p.scores)
          
          
          from Show show where 'fizard' in indices(show.acts)
          
          

          注意,在Hibernate3種,這些結構變量- size , elements , indices , minindex , maxindex , minelement , maxelement - 只能在where子句中使用。

          一個被索引過的(有序的)集合的元素(arrays, lists, maps)可以在其他索引中被引用(只能在where子句中):

          from Order order where order.items[0].id = 1234
          
          
          select person from Person person, Calendar calendar
          where calendar.holidays['national day'] = person.birthDay
          and person.nationality.calendar = calendar
          
          
          select item from Item item, Order order
          where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11
          
          
          select item from Item item, Order order
          where order.items[ maxindex(order.items) ] = item and order.id = 11
          
          

          [] 中的表達式甚至可以是一個算數表達式。

          select item from Item item, Order order
          where order.items[ size(order.items) - 1 ] = item
          
          

          對于一個一對多的關聯(one-to-many association)或是值的集合中的元素, HQL也提供內建的index() 函數,

          select item, index(item) from Order order
          join order.items item
          where index(item) < 5
          
          

          如果底層數據庫支持標量的SQL函數,它們也可以被使用

          from DomesticCat cat where upper(cat.name) like 'FRI%'
          
          

          如果你還不能對所有的這些深信不疑,想想下面的查詢。如果使用SQL,語句長度會增長多少,可讀性會下降多少:

          select cust
          from Product prod,
          Store store
          inner join store.customers cust
          where prod.name = 'widget'
          and store.location.name in ( 'Melbourne', 'Sydney' )
          and prod = all elements(cust.currentOrder.lineItems)
          
          

          提示: 會像如下的語句

          SELECT cust.name, cust.address, cust.phone, cust.id, cust.current_order
          FROM customers cust,
          stores store,
          locations loc,
          store_customers sc,
          product prod
          WHERE prod.name = 'widget'
          AND store.loc_id = loc.id
          AND loc.name IN ( 'Melbourne', 'Sydney' )
          AND sc.store_id = store.id
          AND sc.cust_id = cust.id
          AND prod.id = ALL(
          SELECT item.prod_id
          FROM line_items item, orders o
          WHERE item.order_id = o.id
          AND cust.current_order = o.id
          )
          
          

          9.order by子句

          查詢返回的列表(list)可以按照一個返回的類或組件(components)中的任何屬性(property)進行排序:

          from DomesticCat cat
          order by cat.name asc, cat.weight desc, cat.birthdate
          
          

          可選的asc desc 關鍵字指明了按照升序或降序進行排序.

          10.group by子句

          一個返回聚集值(aggregate values)的查詢可以按照一個返回的類或組件(components)中的任何屬性(property)進行分組:

          select cat.color, sum(cat.weight), count(cat)
          from Cat cat
          group by cat.color
          
          
          select foo.id, avg(name), max(name)
          from Foo foo join foo.names name
          group by foo.id
          
          

          having 子句在這里也允許使用.

          select cat.color, sum(cat.weight), count(cat)
          from Cat cat
          group by cat.color
          having cat.color in (eg.Color.TABBY, eg.Color.BLACK)
          
          

          如果底層的數據庫支持的話(例如不能在MySQL中使用),SQL的一般函數與聚集函數也可以出現 在having order by 子句中。

          select cat
          from Cat cat
          join cat.kittens kitten
          group by cat
          having avg(kitten.weight) > 100
          order by count(kitten) asc, sum(kitten.weight) desc
          
          

          注意group by 子句與 order by 子句中都不能包含算術表達式(arithmetic expression_rs).

          posted @ 2010-01-24 13:55 shiwf 閱讀(2074) | 評論 (0)編輯 收藏
           

          DWR 3.0 上傳文件

          第一步:需要文件包,其實就是dwr 3.0中例子所需要的包, dwr.jar 、 commons-fileupload-1.2.jar 、 commons-io-1.3.1.jar

           

           

           

          第二步:編輯web.xml,添加dwr-invoke

          Xml代碼 復制代碼
          1. <servlet>  
          2.     <display-name>DWR Sevlet</display-name>  
          3.     <servlet-name>dwr-invoker</servlet-name>  
          4.     <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>  
          5.     <init-param>  
          6.         <description>是否打開調試功能</description>  
          7.         <param-name>debug</param-name>  
          8.         <param-value>true</param-value>  
          9.     </init-param>  
          10.     <init-param>  
          11.         <description>日志級別有效值為: FATAL, ERROR, WARN (the default), INFO and DEBUG.</description>  
          12.         <param-name>logLevel</param-name>  
          13.         <param-value>DEBUG</param-value>  
          14.     </init-param>  
          15.     <init-param>  
          16.         <description>是否激活反向Ajax</description>  
          17.         <param-name>activeReverseAjaxEnabled</param-name>  
          18.         <param-value>true</param-value>  
          19.     </init-param>  
          20.     <init-param>     
          21.          <description>在WEB啟動時是否創建范圍為application的creator</description>     
          22.          <param-name>initApplicationScopeCreatorsAtStartup</param-name>     
          23.          <param-value>true</param-value>     
          24.     </init-param>     
          25.     <init-param>  
          26.         <description>在WEB啟動時是否創建范圍為application的creator</description>     
          27.         <param-name>preferDataUrlSchema</param-name>  
          28.         <param-value>false</param-value>  
          29.     </init-param>  
          30.         <load-on-startup>1</load-on-startup>     
          31.        
          32. </servlet>  
          33. <servlet-mapping>  
          34.     <servlet-name>dwr-invoker</servlet-name>  
          35.     <url-pattern>/dwr/*</url-pattern>  
          36. </servlet-mapping>  

           第三步:創建上傳類FileUpload.java,編輯代碼,內容如下:

          Java代碼 復制代碼
          1. package learn.dwr.upload_download;   
          2.   
          3. import java.awt.Color;   
          4. import java.awt.Font;   
          5. import java.awt.Graphics2D;   
          6. import java.awt.geom.AffineTransform;   
          7. import java.awt.image.AffineTransformOp;   
          8. import java.awt.image.BufferedImage;   
          9. import java.io.File;   
          10. import java.io.FileOutputStream;   
          11. import java.io.InputStream;   
          12. import org.directwebremoting.WebContext;   
          13. import org.directwebremoting.WebContextFactory;   
          14.   
          15. /**  
          16.  * title: 文件上傳  
          17.  * @author Administrator  
          18.  * @時間 2009-11-22:上午11:40:22  
          19.  */  
          20. public class FileUpload {   
          21.   
          22.     /**  
          23.      * @param uploadImage 圖片文件流  
          24.      * @param uploadFile 需要用簡單的文本文件,如:.txt文件,不然上傳會出亂碼  
          25.      * @param color  
          26.      * @return  
          27.      */  
          28.     public BufferedImage uploadFiles(BufferedImage uploadImage,   
          29.             String uploadFile, String color) {   
          30.         // uploadImage = scaleToSize(uploadImage);   
          31.         // uploadImage =grafitiTextOnImage(uploadImage, uploadFile, color);   
          32.         return uploadImage;   
          33.     }   
          34.   
          35.     /**  
          36.      * 文件上傳時使用InputStream類進行接收,在DWR官方例中是使用String類接收簡單內容  
          37.      *   
          38.      * @param uploadFile  
          39.      * @return  
          40.      */  
          41.     public String uploadFile(InputStream uploadFile, String filename)   
          42.             throws Exception {   
          43.         WebContext webContext = WebContextFactory.get();   
          44.         String realtivepath = webContext.getContextPath() + "/upload/";   
          45.         String saveurl = webContext.getHttpServletRequest().getSession()   
          46.                 .getServletContext().getRealPath("/upload");   
          47.         File file = new File(saveurl + "/" + filename);   
          48.         // if (!file.exists()) {   
          49.         // file.mkdirs();   
          50.         // }   
          51.         int available = uploadFile.available();   
          52.         byte[] b = new byte[available];   
          53.         FileOutputStream foutput = new FileOutputStream(file);   
          54.         uploadFile.read(b);   
          55.         foutput.write(b);   
          56.         foutput.flush();   
          57.         foutput.close();   
          58.         uploadFile.close();   
          59.         return realtivepath + filename;   
          60.     }   
          61.   
          62.     private BufferedImage scaleToSize(BufferedImage uploadImage) {   
          63.         AffineTransform atx = new AffineTransform();   
          64.         atx   
          65.                 .scale(200d / uploadImage.getWidth(), 200d / uploadImage   
          66.                         .getHeight());   
          67.         AffineTransformOp atfOp = new AffineTransformOp(atx,   
          68.                 AffineTransformOp.TYPE_BILINEAR);   
          69.         uploadImage = atfOp.filter(uploadImage, null);   
          70.         return uploadImage;   
          71.     }   
          72.   
          73.     private BufferedImage grafitiTextOnImage(BufferedImage uploadImage,   
          74.             String uploadFile, String color) {   
          75.         if (uploadFile.length() < 200) {   
          76.             uploadFile += uploadFile + " ";   
          77.         }   
          78.         Graphics2D g2d = uploadImage.createGraphics();   
          79.         for (int row = 0; row < 10; row++) {   
          80.             String output = "";   
          81.             if (uploadFile.length() > (row + 1) * 20) {   
          82.                 output += uploadFile.substring(row * 20, (row + 1) * 20);   
          83.             } else {   
          84.                 output = uploadFile.substring(row * 20);   
          85.             }   
          86.             g2d.setFont(new Font("SansSerif", Font.BOLD, 16));   
          87.             g2d.setColor(Color.blue);   
          88.             g2d.drawString(output, 5, (row + 1) * 20);   
          89.         }   
          90.         return uploadImage;   
          91.     }   
          92. }  

           第四步:添加到dwr.xml

          Java代碼 復制代碼
          1. <create creator="new">   
          2.     <param name="class" value="learn.dwr.upload_download.FileUpload" />   
          3. </create>  

           第五步:添加前臺html代碼

          Html代碼 復制代碼
          1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
          2. <html xmlns="http://www.w3.org/1999/xhtml">  
          3. <head>  
          4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
          5. <title>二進制文件處理,文件上傳</title>  
          6. <script type='text/javascript' src='/learnajax/dwr/interface/FileUpload.js'></script>  
          7. <script type='text/javascript' src='/learnajax/dwr/engine.js'></script>  
          8. <script type='text/javascript' src='/learnajax/dwr/util.js'></script>  
          9. <script type='text/javascript' >  
          10. function uploadFiles(){   
          11.     var uploadImage = dwr.util.getValue("uploadImage");   
          12.      FileUpload.uploadFiles(uploadImage, "", "", function(imageURL) {   
          13.         alert(imageURL);   
          14.         dwr.util.setValue('image', imageURL);   
          15.   });   
          16.   
          17. }   
          18. function uploadFile(){   
          19.     var uploadFile = dwr.util.getValue("uploadFile");   
          20.     //var uploadFile =document.getElementById("uploadFile").value;   
          21.     var uploadFileuploadFile_temp = uploadFile.value.replace("\\","/");   
          22.     var filenames = uploadFile.value.split("/");   
          23.     var filename = filenames[filenames.length-1];   
          24.     //var eextension = e[e.length-1];   
          25.     FileUpload.uploadFile(uploadFile,filename,function(data){   
          26.         var file_adocument.getElementById("file_a");   
          27.         file_a.href=data;   
          28.         file_a.innerHTML=data;   
          29.         document.getElementById("filediv").style.display="";   
          30.     });   
          31. }   
          32.        
          33. </script>  
          34. </head>  
          35.   
          36. <body>  
          37. <table border="1" cellpadding="3" width="50%">  
          38.     <tr>  
          39.         <td>Image</td>  
          40.         <td><input type="file" id="uploadImage" /></td>  
          41.         <td><input type="button" onclick="uploadFiles()" value="upload"/><div id="image.container">&nbsp;</div></td>  
          42.     </tr>  
          43.     <tr>  
          44.         <td>File</td>  
          45.         <td><input type="file" id="uploadFile" /></td>  
          46.         <td><input type="button" onclick="uploadFile()" value="upload"/><div id="file.container">&nbsp;</div></td>  
          47.     </tr>  
          48.     <tr>  
          49.         <td colspan="3"></td>  
          50.     </tr>  
          51. </table>  
          52. <img id="image" src="javascript:void(0);"/>  
          53. <div id="filediv" style="display:none;">  
          54. <a href="" id="file_a">上傳的文件</a>  
          55. </div>  
          56. </body>  
          57. </html>  
           

          添加進度條么,就需要用reverse ajax 進行配合使用了。

          posted @ 2010-01-24 13:42 shiwf 閱讀(4379) | 評論 (1)編輯 收藏
           
          Copyright © shiwf Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 孟州市| 莱州市| 静海县| 梁河县| 商河县| 手游| 济南市| 临邑县| 台东县| 大宁县| 徐闻县| 卢龙县| 汝南县| 乌鲁木齐县| 临泽县| 宁城县| 商河县| 肥西县| 汤原县| 巴林左旗| 项城市| 陆川县| 秭归县| 长岭县| 澎湖县| 南部县| 集贤县| 德清县| 乃东县| 六安市| 乐亭县| 蒙阴县| 托克逊县| 蒙自县| 丰原市| 呈贡县| 微山县| 盘山县| 永川市| 宁武县| 星子县|