"Weblogic 连接池 + Oracle + Servlet" 的无状态SessionBean 全攻略

类别:Java 点击:0 评论:0 推荐:

jbuilder7 + welogic6.1+ Oracle8i

一个无状态的Session bean
连接weblogic 数据库连接池
取 Oracle一个表的一个字段值
返回给客户端 (servlet)

就这些,now整理成笔记。

1. 确认安装好Oralce 和 Webligc 6.1 .Jbuilder7
   都是默认安装
2. 开始配置Jbuilder7 和Weblogic 的连接
   我参考了一篇Jbuilder6的配置 ,大同小异
   进入JB7
   a.打开Tools-->Configue Servers--> 选择weblogic6.x+
                Enable Server 打勾
      选择正确的Weblgic 安装路径
    注意 显示器分辨率为1024*768 才能看到下面的OK 按钮
    在General页 的Home Dircetory 和 Work Directory一样 如:
    D:/bea/wlserver6.1
    在Custome页中填入weblogic 启动密码
    其他默认
  b.打开Tools--> Enterprise Setup -->CORBA
               new 一个 起名为Weblogic的项目
               在Path for ORB tools下加入Weblogic 的目录
               在Library for project 下加入 weblogic 6.x delopy 库
               在compiler command 填上 idcj.exe
               在Command ... for oupput Dircetory 填上一个你自己的输出路径
  c 最后确认 Projects--> Default Projects Properties-->Server
              选的Application Server 是Weblogic 6.x file://应该已经是了,再看看
  d 最后到我的电脑点右键去修改系统变量
              Temp 和Tmp
              因为默认得目录名有空格,JB7过敏这个,改为一个没空格的目录
              如C:\temp 当然你得先建立这个目录
             
 3.下来在Weblogic中建立Oracle的连接池
  . 在Weblogic 控制台
       Services -->JDBC -->Connection Pools--> Configure a new JDBC Connection Pool
       在General属性页 
            Name :连接池名 file://我取名为testPool ,注意名字区分大小写
            URL: JDBC 连接字符串 file://Oracle的 为: jdbc:oracle:thin:@xiw:1521:sdb
                                        xiw为服务器名 也可为IP地址
                                        sdb为数据库名
            Driver Classname: 填入 oracle.jdbc.driver.OracleDriver
            Properties(key=value): 填入 user=system  file://即Oracle的用户名,也可以在这里填入密码
            Password 先不填
            点击Apply // Weblogic 如果有图标闪动,表示需要重启动Webligoc设置才能生效 后面不在说明
            然后点击Password 输入数据库密码 
       在Connection 页
             Initial Capacity : 1 file://初始连接数
             Maximum Capacity :10 file://最大连接数
             Capacity Increment :1 // 初始不够时,每次增加连接数
             Refresh Period: 5 file://防止网络意外中断时,每5分钟刷新一次连接,断了就自动恢复
             其他默认
       在testing 页
              Test Table Name:tab // Oracle 已经有了这个表 ,用其他Oracle系统表也行
              下面两项选中 打勾 表示启用意外端开时,自动刷新恢复连接
       图标闪动,表示需要重启动Webligoc
       重启后:
          在: Serviers -->JDBC -->Connection Pools-->testPool页
                target页 将myserver移到chosen 中 点Apply file://表示那个服务器启用这个池
                如果有错误,一般就是前面的URL错 或没有testing指定的那个表,我在这绊了很久
          可能需要重启
          然后到Services-->JDBC-->Data Source
               Configure a new JDBC Data Source
                 Name:自己起吧
                   JNDI Name: 起名为MyJNDI file://这个后面编程要用,区分大小写
                   Pool Name:testPool file://前面建的那个池的名字
                   然后点击Apply
             在target页,和前面一样,将myserver移到chosen Apply
             此时若有错误,一般为连接池名大小写问题  
        重启动Weblogic 完成
4 开始编程
  ·在JB7中新建一个空项目
  ·在New 的Enterprise 页Ejb2.0 bean designer
  ·在可视化设计窗口,右键,New Session bean ,起名字为testsqlBean  type为stateless
  ·启动Oralce
  ·添加一个表table3 字段名 A1 再加一条数据 'OKOK' file://最后在Servlet中返回OKOK就算成功
  ·在该项目中New一个Class ,作为返回结果用,该类进行了序列化
   该类取名为TestString  代码如下,较为粗糙,没有优化,其实可以直接返回值的,凑合看吧。
