国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

Hibernate配置及自定義注冊(cè)映射文件

coordinate35 / 944人閱讀

摘要:一配置屬性詳解可以在各式各樣不同環(huán)境下工作而設(shè)計(jì)的因此存在著大量的配置參數(shù)。以簡(jiǎn)便操作,多數(shù)配置參數(shù)都有默認(rèn)的配置值也是我們?nèi)粘J褂玫谋仨毱贰?/p>

Hibernate (開(kāi)放源代碼的對(duì)象關(guān)系映射框架)
    Hibernate是一個(gè)開(kāi)放源代碼的對(duì)象關(guān)系映射框架,它對(duì)JDBC進(jìn)行了非常輕量級(jí)的對(duì)象封裝,
    它將POJO與數(shù)據(jù)庫(kù)表建立映射關(guān)系,是一個(gè)全自動(dòng)的orm框架,hibernate可以自動(dòng)生成SQL
    語(yǔ)句,自動(dòng)執(zhí)行,使得Java程序員可以隨心所欲的使用對(duì)象編程思維來(lái)操縱數(shù)據(jù)庫(kù)。 
    Hibernate可以應(yīng)用在任何使用JDBC的場(chǎng)合,既可以在Java的客戶(hù)端程序使用,也
    可以在Servlet/JSP的Web應(yīng)用中使用,最具革命意義的是,Hibernate可以在應(yīng)用
    EJB的J2EE架構(gòu)中取代CMP,完成數(shù)據(jù)持久化的重任。
 
一.hibernate配置屬性詳解
   hibbernate可以在各式各樣不同環(huán)境下工作而設(shè)計(jì)的, 因此存在著大量的配置參數(shù)。以簡(jiǎn)便操 
   
 作,多數(shù)配置參數(shù)都有默認(rèn)的配置值,也是我們?nèi)粘J褂胔ibernate的必須品。
Hibernate JDBC屬性
     -----------------------------------------------------------------------------------
     |              屬性名                     |              用途
     -----------------------------------------------------------------------------------
     |  hibernate.connection.driver_class     |           jdbc驅(qū)動(dòng)類(lèi)                                        
     |  hibernate.connection.url              |           jdbc URL                              
     |  hibernate.connection.username         |           數(shù)據(jù)庫(kù)用戶(hù)                                         
     |  hibernate.connection.password         |           數(shù)據(jù)庫(kù)用戶(hù)密碼                                    
     |  hibernate.connection.pool_size        |           連接池容量上限數(shù)目                           
     -----------------------------------------------------------------------------------                 
Hibernate 數(shù)據(jù)源屬性
     ----------------------------------------------------------------------------------- 
     |屬性名                                     |               用途
     ----------------------------------------------------------------------------------- 
     |hibernate.connection.datasource           |           數(shù)據(jù)源JNDI名字
     |hibernate.jndi.url                        |        DI提供者的URL (可選)
     |hibernate.jndi.class                      |    DI InitialContextFactory類(lèi) (可選)
     |hibernate.connection.username             |           數(shù)據(jù)庫(kù)用戶(hù) (可選)
     |hibernate.connection.password             |           數(shù)據(jù)庫(kù)用戶(hù)密碼 (可選)
     -----------------------------------------------------------------------------------          
