今天更新了一下 Oracle SQL Developer,发现连不上数据库了,测试连接报错:IO 错误:Undefined Error。后来在新装的虚拟机里安装了同样版本的 SQL Developer,发现连接成功了!分析了两个系统的环境基本一致,感觉不可思议。后来又打开 Wireshark 看看两个系统连接数据库的 TNS 包有何不同,发现报错的系统的登录 TNS 包被服务器返回了拒绝连接的包,而正常的系统不是这样。于是比较了一下两个登录请求包有何不同,发现大部分都相同,只有 User 部分不同,被拒绝的包的 User 部分是乱码,而正常的包里的 User 部分是全英文的 Windows 默认管理员用户名 Administrator。这时我想起报错系统的用户名是中文的,估计在新版本的 SQL Developer 中把系统的登录用户名放到了请求包里。我猜测 SQL Developer 是从 java 系统属性 user.name 取到的,而改变这个系统属性就应该可以解决这个问题。所以我在 SQL Developer 的安装目录里找了一下,发现了这样一个配置文件 "X:\xxx\sqldeveloper\sqldeveloper\bin\sqldeveloper.conf"。里面有许多 AddVMOption 这样的指令配置 java 系统属性,所以手工加了一条配置:
AddVMOption -Duser.name=SQL
保存重启 SQL Developer 后发现连接测试成功。