蔣德的JAVA備忘錄

          JAVA備忘錄

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            14 隨筆 :: 4 文章 :: 5 評論 :: 0 Trackbacks

          2009年8月23日 #

          weblogic10.3 這個應用服務器是oracle 收購Bean 公司后新出的版本.今天試用下,發現不錯.將JNDI的配置過程一一記錄,
          1: 啟動weblogic 10.3 采用默認密碼進入
          2:在JDBC-DATASOURCE 中假建一個應用數據源.
          3:在 Configuration-->Connection Pool-->Advanced 中的  一定要溝上,不然會測試通不過
          4:填寫測試的表名    等信息

          5:編寫測試的JSP文件

          <!doctype html public "-//w3c//dtd html 4.0 transitional//en"   "http://www.w3.org/TR/REC-html40/strict.dtd">
          <%@ page import="java.sql.*"%>
          <%@ page import="javax.sql.*"%>
          <%@ page import="javax.naming.*"%>
          <%@ page session="false"%>
          <html>
          <head>
          <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
          <title>Test JNDI</title>
          </head>
          <body>
              
          <%
              out.print(
          "  Test Jndi Begin !!    ");
              DataSource ds 
          = null;
              
          try {
                  InitialContext ctx 
          = new InitialContext();
                  ds 
          = (DataSource) ctx.lookup("jdbc/mysql");
                  Connection conn 
          = ds.getConnection();
                  Statement stmt 
          = conn.createStatement();
                  String strSql 
          = " select * from tb_adminuser";
                  ResultSet rs 
          = stmt.executeQuery(strSql);
                  
          while (rs.next()) {
                      out.println(rs.getString(
          4));
                  }

                  out.print(
          "Test is over");
              }
          catch (Exception ex) {
                  out.print(
          "ERROR:" + ex.getMessage());
                  ex.printStackTrace();
              }

          %>
          </body>

          </html>

          6:編寫 JUNIT
          package com.XXXXXX.framework.datasource;

          import java.sql.Connection;
          import java.sql.ResultSet;
          import java.sql.Statement;
          import java.util.Hashtable;

          import javax.naming.Context;
          import javax.naming.InitialContext;
          import javax.sql.DataSource;

          import junit.framework.TestCase;

          public class TestJndi extends  TestCase{

              
              
          public void testJndi() throws Exception{
                  Hashtable ht 
          = new Hashtable();          
                  ht.put(Context.INITIAL_CONTEXT_FACTORY,
          "weblogic.jndi.WLInitialContextFactory");
                  ht.put(Context.PROVIDER_URL, 
          "t3://localhost:7001");
                  Context initial 
          = new InitialContext(ht);
                  DataSource ds 
          = (DataSource) initial.lookup("jdbc/mysql");
                  Connection connect 
          = ds.getConnection();

                  Statement stmt 
          = connect.createStatement();   
                  String strSql 
          = " select * from tb_adminuser";   
                 
                  ResultSet rs 
          = stmt.executeQuery(strSql);   
                  
          while(rs.next()){   
                      System.out.println(rs.getString(
          2));
                    }
            

              }



          }

          其中在編寫JUNIT 的時候,有一個插曲.我在網上看到別人的代碼是用t3://localhost:7007

          我也照COPY,結果出現錯誤如下:
          javax.naming.CommunicationException [Root exception is java.net.ConnectException: t3://localhost:7007: Destination unreachable; nested exception is: 
              java.net.ConnectException: Connection refused: connect; No available router to destination]
              at weblogic.jndi.internal.ExceptionTranslator.toNamingException(ExceptionTranslator.java:
          40)
              at weblogic.jndi.WLInitialContextFactoryDelegate.toNamingException(WLInitialContextFactoryDelegate.java:
          783)
              at weblogic.jndi.WLInitialContextFactoryDelegate.getInitialContext(WLInitialContextFactoryDelegate.java:
          367)
              at weblogic.jndi.Environment.getContext(Environment.java:
          315)
              at weblogic.jndi.Environment.getContext(Environment.java:
          285)
              at weblogic.jndi.WLInitialContextFactory.getInitialContext(WLInitialContextFactory.java:
          117)
              at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:
          667)
              at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:
          288)
              at javax.naming.InitialContext.init(InitialContext.java:
          223)
              at javax.naming.InitialContext.
          <init>(InitialContext.java:197)
              at com.etong.framework.datasource.TestJndi.testJndi(TestJndi.java:
          21)
              at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
              at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:
          39)
              at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:
          25)
              at java.lang.reflect.Method.invoke(Method.java:
          597)
              at junit.framework.TestCase.runTest(TestCase.java:
          168)
              at junit.framework.TestCase.runBare(TestCase.java:
          134)
              at junit.framework.TestResult$
          1.protect(TestResult.java:110)
              at junit.framework.TestResult.runProtected(TestResult.java:
          128)
              at junit.framework.TestResult.run(TestResult.java:
          113)
              at junit.framework.TestCase.run(TestCase.java:
          124)
              at junit.framework.TestSuite.runTest(TestSuite.java:
          232)
              at junit.framework.TestSuite.run(TestSuite.java:
          227)
              at org.junit.internal.runners.OldTestClassRunner.run(OldTestClassRunner.java:
          76)
              at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:
          38)
              at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:
          38)
              at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:
          460)
              at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:
          673)
              at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:
          386)
              at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:
          196)
          Caused by: java.net.ConnectException: t3:
          //localhost:7007: Destination unreachable; nested exception is: 
              java.net.ConnectException: Connection refused: connect; No available router to destination
              at weblogic.rjvm.RJVMFinder.findOrCreate(RJVMFinder.java:
          203)
              at weblogic.rjvm.ServerURL.findOrCreateRJVM(ServerURL.java:
          153)
              at weblogic.jndi.WLInitialContextFactoryDelegate.getInitialContext(WLInitialContextFactoryDelegate.java:
          352)
               
          27 more
          Caused by: java.rmi.ConnectException: Destination unreachable; nested exception is: 
              java.net.ConnectException: Connection refused: connect; No available router to destination
              at weblogic.rjvm.ConnectionManager.bootstrap(ConnectionManager.java:
          464)
              at weblogic.rjvm.ConnectionManager.bootstrap(ConnectionManager.java:
          315)
              at weblogic.rjvm.RJVMManager.findOrCreateRemoteInternal(RJVMManager.java:
          251)
              at weblogic.rjvm.RJVMManager.findOrCreate(RJVMManager.java:
          194)
              at weblogic.rjvm.RJVMFinder.findOrCreateRemoteServer(RJVMFinder.java:
          225)
              at weblogic.rjvm.RJVMFinder.findOrCreate(RJVMFinder.java:
          188)
               
          29 more


          換成 t3://localhost:7001
          測試成功.看來不懂就到網上亂COPY代碼,還是不行的

           

          我已經在配置文件里配置了context.java.naming.factory.initial,而在這里還提示這個錯誤
          關鍵看這里

          Error initializing JtaTransactionConfig while looking up UserTransaction (javax.transaction.UserTransaction). Cause: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial


          jvm里加上一個參數,測試一下

          -Djava.naming.factory.initial=weblogic.jndi.WLInitialContextFactory


          運行通過

          這個參數在:右鍵項目--Run as --Open Run Dialog--ArgumentsVM arguments中添加即可


          posted @ 2009-08-23 10:41 蔣德 閱讀(5190) | 評論 (1)編輯 收藏

          主站蜘蛛池模板: 英吉沙县| 拜泉县| 叙永县| 长泰县| 临泉县| 双峰县| 延川县| 台湾省| 建宁县| 梁平县| 来凤县| 永寿县| 西充县| 河源市| 石城县| 宝应县| 兰溪市| 深泽县| 洛隆县| 娄底市| 讷河市| 甘孜县| 惠安县| 海晏县| 贞丰县| 乌拉特后旗| 莱西市| 临沧市| 宣化县| 彭山县| 图木舒克市| 高雄市| 梨树县| 舞钢市| 灵川县| 遂溪县| 吴川市| 阳新县| 宜章县| 双桥区| 望谟县|