可選的配置屬性
     ----------------------------------------------------------------------------------- 
     |屬性名                                 |                        用途
     ----------------------------------------------------------------------------------------------------------------------------------------------------------------
     hibernate.dialect                      |     一個(gè)Hibernate Dialect類(lèi)名允許Hibernate針對(duì)特定的關(guān)系數(shù)據(jù)庫(kù)生成優(yōu)化的SQL.取值 full.classname.of.Dialect
     hibernate.show_sql                     |     輸出所有SQL語(yǔ)句到控制臺(tái). 有一個(gè)另外的選擇是把org.hibernate.SQL這個(gè)log category設(shè)為debug。eg. true | false
     hibernate.format_sql                   |     在log和console中打印出更漂亮的SQL。取值 true | false
     hibernate.default_schema               |     在生成的SQL中, 將給定的schema/tablespace附加于非全限定名的表名上.取值 SCHEMA_NAME
     hibernate.default_catalog              |     在生成的SQL中, 將給定的catalog附加于非全限定名的表名上.取值 CATALOG_NAME
     hibernate.session_factory_name         |     SessionFactory創(chuàng)建后,將自動(dòng)使用這個(gè)名字綁定到JNDI中.取值 jndi/composite/name
     hibernate.max_fetch_depth              |     為單向關(guān)聯(lián)(一對(duì)一, 多對(duì)一)的外連接抓取(outer join fetch)樹(shù)設(shè)置最大深度. 值為0意味著將關(guān)閉默認(rèn)的外連接抓取.取值 建議在0到3之間取值
     hibernate.default_batch_fetch_size     |     為Hibernate關(guān)聯(lián)的批量抓取設(shè)置默認(rèn)數(shù)量.取值 建議的取值為4, 8, 和16
     hibernate.default_entity_mode          |     為由這個(gè)SessionFactory打開(kāi)的所有Session指定默認(rèn)的實(shí)體表現(xiàn)模式.取值 dynamic-map, dom4j, pojo
     hibernate.order_updates                |     強(qiáng)制Hibernate按照被更新數(shù)據(jù)的主鍵,為SQL更新排序。這么做將減少在高并發(fā)系統(tǒng)中事務(wù)的死鎖。取值 true | false
     hibernate.generate_statistics          |     如果開(kāi)啟, Hibernate將收集有助于性能調(diào)節(jié)的統(tǒng)計(jì)數(shù)據(jù).取值 true | false
     hibernate.use_identifer_rollback       |     如果開(kāi)啟, 在對(duì)象被刪除時(shí)生成的標(biāo)識(shí)屬性將被重設(shè)為默認(rèn)值.取值 true | false
     hibernate.use_sql_comments             |     如果開(kāi)啟, Hibernate將在SQL中生成有助于調(diào)試的注釋信息, 默認(rèn)值為false.取值 true | false
     ----------------------------------------------------------------------------------------------------------------------------------------------------------------         
