Oracle SQL Developer IO 错误:Undefined Error

今天更新了一下 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 后发现连接测试成功。

转载于:https://my.oschina.net/tweea/blog/1825484

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值