日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

在Tomcat中配置數(shù)據(jù)源

系統(tǒng) 2132 0

使用工具:TOMCAT 7.0.52、IntelliJ IDEA 13.0.2、JSF 2.0+、SqlServer、jtds-1.2.5.jar

搞了好久都沒成功,開始使用注解引入DataSource,可是一直不成功,后來(lái)使用lookup方式,寫了一個(gè)本地主類(包含main方法)測(cè)試,也是不成功,艸,都快崩潰了,后來(lái)經(jīng)過各種測(cè)試,終于搞定了,本地主類測(cè)試是無(wú)效的,必須通過web訪問才能成功,真尼瑪?shù)疤?。注解估?jì)跟版本有關(guān),沒精力去弄了。

以下是配置步驟(相應(yīng)的路徑換成自己的):

1、把jtds-1.2.5.jar放到Tomcat目錄里的lib目錄下。如:D:\IntelliJ\tomcat7\lib

2、在D:\IntelliJ\tomcat7\conf目錄里的context.xml文件里加上如下代碼:

      
        1
      
      
        <
      
      
        Context
      
      
        >
      
      
        2
      
      
        <
      
      
        WatchedResource
      
      
        >
      
      WEB-INF/web.xml
      
        </
      
      
        WatchedResource
      
      
        >
      
      
        3
      
      
        <
      
      
        Resource 
      
      
        name
      
      
        ="jdbc/sqlserver"
      
      
         auth
      
      
        ="Container"
      
      
         type
      
      
        ="javax.sql.DataSource"
      
      
        4
      
      
                      driverClassName
      
      
        ="net.sourceforge.jtds.jdbc.Driver"
      
      
        5
      
      
                      url
      
      
        ="jdbc:jtds:sqlserver://localhost:1433/yourDatabaseName"
      
      
        6
      
      
                      username
      
      
        ="username"
      
      
         password
      
      
        ="password"
      
      
         maxActive
      
      
        ="100"
      
      
          maxIdle
      
      
        ="30"
      
      
        />
      
      
        7
      
      
        </
      
      
        Context
      
      
        >
      
    

3、在你項(xiàng)目里的web.xml文件里加入如下內(nèi)容:

      
        1
      
      
        <!--
      
      
        配置數(shù)據(jù)源
      
      
        -->
      
      
        2
      
      
        <
      
      
        resource-ref
      
      
        >
      
      
        3
      
      
        <
      
      
        description
      
      
        >
      
      Sqlserver Datasource
      
        </
      
      
        description
      
      
        >
      
      
        4
      
      
        <
      
      
        res-ref-name
      
      
        >
      
      jdbc/sqlserver
      
        </
      
      
        res-ref-name
      
      
        >
      
      
        5
      
      
        <
      
      
        res-type
      
      
        >
      
      javax.sql.DataSource
      
        </
      
      
        res-type
      
      
        >
      
      
        6
      
      
        <
      
      
        res-auth
      
      
        >
      
      Container
      
        </
      
      
        res-auth
      
      
        >
      
      
        7
      
      
        </
      
      
        resource-ref
      
      
        >
      
    

4、在你的代碼里引用數(shù)據(jù)源:

      
         1
      
      
        private
      
      
         DataSource ds;


      
      
         2
      
      
         3
      
      
        public
      
      
         LoginBean() {


      
      
         4
      
      
         5
      
      
        try
      
      
         {


      
      
         6
      
      
        //
      
      
         初始化查找命名空間
      
      
         7
      
                   Context ctx = 
      
        new
      
      
         InitialContext();


      
      
         8
      
                   ds = (DataSource)ctx.lookup("java:comp/env/jdbc/sqlserver"
      
        ) ;


      
      
         9
      
               } 
      
        catch
      
      
         (NamingException e) {


      
      
        10
      
                   System.out.println("使用lookup找不到數(shù)據(jù)源."
      
        );


      
      
        11
      
      
                    e.printStackTrace();


      
      
        12
      
      
                }


      
      
        13
      
      
        14
      
           }
    

5、測(cè)試test.jsp:

      <%@ page language="java" 
      
        import
      
      ="java.util.*" pageEncoding="utf-8" %>

<%@ page 
      
        import
      
      ="java.sql.*"%>

<%@ page 
      
        import
      
      ="javax.sql.*"%>

<%@ page 
      
        import
      
      ="javax.naming.*"%>

<%!

    
      
        final
      
       String JNDINAME = "java:comp/env/jdbc/sqlserver"
      
         ;


      
      %>

<%
      
        

    Connection conn 
      
      = 
      
        null
      
      
         ;

    
      
      
        try
      
      
        

    {

        
      
      
        //
      
      
         初始化查找命名空間
      
      

        Context ctx = 
      
        new
      
      
         InitialContext() ;

        
      
      
        //
      
      
         找到DataSource
      
      

        DataSource ds =
      
         (DataSource)ctx.lookup(JNDINAME) ;

        conn 
      
      =
      
         ds.getConnection() ;

        String sql
      
      ="select passwd,logincount from credential where username=?"
      
        ;

        PreparedStatement pwdQuery
      
      =
      
        conn.prepareStatement(sql);

        pwdQuery.setString(
      
      1,"admin"
      
        );

        ResultSet result
      
      =
      
          pwdQuery.executeQuery();

        
      
      
        if
      
      (!
      
        result.next()){

             
      
      
        return
      
      
        ;

         } 

        System.out.println(result.getString(
      
      "passwd"
      
        )) ;

    }

    
      
      
        catch
      
      
        (Exception e)

    {

        System.out.println(e) ;

    }


      
      %>

<%=conn%>

<%

    
      
        //
      
      
         將連接重新放回到池中
      
      
            conn.close() ;


      
      %>
    

?

只要能輸出數(shù)據(jù)庫(kù)的連接信息就沒問題了。

?

如果注解不能使用,就不要糾結(jié)了,換種方式。

?

在Tomcat中配置數(shù)據(jù)源


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦?。。?/p>

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 沽源县| 濉溪县| 迭部县| 西城区| 麻江县| 米泉市| 鄯善县| 水富县| 伊宁市| 临潭县| 巨鹿县| 苏尼特左旗| 乐清市| 德州市| 娄底市| 松滋市| 通城县| 沂南县| 土默特左旗| 海城市| 漾濞| 措勤县| 栾川县| 竹溪县| 甘泉县| 儋州市| 寿光市| 富锦市| 正镶白旗| 洪雅县| 珲春市| 崇左市| 重庆市| 屏东市| 车致| 大足县| 始兴县| 乐山市| 文登市| 沾化县| 泸州市|