Hibernate JDBC和連接(connection)屬性:
     ----------------------------------------------------------------------------------------------------------------------------------------------------------------------   
     屬性名                                       |                                                   用途
     ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
     hibernate.jdbc.fetch_size                   |   非零值,指定JDBC抓取數(shù)量的大小 (調(diào)用Statement.setFetchSize()).
     hibernate.jdbc.batch_size                   |   非零值,允許Hibernate使用JDBC2的批量更新.取值 建議取5到30之間的值
     hibernate.jdbc.batch_versioned_data         |   如果你想讓你的JDBC驅(qū)動(dòng)從executeBatch()返回正確的行計(jì)數(shù) , 那么將此屬性設(shè)為true(開(kāi)啟這個(gè)選項(xiàng)通常是安全的). 同時(shí),Hibernate將為自動(dòng)版本化的數(shù)據(jù)使用批量DML. 默認(rèn)值為false.eg. true | false
     hibernate.jdbc.factory_class                |   選擇一個(gè)自定義的Batcher. 多數(shù)應(yīng)用程序不需要這個(gè)配置屬性.eg. classname.of.Batcher
     hibernate.jdbc.use_scrollable_resultset     |   允許Hibernate使用JDBC2的可滾動(dòng)結(jié)果集. 只有在使用用戶(hù)提供的JDBC連接時(shí),這個(gè)選項(xiàng)才是必要的, 否則Hibernate會(huì)使用連接的元數(shù)據(jù).取值 true | false
     hibernate.jdbc.use_streams_for_binary       |   在JDBC讀寫(xiě)binary (二進(jìn)制)或serializable (可序列化) 的類(lèi)型時(shí)使用流(stream)(系統(tǒng)級(jí)屬性).取值 true | false
     hibernate.jdbc.use_get_generated_keys       |   在數(shù)據(jù)插入數(shù)據(jù)庫(kù)之后,允許使用JDBC3 PreparedStatement.getGeneratedKeys() 來(lái)獲取數(shù)據(jù)庫(kù)生成的key(鍵)。需要JDBC3+驅(qū)動(dòng)和JRE1.4+, 如果你的數(shù)據(jù)庫(kù)驅(qū)動(dòng)在使用Hibernate的標(biāo) 識(shí)生成器時(shí)遇到問(wèn)題,請(qǐng)將此值設(shè)為false. 默認(rèn)情況下將使用連接的元數(shù)據(jù)來(lái)判定驅(qū)動(dòng)的能力.取值 true|false
     hibernate.connection.provider_class         |   自定義ConnectionProvider的類(lèi)名, 此類(lèi)用來(lái)向Hibernate提供JDBC連接.取值 classname.of.ConnectionProvider
     hibernate.connection.isolation              |   設(shè)置JDBC事務(wù)隔離級(jí)別. 查看java.sql.Connection來(lái)了解各個(gè)值的具體意義, 但請(qǐng)注意多數(shù)數(shù)據(jù)庫(kù)都不支持所有的隔離級(jí)別.取值 1, 2, 4, 8
     hibernate.connection.autocommit             |   允許被緩存的JDBC連接開(kāi)啟自動(dòng)提交(autocommit) (不建議).取值 true | false
     hibernate.connection.release_mode           |   指定Hibernate在何時(shí)釋放JDBC連接. 默認(rèn)情況下,直到Session被顯式關(guān)閉或被斷開(kāi)連接時(shí),才會(huì)釋放JDBC連接. 對(duì)于應(yīng)用程序服務(wù)器的JTA數(shù)據(jù)源, 你應(yīng)當(dāng)使用after_statement, 這樣在每次JDBC調(diào)用后,都會(huì)主動(dòng)的釋放連接. 對(duì)于非JTA的連接, 使用after_transaction在每個(gè)事務(wù)結(jié)束時(shí)釋放連接是合理的. auto將為JTA和CMT事務(wù)策略選擇after_statement, 為JDBC事務(wù)策略選擇after_transaction.取值 on_close | after_transaction | after_statement | auto
     hibernate.connection.         |   將JDBC屬性propertyName傳遞到DriverManager.getConnection()中去.
     hibernate.jndi.               |   將屬性propertyName傳遞到JNDI InitialContextFactory中去.
     ---------------------------------------------------------------------------------------------------------------------------------------------------------------------          
Hibernate 緩沖屬性
     ----------------------------------------------------------------------------------------------------------------------------------------------------------------------  
     |屬性名                                         |                                                        用途
     ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
     |hibernate.cache.provider_class                |         自定義的CacheProvider的類(lèi)名. 取值 classname.of.CacheProvider
     |hibernate.cache.use_minimal_puts              |         以頻繁的讀操作為代價(jià), 優(yōu)化二級(jí)緩存來(lái)最小化寫(xiě)操作. 在Hibernate3中,這個(gè)設(shè)置對(duì)的集群緩存非常有用, 對(duì)集群緩存的實(shí)現(xiàn)而言,默認(rèn)是開(kāi)啟的.取值 true|false
     |hibernate.cache.use_query_cache               |         允許查詢(xún)緩存, 個(gè)別查詢(xún)?nèi)匀恍枰辉O(shè)置為可緩存的.取值 true|false
     |hibernate.cache.use_second_level_cache        |         能用來(lái)完全禁止使用二級(jí)緩存. 對(duì)那些在類(lèi)的映射定義中指定的類(lèi),會(huì)默認(rèn)開(kāi)啟二級(jí)緩存.取值 true|false
     |hibernate.cache.query_cache_factory           |         自定義實(shí)現(xiàn)QueryCache接口的類(lèi)名, 默認(rèn)為內(nèi)建的StandardQueryCache.取值 classname.of.QueryCache
     |hibernate.cache.region_prefix                 |         二級(jí)緩存區(qū)域名的前綴.取值 prefix
     |hibernate.cache.use_structured_entries        |         強(qiáng)制Hibernate以更人性化的格式將數(shù)據(jù)存入二級(jí)緩存.取值 true|false
     ----------------------------------------------------------------------------------------------------------------------------------------------------------------------        
