close
Tomcat 7 設置Oracle JNDI
- 事前準備
- Oracle JDBC Driver :放置 Tomcat 安裝的位置,例如:C:\tomcat7\lib
請至Oracle官方網站下載 http://www.oracle.com/technetwork/database/enterprise-edition/jdbc-112010-090769.html
(我是使用Oracle 11g Express 版本)
data:image/s3,"s3://crabby-images/61593/61593c2daa2b445079fec8909f8383945344b545" alt=""
data:image/s3,"s3://crabby-images/0ffdb/0ffdbe61f2884adc37ea99efb33e1967cf234c46" alt="setJNDI1 setJNDI1"
- 開始設定
一開始以為網路上講修改Tomcat的xml設定檔
是在當初下載回Tomcat的安裝的位置@@"
data:image/s3,"s3://crabby-images/181a2/181a2242617697dc0e37a1e733a07f94f77bd9aa" alt="setJNDI2 setJNDI2"
結果原來不是.....
是Eclipse裡面建立的
data:image/s3,"s3://crabby-images/18143/1814351a2345f1aa8d8cd68efbad4515233cdc8f" alt="".png)
data:image/s3,"s3://crabby-images/0692a/0692a3932ada6bfc0c2140bd5785a3ff2c0f3a79" alt="setJNDI3 setJNDI3"
我這邊設定的方式是全域的JNDI設定,有三種設定方式,
Step 1) 先設定Tomcat Server的server.xml
加入
<Resource name= "jdbc/oracleDB" auth ="Container"
type= "javax.sql.DataSource"
factory= "org.apache.tomcat.jdbc.pool.DataSourceFactory"
driverClassName="oracle.jdbc.OracleDriver"
url= "jdbc:oracle:thin:@localhost:1521:xe"
username= "username" password ="password"
maxActive="20" maxIdle="10"/>
data:image/s3,"s3://crabby-images/48461/484612e0e2042fe730e5988d124f023b76818f3c" alt="Image4 Image4"
data:image/s3,"s3://crabby-images/26311/26311780d810b53e9a6524244965cbf96c6c3f11" alt="".png)
這邊還有很多屬性可以設定,
請看
介紹
我這邊首要是能建立連線就好,先隨意設個屬性可以Run成功即可。
Step 2) 再到此server.xml下面一點的地方找尋<Host> ... </Host>,確認裡面有你的專案名稱
我的Create的專案名稱為CDBRS2
加入
<ResourceLink global ="jdbc/oracleDB" name ="jdbc/oracleDB" type="javax.sql.DataSource"/>
data:image/s3,"s3://crabby-images/900e4/900e406cf43e5024b41ccdd1f852da9ded501d50" alt="Image5 Image5"
===2014.10.8補充===
還有Context.xml裡面也要加入才能正常運作...
<ResourceLink global ="jdbc/oracleDB" name ="jdbc/oracleDB" type="javax.sql.DataSource"/>
data:image/s3,"s3://crabby-images/2d42f/2d42f37c44ffb01fc9468e3f2f4da235fe2555a4" alt="Image Image"
Step 3) 再到Eclipse Project裡的WEB-INF/web.xml 加入
data:image/s3,"s3://crabby-images/36bdf/36bdf0043716d7a5e8c318e5033d8f6cc48978a9" alt="Image6 Image6"
<!-- Oracle JNDI -->
<resource-ref>
<description> Oracle DB</description >
<res-ref-name> jdbc/oracleDB </res-ref-name>
<res-type> javax.sql.DataSource</res-type >
<res-auth> Container</res-auth >
</resource-ref>
data:image/s3,"s3://crabby-images/b517a/b517ad6bd50e5dbe503bca9b783ef59c72e5b8b3" alt="Image7 Image7"
step 4) 因為我有用Springframework,所以設定springframework吃的xml檔
data:image/s3,"s3://crabby-images/879fd/879fd3254bec9732c164d04c9ed2c74852b44b09" alt="Image8 Image8"
data:image/s3,"s3://crabby-images/dcdde/dcddefa720d2af930c0c20784e6284cbf4a7d337" alt="".png)
專案裡面設定是applicationContext.xml為空的
data:image/s3,"s3://crabby-images/32287/32287915cf893905f7180b24d98bdf354b47faf9" alt="Image9 Image9"
data:image/s3,"s3://crabby-images/c2589/c25897e15fa9f515cc774413e76a42f430fd2521" alt="".png)
主要都是寫在datasource.xml
data:image/s3,"s3://crabby-images/8312f/8312f6428c57ff8146d86708b28fd3a7565b2503" alt="Image10 Image10"
data:image/s3,"s3://crabby-images/e7fd8/e7fd83a4cf6faa7a8077fef30d63a02f19f083c6" alt="".png)
done~成功連線
文章標籤
全站熱搜