package testpool;
import javax.ejb.*;
import java.sql.*;
import javax.sql.*;
public class TestString implements java.io.Serializable{
        private String returnS;
        public TestString(String ss){
                returnS=ss;
        }

        public String returnStr(){
          return returnS;
        }
        public String getA1(DataSource  ds, String sql)
        {String temp="nono"; file://默认为no  Servlet要是返回这个就是失败了
        try{
         Connection  conn=ds.getConnection();
         Statement stmt=conn.createStatement();
         stmt.executeQuery(sql);
         ResultSet rs=stmt.getResultSet();
         int i=rs.getRow(); file://没显示改值,调试时看了看
         if(rs.next())
           {temp=rs.getString(1);
           }
         rs.close();
         conn.close();
       }
        catch(Exception e)
        {
          e.printStackTrace();
        }
        return temp;
        }
}
  ·以下修改testsqlbean.java
  需要添加一些类
  import java.sql.*;
  import javax.sql.*;
  其他Home接口或Remote接口用到诸如ResultSet ,DataSource 得自己加入就行,不再复述
  添加几个属性
  String returnString;
  DataSource  ds;
 
  ·同时需要修改testsqlbean的ejbCreate代码为:
  public void ejbCreate() throws CreateException {
    try{
    Context  ctx=new  InitialContext();
    ds=(DataSource)ctx.lookup("MyJNDI"); // MyJNDI为前面配置的Weblogic的JDBC的JNDI名
    }
    catch(Exception e)
   { }
   }
  ·然后。在可视化设计窗口 testsqlBean上右键 add method 取名为getMyConn 返回类型为前面自建的TestString
   参数为String sql
   最后修改该函数代码如下:
   public TestString getMyConn(String sql) {
   TestString t1=new TestString(sql);
   String returnString=t1.getA1(ds,sql);
   return new TestString(returnString);
   }    
  .完成后 Make Project 一次编译通过后
  ·在项目文件列表上,点击web run
  此时不要人工启动Weblogic 让JB7去启动它
  如果没有错误,则EJB被自动部署到weblogic上,
 
  · 编一个Servlet作为客户端 
  用JB7的New 一个Servlet 起名为testpoolServlet
  全部代码如下
  package testpool;

import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.sql.*;
import java.util.*;
import javax.naming.*;
import javax.ejb.*;
import java.rmi.RemoteException;
import java.rmi.Remote;
import testpool.testsql;
import testpool.testsqlHome;

public class testpoolServlet extends HttpServlet {
  static final private String CONTENT_TYPE = "text/html; charset=GBK";
  TestVector myStr;

  file://Initialize global variables
  public void init() throws ServletException {
  }
  file://Process the HTTP Get request
  public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    response.setContentType(CONTENT_TYPE);
    String sql="select * from table3"; file://客户端给EJB的sql语句
    PrintWriter out = response.getWriter();
    out.println("<html>");
    out.println("<head><title>testpoolServlet</title></head>");
    out.println("<body>");
    out.println("<table><tr>");
    try {
      Context context=new  InitialContext();
      Object objref = context.lookup("testsqlBean");// EJB中那个SessionBean的名字
     testsqlHome home = (testsqlHome)javax.rmi.PortableRemoteObject.narrow(objref,testsqlHome.class);
      testsql servletsql=home.create();
      TestString myTStr=servletsql.getMyConn(sql);
      String myStr=myTStr.returnStr();
      out.println("<td>This is=="+myStr+"</td>");
    out.println("</tr></table>");
    out.println("<p>The servlet has received a GET. This is the reply.</p>");
    out.println("</body></html>");
    } catch (Exception e) {
        out.println("A problem has occurred with the servlet.");
    }
  }

  file://Clean up resources
  public void destroy() {
  }
}
     
 .完成后 Web Run Use "testpoolServlet" 
 
 或者·手工启动Weblogic 输入http://localhost:7001/testpoolservlet
 
 最后结果应该显示为            
                This is==okok
                The servlet has received a GET. This is the reply
               
 一般错误发生为:刚才Oracle插入数据时,没有Commit,所以查询不到。
                为这个问题,曾迷惑我半天,失败啊,哈哈
  
   JB7还是不错的,可以运行时单步调试EJB
   还可以为Bean中建一个testsqlBeanTestClient1,不用Servlet也很简单,作为测试用,不再赘述 
  
   下次作个Message Drive Bean ,学会了也共享之
    欢迎评论
   希望共同学习J2EE  我的QQ:11161875 身份请验证注明:CSDN J2EE
    
 
    

本文地址:http://com.8s8s.com/it/it18141.htm