Hibernate 事務(wù)屬性
     --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
     |屬性名                                               |                                                              用途
     --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
     |hibernate.transaction.factory_class                 |         一個(gè)TransactionFactory的類(lèi)名, 用于Hibernate Transaction API (默認(rèn)為JDBCTransactionFactory).取值 classname.of.TransactionFactory
     |jta.UserTransaction                                 |         一個(gè)JNDI名字,被JTATransactionFactory用來(lái)從應(yīng)用服務(wù)器獲取JTA UserTransaction.取值 jndi/composite/name
     |hibernate.transaction.manager_lookup_class          |         一個(gè)TransactionManagerLookup的類(lèi)名 - 當(dāng)使用JVM級(jí)緩存,或在JTA環(huán)境中使用hilo生成器的時(shí)候需要該類(lèi).取值 classname.of.TransactionManagerLookup
     |hibernate.transaction.flush_before_completion       |         如果開(kāi)啟, session在事務(wù)完成后將被自動(dòng)清洗(flush)。 現(xiàn)在更好的方法是使用自動(dòng)session上下文管理。取值 true | false
     |hibernate.transaction.auto_close_session            |         如果開(kāi)啟, session在事務(wù)完成后將被自動(dòng)關(guān)閉。 現(xiàn)在更好的方法是使用自動(dòng)session上下文管理。取值 true | false
     ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------            
方言
     ----------------------------------------------------------------------------------
     |RDBMS                                  |    方言
     ----------------------------------------------------------------------------------
     |DB2                                    |                org.hibernate.dialect.DB2Dialect
     |DB2 AS/400                             |                org.hibernate.dialect.DB2400Dialect
     |DB2 OS390                              |                org.hibernate.dialect.DB2390Dialect
     |PostgreSQL                             |                org.hibernate.dialect.PostgreSQLDialect
     |MySQL                                  |                org.hibernate.dialect.MySQLDialect
     |MySQL with InnoDB                      |                org.hibernate.dialect.MySQLInnoDBDialect
     |MySQL with MyISAM                      |                org.hibernate.dialect.MySQLMyISAMDialect
     |Oracle (any version)                   |                org.hibernate.dialect.OracleDialect
     |Oracle 9i/10g                          |                org.hibernate.dialect.Oracle9Dialect
     |Sybase                                 |                org.hibernate.dialect.SybaseDialect
     |Sybase Anywhere                        |                org.hibernate.dialect.SybaseAnywhereDialect
     |Microsoft SQL Server                   |                org.hibernate.dialect.SQLServerDialect
     |SAP DB                                 |                org.hibernate.dialect.SAPDBDialect
     |Informix                               |                org.hibernate.dialect.InformixDialect
     |HypersonicSQL                          |                org.hibernate.dialect.HSQLDialect
     |Ingres                                 |                org.hibernate.dialect.IngresDialect
     |Progress                               |                org.hibernate.dialect.ProgressDialect
     |Mckoi SQL                              |                org.hibernate.dialect.MckoiDialect
     |Interbase                              |                org.hibernate.dialect.InterbaseDialect
     |Pointbase                              |                org.hibernate.dialect.PointbaseDialect
     |FrontBase                              |                org.hibernate.dialect.FrontbaseDialect
     |Firebird                               |                org.hibernate.dialect.FirebirdDialect
     ----------------------------------------------------------------------------------           
其他屬性
     ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ 
     |屬性名    用途
     ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
     |hibernate.current_session_context_class                |    為"當(dāng)前" Session指定一個(gè)(自定義的)策略。eg. jta | thread | custom.Class
     |hibernate.query.factory_class                          |    選擇HQL解析器的實(shí)現(xiàn).取值 org.hibernate.hql.ast.ASTQueryTranslatorFactory or org.hibernate.hql.classic.ClassicQueryTranslatorFactory
     |hibernate.query.substitutions                          |   將Hibernate查詢(xún)中的符號(hào)映射到SQL查詢(xún)中的符號(hào) (符號(hào)可能是函數(shù)名或常量名字).取值 hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC
     |hibernate.hbm2ddl.auto                                 |   在SessionFactory創(chuàng)建時(shí),自動(dòng)檢查數(shù)據(jù)庫(kù)結(jié)構(gòu),或者將數(shù)據(jù)庫(kù)schema的DDL導(dǎo)出到數(shù)據(jù)庫(kù). 使用 create-drop時(shí),在顯式關(guān)閉SessionFactory時(shí),將drop掉數(shù)據(jù)庫(kù)schema.取值 validate | update | create | create-drop
     |hibernate.cglib.use_reflection_optimizer               |   開(kāi)啟CGLIB來(lái)替代運(yùn)行時(shí)反射機(jī)制(系統(tǒng)級(jí)屬性). 反射機(jī)制有時(shí)在除錯(cuò)時(shí)比較有用. 注意即使關(guān)閉這個(gè)優(yōu)化, Hibernate還是需要CGLIB. 你不能在hibernate.cfg.xml中設(shè)置此屬性取值 true | false
     ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
