【问题标题】:How to link JDBC driver to EJB project missing WEB-INF folder如何将 JDBC 驱动程序链接到缺少 WEB-INF 文件夹的 EJB 项目
【发布时间】:2016-11-09 12:12:27
【问题描述】:

我在 Neon Eclipse 中有企业应用解决方案,它封装了 EJB 和 Servlet 项目并部署到 Wildfly 10 服务器。
Servlet 调用 EJB 来访问 DB。
如果我将 JDBC 驱动程序放在 Servlet 项目的 WEB-INF 文件夹中,一切顺利,但如果我将代码移动到 EJB 并将驱动程序链接为外部 JAR(见截图),我会收到错误:

 java.lang.ClassNotFoundException: com.mysql.jdbc.Driver from [Module "deployment.NeoflexBank.ear.Neoflex.jar:main" from Service Module Loader]

这是我用来访问数据库的代码:

    public String test() {
        String output = "";

        try {
            Class.forName("com.mysql.jdbc.Driver").newInstance();
        } catch (Exception e) {
            e.printStackTrace();
        }

        String url="jdbc:mysql://localhost:3306/neoflex";
        String username="root";
        String password="";
        String query="select * from clients";
        Connection conn;
        try {
            conn = (Connection) DriverManager.getConnection(url, username, password);
            Statement stmt = (Statement) conn.createStatement();
            ResultSet rs = stmt.executeQuery(query);

            while(rs.next())
            {
                output += rs.getInt("id");
                output += rs.getString("username");
                output += rs.getString("birth_date");
                output += rs.getString("name");
                output += rs.getString("surename");
            }
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            return e.toString();
        }

        return output;
    }

【问题讨论】:

  • 是的,因为我将代码移动到EJB项目,它没有看到servlet项目的WEB-INF。但我解决了。我把驱动放在企业应用项目(NeoflexBank)的EarContent中。
  • 这与问题无关,但由于一些硬编码的内置 SQL 语句(INSERT和更新)。考虑将所有内容移至准备好的语句或可调用的语句。顺便说一下,从性能的角度来看,它也更好。

标签: java eclipse jdbc ejb


【解决方案1】:

在 Java EE 服务器中执行此操作的方法是定义一个 DataSource,然后使用它来获取 JDBC 连接:

  1. 将 mysql-connector-java-5.1.40-bin.jar 移动到 WildFly 安装的 standalone\deployments 目录中。

  2. 启动您的 WildFly 服务器并在 http://localhost:9990 打开管理控制台。您可能需要按照一些说明在此处设置一些安全性。

  3. 点击Configuration标签,然后点击:

    一个。子系统

    b.数据源

    c。非 XA

  4. 单击蓝色的Add 按钮并按照提示进行操作。

现在,您的 EJB 中的代码看起来有点像:

@Stateless
public class SomeEJB {

   @Resource(name="java:/MySqlDS")
   private DataSource ds;

   public String test() {
        String output = "";

        String query="select * from clients";

        try {
            try (Connection conn = ds.getConnection();
                 Statement stmt = conn.createStatement();
                 ResultSet rs = stmt.executeQuery(query)) {

                while(rs.next())
                {
                    output += rs.getInt("id");
                    output += rs.getString("username");
                    output += rs.getString("birth_date");
                    output += rs.getString("name");
                    output += rs.getString("surename");
                }
            } 
        } catch (SQLException e) {
            return e.toString();
        }

        return output;
    }
}

这将您的应用程序与数据库配置分离。 DataSource 配置也可以通过命令行脚本完成。

【讨论】:

    猜你喜欢
    • 2015-08-03
    • 2017-08-27
    • 2013-01-08
    • 1970-01-01
    • 1970-01-01
    • 2019-04-05
    • 2011-02-20
    • 2012-12-27
    • 1970-01-01
    相关资源
    最近更新 更多