即使登录被拒绝,SQL*Plus 也会以 0 退出

Posted

技术标签:

【中文标题】即使登录被拒绝,SQL*Plus 也会以 0 退出【英文标题】:SQL*Plus exiting with 0 even when logon denied 【发布时间】:2018-03-13 06:50:00 【问题描述】:

我正在使用一个 shell 脚本来运行一个访问 SQL*PLUS 的 java 类。现在,有一个非常特殊的行为,即使数据库凭据错误,sqlplus(通过 java.process 运行)仍然不会引发错误(退出代码 1)或错误流。相反,它会在 java.process 输出中打印错误。

有谁知道我能做些什么来解决这个问题?

【问题讨论】:

【参考方案1】:

一种解决方案是首先确保使用 -L 选项运行 sqlplus(尝试只登录一次,而不是重新提示错误。)然后解析输出,如果它包含

ORA-01017: invalid username/password; logon denied

SP2-0751: Unable to connect to Oracle.

表示登录失败。

注意:仅查找 ORA-01017 或 SP2-0751,因为字符串可能已本地化。

【讨论】:

以上是关于即使登录被拒绝,SQL*Plus 也会以 0 退出的主要内容,如果未能解决你的问题,请参考以下文章

即使是空角色,Keycloak 也会拒绝访问

即使正确设置了 document.domain,跨子域 ajax 请求也会被拒绝

即使使用正确的 API 密钥,Android 自动完成的 Google Places API 请求也会被拒绝

即使使用 RPC_C_AUTHN_NONE,Windows RPC 访问也会被拒绝

即使命令失败,退出状态也会返回“0”

即使在 Ar.js 中的浏览器中授予权限后,地理定位访问被拒绝弹出窗口也会显示