二、hibernate.xmls配置




    
    oracle.jdbc.driver.OracleDriver
    
    jdbc:oracle:thin:@localhost:1521:orcl
    
    system
    
    sa
    org.hibernate.dialect.Oracle10gDialect
    
    true
    
    true
         
    
    validate
    
    thread

    
    10
    
    false
    
    


hibernate配置文件可以有兩種方式:官方推薦的XML配置文件和屬性配置文件。我們大都采用XML方式的配置,因?yàn)榻Y(jié)構(gòu)良好,配置靈活,可讀性強(qiáng)。而且可以在XML中直接配置映射文件而屬性文件則不行。但是我們可能忽略的一個(gè)問(wèn)題是:hibernate首先查找的配置文件卻是屬性配置文件hibernate.properties。

Hibernate首先去找了hibernate.properties配置文件,但是沒(méi)找到。然后創(chuàng)建字節(jié)碼支持器,用到cglib,之后用了時(shí)間戳控制,之后才是讀取hibernate.cfg.xml配置文件。這些在最前面的日志信息我們可能會(huì)忽略它,但是我們要明白hibernate的一些加載原理。

為什么使用properties配置hibernate?
  在實(shí)際開(kāi)發(fā)中一般都是hibernate.properties和hibernate.cfg.xml結(jié)合使用,這樣可以使得結(jié)果更加清晰,便于更改數(shù)據(jù)庫(kù)連接配置,需要修改屬性就去hibernate.properties文件修改,需要修改映射配置就在hibernate.cfg.xml中去修改。
使用hibernate.properties配置
    
    hibernate.connection.driver_class=oracle.jdbc.driver.OracleDriver
    
    hibernate.connection.url=jdbc:oracle:thin:@localhost:1521:orcl
    
    hibernate.connection.username=root
    
    hibernate.connection.password=password
    hibernate.dialect=org.hibernate.dialect.Oracle10gDialect
    
    hibernate.show_sql=true
    
    hibernate.format_sql=true
         
    
    hbm2ddl.auto=validate
    
    current_session_context_class=thread
    
    hibernate.jdbc.batch_size=10
    
    hibernate.cache.use_second_level_cache=false
hibernate 配置
   
     
       classpath:jdbc.properties  
         
     




${hibernate.connection.driver_class}

${hibernate.connection.url}

${hibernate.connection.username}

${hibernate.connection.password}
${hibernate.dialect}

${hibernate.show_sql}

${hibernate.format_sql}
     

${hibernate.connection.url}

${current_session_context_class}


${hibernate.jdbc.batch_size}

${use_second_level_cache}


 

可能寫(xiě)的有點(diǎn)簡(jiǎn)單,但意思是這個(gè)意思
如果和spring 一起用,那么幾乎一樣。

配置如下:

jdbc.properties

jdbc.driverClassName=com.mysql.jdbc.Driver  
jdbc.url=jdbc:mysql://localhost:3306/demo  
jdbc.username=root  
jdbc.password=password
jdbc.initialPoolSize=5  
jdbc.minPoolSize=5  
jdbc.maxPoolSize=100   
spring-applicationContext.xml
  
     
       classpath:jdbc.properties  
         
     
   
   
   
   
   
   
  

