蔣德的JAVA備忘錄

          JAVA備忘錄

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            14 隨筆 :: 4 文章 :: 5 評(píng)論 :: 0 Trackbacks

          2008年12月17日 #

          weblogic10.3 這個(gè)應(yīng)用服務(wù)器是oracle 收購Bean 公司后新出的版本.今天試用下,發(fā)現(xiàn)不錯(cuò).將JNDI的配置過程一一記錄,
          1: 啟動(dòng)weblogic 10.3 采用默認(rèn)密碼進(jìn)入
          2:在JDBC-DATASOURCE 中假建一個(gè)應(yīng)用數(shù)據(jù)源.
          3:在 Configuration-->Connection Pool-->Advanced 中的  一定要溝上,不然會(huì)測(cè)試通不過
          4:填寫測(cè)試的表名    等信息

          5:編寫測(cè)試的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 的時(shí)候,有一個(gè)插曲.我在網(wǎng)上看到別人的代碼是用t3://localhost:7007

          我也照COPY,結(jié)果出現(xiàn)錯(cuò)誤如下:
          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
          測(cè)試成功.看來不懂就到網(wǎng)上亂COPY代碼,還是不行的

           

          我已經(jīng)在配置文件里配置了context.java.naming.factory.initial,而在這里還提示這個(gè)錯(cuò)誤
          關(guān)鍵看這里

          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里加上一個(gè)參數(shù),測(cè)試一下

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


          運(yùn)行通過

          這個(gè)參數(shù)在:右鍵項(xiàng)目--Run as --Open Run Dialog--ArgumentsVM arguments中添加即可


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

          一直用Xdoclet 來管理項(xiàng)目的配置文件,今天用Myeclipse 建新了一個(gè)工程,使用Myeclipse 的Strtus1.2的相關(guān)包,發(fā)現(xiàn)生成相關(guān)的配置文件中<action-mappings> 部分竟然是空白的,百思不得其解,反復(fù)測(cè)試后,發(fā)現(xiàn)取消Myeclipse 的Strtus1.2的相關(guān)包,使用以前的Struts .jar又可以生成.
           記錄下,日后再找到原因

          到google 里一找,發(fā)現(xiàn)自己幾年前還記錄了這個(gè),2009年我又遇到了這個(gè)問題
          發(fā)現(xiàn),在xdoclet 里生成struts的配置文件時(shí),一定要在lib下面存在
          struts.jar
          commons-collections-3.0.jar
          commons-digester.jar
          commons-logging-1.0.4.jar
          否則就可能不生成,也不出錯(cuò).

          莫名其妙的.

          posted @ 2008-12-17 20:54 蔣德 閱讀(147) | 評(píng)論 (0)編輯 收藏

          主站蜘蛛池模板: 广州市| 寿光市| 南康市| 萨迦县| 晋州市| 洛隆县| 和硕县| 平邑县| 波密县| 桐庐县| 漳浦县| 仁化县| 左贡县| 通海县| 深水埗区| 名山县| 彭山县| 石门县| 南江县| 夏津县| 达拉特旗| 鄯善县| 萨嘎县| 祁东县| 桦南县| 重庆市| 易门县| 长岛县| 林周县| 通化市| 崇文区| 公安县| 邮箱| 北票市| 竹溪县| 德保县| 阳山县| 盐源县| 子长县| 荥经县| 汕尾市|