5

我一直在尝试连接到 Teradata

Class.forName("com.teradata.jdbc.TeraDriver");
        String connectionString = "jdbc:teradata://xxx.xxxxxx.com/database=xxxxxx,  tmode=ANSI,  charset=UTF8";
        String user = "Rocket512";
        String password = "aui8mn5";
        Connection conn = DriverManager.getConnection(connectionString, user, password);

得到以下

  Exception in thread "main" com.teradata.jdbc.jdbc_4.util.JDBCException: [Teradata Database] 
[TeraJDBC 14.10.00.17] [Error 8017] [SQLState 28000] The UserId, Password or Account is invalid.
        at com.teradata.jdbc.jdbc_4.util.ErrorFactory.makeDatabaseSQLException(ErrorFactory.java:300)
        at com.teradata.jdbc.jdbc.GenericLogonController.run(GenericLogonController.java:666)
        at com.teradata.jdbc.jdbc_4.TDSession.<init>(TDSession.java:216)

我知道主机指定正确,因为我没有得到UnknownHost Exception. 我还仔细检查了我的用户名和密码是否正确。


我运行了@beni23 建议的查询(谢谢)

select * 
from dbc.logonoff 
where logdate >= date '2013-10-31'

这是我得到的结果

在此处输入图像描述

是什么Bad Password?我用这个密码使用了 SQL 助手,效果很好。为什么我无法连接到 Java?

4

5 回答 5

6

LDAP 身份验证失败不会DBC.LogOnOff作为Bad Password事件被捕获,因为身份验证不在数据库上进行。

通常,您收到的错误消息The UserId, Password or Account is invalid.表示用户帐户被锁定在数据库上。

SELECT U.UserName
     , U.ProfileName
     , U.DefaultAccount
     , COALESCE(P.MAXLOGONATTEMPTS, S.MAXLOGONATTEMPTS) AS MaxLogonAttempts_
     , U.LockedCount
     , U.LockedDate
  FROM dbc.UsersV U
  LEFT JOIN
       dbc.ProfileInfoV P
    ON P.ProfileName = U.ProfileName   
  CROSS JOIN
       dbc.SecurityDefaults S
 WHERE UserName = 'Rocket512';

如果LockedCount不是0自上次成功登录到数据库后发生了一次失败的登录尝试。

如果LockedDate不是NULL,则表示帐户上次锁定的日期。

MaxLogonAttempts_将告诉您在帐户被锁定之前您可以尝试使用数据库身份验证 (TD2) 登录多少次。

我建议的几件事:

  1. 去掉参数之间的空格connectString
  2. 将用户和密码参数放入connectString
  3. 使用上面的原始代码修改connectString添加:,ACCOUNT=$AMRWRW&DrT&r它应该与我上面的响应中查询返回的内容相匹配(我已经添加了DefaultAccount)。

编辑:13 年 11月 12 日我建议您下载 Teradata Studio Express 并尝试使用 JDBC 连接到同一个 Teradata 系统,就像您在代码中一样。这可能有助于阐明您需要在连接字符串中指定的参数以使连接成功。您应该能够在 Teradata Studio Express 中设置与代码中相同的连接参数,并查看它是否有效。

使用 LDAP 作为未被授予使用 NULL 密码登录的明确权限的用户的登录机制会导致错误消息“用户 ID、密码或帐户无效。”。前几天我使用特权帐户收到了这个,而我的登录机制没有从 LDAP 更改为 TD2。

以下 SQL 返回什么?

SELECT *
  FROM DBC.LogonRulesV
 WHERE UserName = 'Rocket512';

它可能不会返回任何东西,这没关系。这仅仅意味着您从系统上的任何主机使用该用户标识登录的能力尚未被明确授予或撤销。

编辑:05/22/18 当提供的密码与存储在目录服务器上的密码不匹配时,外部身份验证用户的“密码错误”事件可能会出现在事件日志中。在某些情况下,您可以通过使用ldapsearch从 PDN 直接向 LDAP 目录提交查询来验证这一点。您可以在安全管理手册中找到有关使用此命令的更多详细信息。我发现这试图对未能对目录进行身份验证的用户帐户子集进行分类问题。我觉得用更多细节来更新这个答案是合适的,因为我在顶部的陈述并不是 100% 准确的。

于 2013-11-08T15:26:17.723 回答
4

以下内容可能无法为您提供解决方案,但可能会为您指明正确的方向。我认为您需要dbc.logonoff通过控制台检查 teradata 中的表,以确保您的用户没有被锁定或了解您的驱动程序是否正在访问 teradata。

select * 
  from dbc.logonoff 
 where logdate >= date '2013-10-31'
于 2013-11-04T23:02:53.690 回答
2

阅读本文安全性疑难解答:用户 ID、密码或帐户无效。我们可以看到这个错误的典型原因。

原因:指定了 LOGMECH=LDAP,并且在 LOGDATA 和单独的连接参数中冗余地提供了用户名/密码凭据。

解决方案:通过 LOGDATA 或通过单独的用户名/密码参数识别 LDAP 用户,但不能同时进行。

所以,你应该检查这种情况。可能是您无需用户/密码即可获得连接

于 2013-11-07T17:19:24.647 回答
1

也许你可能有更多的运气:

String driver = "com.teradata.jdbc.TeraDriver";
String conUrl="jdbc:teradata://xxx.xxxxxx.com/database=xxxxxx,USER=Rocket512,PASSWORD=aui8mn5,tmode=ANSI,charset=UTF8";
Class.forName(driver);
Connection dbConn = DriverManager.getConnection(conUrl);

如果这不起作用,请确保使用最新的 jdbc 驱动程序。

于 2013-11-07T15:46:24.270 回答
1

我有类似的错误,并遵循了这里给出的所有建议。我的帐户没有被锁定,我可以通过 SQL 帮助编辑器使用相同的用户名和密码连接到数据库。

对我有用的解决方案是在连接字符串中添加以下行:LOGMECH=LDAP。

您需要了解 Teradata 的登录机制,或者您可以像我一样联系您的 DBA 团队。所以你的连接字符串看起来像这样:

String connurl="jdbc:teradata://xx/database=xx,USER=xx,PASSWORD=xx,tmode=ANSI,charset=UTF8,LOGMECH=LDAP";

于 2015-01-13T22:03:52.417 回答