如果實(shí)體配置完后,如果是幾個(gè)的話(huà),還好,要是多起來(lái),那么你將會(huì)瘋,所以提供以下解決實(shí)體類(lèi)加載到hibernate中。

 1.自動(dòng)掃包
 2.注冊(cè)映射文件<這個(gè)在上面其實(shí)已經(jīng)用過(guò)了>  
1.自動(dòng)掃包 掃描一個(gè)包下的文件時(shí):
      
      
      
需要掃描不同包下的文件時(shí):
   
  
      
        classpath:entity  
        classpath:com.smilesnake..entity  
      
 

2.注冊(cè)映射文件


     
     

本人提供第三種配置方案----自定義
 
 



    
        
            /WEB-INF/config/jdbc.properties
        
    



    
        
            /WEB-INF/config/jdbc.properties
        
    
    




    




    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    


    
    
    
    
    
    
        
            hibernate.dialect=${hibernate.dialect}
            
            hibernate.show_sql=false
            
            hibernate.format_sql=false
            
            
            hibernate.query.substitutions=true 1, false 0
            
            hibernate.jdbc.fetch_size=20
            
            hibernate.connection.autocommit=true
            
            
            
            
            
            hibernate.connection.release_mode=auto
            
            hibernate.cache.use_query_cache=true
            
            
            hibernate.cache.use_second_level_cache=true
            
            hibernate.cache.use_structured_entries=true
        
    

當(dāng)然,這上面的配置省略了很多,只提供了hibernate部分

jdbc.properties
#mysql
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/smilesnake?characterEncoding=UTF-8
jdbc.username=smilesnake
jdbc.password=password


hibernate.db=mysql

hibernate.dialect=org.hibernate.dialect.MySQL5Dialect

#oracle
#jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
#jdbc.url=jdbc:oracle:thin:@192.168.0.132:1521:orcl
#jdbc.username=smilesnake
#jdbc.password=password
#hibernate.db=oracle
#hibernate.dialect=org.hibernate.dialect.Oracle10gDialect

#sqlserver
#jdbc.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
#jdbc.url=jdbc:sqlserver://192.168.0.132:1433;DatabaseName=smilesnake
#jdbc.username=smilesnake
#jdbc.password=password
#hibernate.db=sqlserver
#hibernate.dialect=org.hibernate.dialect.SQLServerDialect

#db2
#jdbc.driverClassName=com.ibm.db2.jcc.DB2Driver
#jdbc.url=jdbc:db2://localhost:50000/smilesnake
#jdbc.username=smilesnake
#jdbc.password=password

#hibernate.db=db2
#hibernate.dialect=org.hibernate.dialect.DB2Dialect

#mysql
hibernate.hbm.jeecms.core=classpath*:/com/smilesnake/core/entity/hbm/common/*.hbm.xml
hibernate.hbm.jeecms.cms=classpath*:/com/smilesnake/cms/entity/main/hbm/common/*.hbm.xml
hibernate.hbm.jeecms.assist=classpath*:/com/smilesnake/cms/entity/assist/hbm/common/*.hbm.xml




cpool.checkoutTimeout=5000

cpool.minPoolSize=20

cpool.maxPoolSize=100


cpool.maxIdleTime=7200

cpool.maxIdleTimeExcessConnections=1800

cpool.acquireIncrement=10

想用哪個(gè)就打開(kāi)哪個(gè),不想用哪個(gè)就注釋掉

PropertyUtils.java
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import java.util.TreeSet;

import org.springframework.beans.BeansException;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.BeanFactoryAware;



public class PropertyUtils implements BeanFactoryAware {

    /**
     * 從指定的properties 得到 以prefix開(kāi)頭的配置,并將其路徑放到一個(gè)list中后返回此list
     * @param prefix
     * @return list
     */
    public List getList(String prefix) {
        //判斷配置文件或者前綴不為空,為空返回一個(gè)空的集合
        if (properties == null || prefix == null) {
            return Collections.emptyList();
        }
        List list = new ArrayList();
    
    // 返回屬性列表中所有鍵的枚舉,如果在主屬性列表中未找到同名的鍵,則包括默認(rèn)屬性列表中不同的鍵。
    Enumeration en = properties.propertyNames();
    String key;
    
    //遍歷 Enumeration
    while (en.hasMoreElements()) {
        key = (String) en.nextElement();
        
        //判斷是否以hibernate.hbm開(kāi)頭
        //意為著讀取properties文件中的herbernate.hbm開(kāi)頭的配置,
        if (key.startsWith(prefix)) {
            list.add(properties.getProperty(key));
        }
    }
    return list;
}
/**
 * 從指定的properties 得到 以prefix開(kāi)頭的配置,并將其路徑放到一個(gè)Set中后返回此Set
 * @param prefix
 * @return Set
 */
