0

这可能是非常基本的,但我现在坚持了几个小时,所以请听我说完。

我正在尝试在 Eclipse 的 Glassfish 4.0 上的 Java 7 Web 应用程序中执行基于 JDBCRealm 的身份验证。这篇博文是配置JDBCRealm的参考。

web.xml 如下

<login-config>
  <auth-method>FORM</auth-method>
  <realm-name>MyJDBCRealm</realm-name>
  <form-login-config>
    <form-login-page>/login.html</form-login-page>
    <form-error-page>/tologin.html</form-error-page>
  </form-login-config>
</login-config>

当我启动 Glassfish 服务器时,控制台中清楚地写着:

SEC1115: Realm [MyJDBCRealm] of classtype [com.sun.enterprise.security.ee.auth.realm.jdbc.JDBCRealm] successfully created.

但是当我请求任何应用程序的资源时,我得到了这个异常

javax.naming.NamingException: Lookup failed for 'MyJDBCRealm' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: MyJDBCRealm not found]

根本原因:

javax.naming.NameNotFoundException: MyJDBCRealm not found
  at com.sun.enterprise.naming.impl.TransientContext.doLookup(TransientContext.java:237)
  at com.sun.enterprise.naming.impl.TransientContext.lookup(TransientContext.java:204)
  ...

发生在这里

public DataSource getDataSource() {
  DataSource datasource = null;

  try {
    datasource = (DataSource) initialContext.lookup("MyJDBCRealm");
  } catch (NamingException ex) {
    ex.printStackTrace();
  }

  return datasource;
}

我应该注意到,Hibernate 成功连接到后端数据库并映射表,并且在 glassfish 控制台中,我可以成功 ping JDBC 连接池。

4

1 回答 1

1

我猜你在混淆一些东西。

领域与数据源不同。要在 Java 中获取领域的实例,您可以执行以下操作:

JDBCRealm realm = (JDBCRealm) Realm.getInstance("realmName");

如果你真的想获得一个数据源,你必须使用 JNDI 名称,它通常以jdbc/这样的开头:

DataSource datasource = (DataSource) initialContext.lookup("jdbc/MyJDBCRealm");

但无论如何,我认为对于普通的基于 JDBC 的身份验证,您不需要这样的东西。

于 2013-11-04T02:26:57.110 回答