public Set getSet(String prefix) {
    if (properties == null || prefix == null) {
        return Collections.emptySet();
    }
    Setset=new TreeSet();
    Enumeration en = properties.propertyNames();
    String key;
    while (en.hasMoreElements()) {
        key = (String) en.nextElement();
        if (key.startsWith(prefix)) {
            set.add(properties.getProperty(key));
        }
    }
    return set;
}


/**
 * 從指定的properties 得到 以prefix開(kāi)頭的配置,并將其路徑放到一個(gè)Map中后返回此Map
 * @param prefix
 * @return Map
 */
public Map getMap(String prefix) {
    if (properties == null || prefix == null) {
        return Collections.emptyMap();
    }
    Map map = new HashMap();
    Enumeration en = properties.propertyNames();
    String key;
    int len = prefix.length();
    while (en.hasMoreElements()) {
        key = (String) en.nextElement();
        if (key.startsWith(prefix)) {
            map.put(key.substring(len), properties.getProperty(key));
        }
    }
    return map;
}

/**
 * Properties 繼承了HashTable
 * 從指定的properties 得到 以prefix開(kāi)頭的配置,并將其路徑放到一個(gè)Properties中后返回此Properties
 * @param prefix
 * @return Properties
 */
public Properties getProperties(String prefix) {
    Properties props = new Properties();
    if (properties == null || prefix == null) {
        return props;
    }
    Enumeration en = properties.propertyNames();
    String key;
    int len = prefix.length();
    while (en.hasMoreElements()) {
        key = (String) en.nextElement();
        if (key.startsWith(prefix)) {
            props.put(key.substring(len), properties.getProperty(key));
        }
    }
    return props;
}

//此方法分別在config/jeecms/jeecms-servlet-admin-action.xml調(diào)用("hibernate.db")
/**
 * 從指定的properties 得到 以prefix開(kāi)頭的配置,并將其路徑放到一個(gè)String中后返回此String
 * @param prefix
 * @return String
 */
public String getPropertiesString(String prefix) {
    String property = "";
    if (properties == null || prefix == null) {
        return property;
    }
    Enumeration en = properties.propertyNames();
    String key;
    while (en.hasMoreElements()) {
        key = (String) en.nextElement();
        if (key.equals(prefix)) {
            return properties.getProperty(key);
        }
    }
    return property;
}

//此方法分別在config/jeecms/jeecms-context.xml調(diào)用("directive.")
//此方法分別在config/jeecms/jeecms-servlet-front-action.xml調(diào)用("directive.")
/**
 * 從指定的properties 得到 以prefix開(kāi)頭的配置,并將其路徑放到一個(gè)Map中后返回此Map
 * @param prefix
 * @return
 */
public Map getBeanMap(String prefix) {
    Map keyMap = getMap(prefix);
    if (keyMap.isEmpty()) {
        return Collections.emptyMap();
    }
    Map resultMap = new HashMap(keyMap.size());
    String key, value;
    for (Map.Entry entry : keyMap.entrySet()) {
        key = entry.getKey();
        value = entry.getValue();
        resultMap.put(key, beanFactory.getBean(value, Object.class));
    }
    return resultMap;
}

/**
 * 讀取file文件后將文件信息保存在props
 * @param file
 * @return
 */
public static Properties getProperties(File file) {
    Properties props = new Properties();
    InputStream in;
    try {
        in = new FileInputStream(file);
        //讀取此文件
        props.load(in);
    } catch (FileNotFoundException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    return props;
}
/**
 * 讀取指定文件中的指定key的value值,
 * @param file
 * @param key
 * @return String
 */
public static String getPropertyValue(File file,String key) {
    Properties props=getProperties(file);
    return (String) props.get(key);
}

private BeanFactory beanFactory;
private Properties properties;

public void setProperties(Properties properties) {
    this.properties = properties;
}

public void setBeanFactory(BeanFactory beanFactory) throws BeansException {
    this.beanFactory = beanFactory;
}

}

如果有侵權(quán),馬上刪除

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/68383.html

相關(guān)文章

  • 開(kāi)發(fā)利器之IntelliJ IDEA學(xué)習(xí)筆記

    摘要:旨在記錄自己的學(xué)習(xí)過(guò)程,方便日后遇到問(wèn)題是及時(shí)查閱復(fù)習(xí),另一方面也希望能幫助像筆者一樣從來(lái)沒(méi)使用過(guò)的人快速熟悉。 這篇文章主要記錄的是本人學(xué)習(xí)使用IntelliJ IDEA的筆記,可能不是特別的詳細(xì)。旨在記錄自己的學(xué)習(xí)過(guò)程,方便日后遇到問(wèn)題是及時(shí)查閱復(fù)習(xí),另一方面也希望能幫助像筆者一樣從來(lái)沒(méi)使用過(guò)IDEA的人快速熟悉IDEA。文章錯(cuò)誤之處還請(qǐng)各位大佬批評(píng)指正。(文末有本人的微信公眾號(hào),...

    馬永翠 評(píng)論0 收藏0
  • Hibernate入門(mén)指南

    摘要:在使用作為應(yīng)用時(shí)推薦使用作為開(kāi)發(fā)工具導(dǎo)入相應(yīng)的的包到文件下的目錄下關(guān)于開(kāi)發(fā)中導(dǎo)入的說(shuō)明在此提供一個(gè)包下載鏈接,地址百度云盤(pán)下載好以后解壓到某個(gè)文件夾里解壓好以后,開(kāi)發(fā)所需要的包在解壓后的包下,將該文件夾下的包復(fù)制到項(xiàng)目中另外還需 1.在使用Hibernate作為orm應(yīng)用時(shí)推薦使用myeclipse作為開(kāi)發(fā)工具2.導(dǎo)入相應(yīng)的Hibernate的jar包到webroot文件下的lib目錄...

    Codeing_ls 評(píng)論0 收藏0
  • 慕課網(wǎng)_《Hibernate注解》學(xué)習(xí)總結(jié)

    摘要:時(shí)間年月日星期二說(shuō)明本文部分內(nèi)容均來(lái)自慕課網(wǎng)。文件如下在目錄下,創(chuàng)建文件指定映射文件的路徑注解映射實(shí)體類(lèi)可選,對(duì)應(yīng)數(shù)據(jù)庫(kù)中的一個(gè)表。 時(shí)間:2017年07月11日星期二說(shuō)明:本文部分內(nèi)容均來(lái)自慕課網(wǎng)。@慕課網(wǎng):http://www.imooc.com教學(xué)源碼:無(wú)學(xué)習(xí)源碼:https://github.com/zccodere/s... 第一章:類(lèi)級(jí)別注解 1-1 本章簡(jiǎn)介 本章簡(jiǎn)介 H...

    Jaden 評(píng)論0 收藏0
  • MyBatis 源碼分析系列文章導(dǎo)讀

    摘要:本文速覽本篇文章是我為接下來(lái)的源碼分析系列文章寫(xiě)的一個(gè)導(dǎo)讀文章。年該項(xiàng)目從基金會(huì)遷出,并改名為。同期,停止維護(hù)。符號(hào)所在的行則是表示的執(zhí)行結(jié)果。同時(shí),使用無(wú)需處理受檢異常,比如。另外,把寫(xiě)在配置文件中,進(jìn)行集中管理,利于維護(hù)。 1.本文速覽 本篇文章是我為接下來(lái)的 MyBatis 源碼分析系列文章寫(xiě)的一個(gè)導(dǎo)讀文章。本篇文章從 MyBatis 是什么(what),為什么要使用(why),...

    weizx 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<