连接oracle报 错误: Undefined Error

如果你的电脑用户名是纯英文,那么这篇文章可能对你没用

ERROR com.alibaba.druid.pool.DruidDataSource - init datasource error, url: jdbc:oracle:thin:@//192.168.111.86:1521/sjtsoms

java.sql.SQLRecoverableException: IO 错误: Undefined Error

md,我要是不看到《SpringBoot项目启动Application报错------ojdbc8驱动升级后不兼容中文用户名导致》这篇文章,这辈子都想不到。

之前的项目也是这样我加了个中文包和换了个依赖就行了,就是有一个项目怎么都是不行,还好找到了方法。
也在文章(方法一)的基础上进行了拓展,个人代码用方法1完事,公司的代码我就不想动无关的我就用方法3

方法一

在Java应用启动时设置System属性,将user.name属性值改为英文名。

如何设置System.setProperty("user.name", "English Name")

直接在代码中设置 :在Java应用的入口方法(如main方法)中加
System.setProperty("user.name", "English Name");。这种方式的缺点是对代码的侵入性较大,而且不便于维护。

java 复制代码
public class Application {
    public static void main(String[] args) {
        System.setProperty("user.name", "EnglishIkun");
        // 启动Spring Boot应用或其他应用逻辑
    }
}

方法二

使用启动脚本设置:如果您的应用是通过脚本启动的(例如一个shell脚本或bat脚本),您可以在脚本中设置JVM参数。这样做的好处是不需要修改Java代码。

  • 对于Shell脚本(Linux/Unix):

    bash 复制代码
    java -Duser.name=EnglishName -jar yourapp.jar
  • 对于Batch脚本(Windows):

    bash 复制代码
    java -Duser.name=EnglishName -jar yourapp.jar

方法三

使用IDE设置:如果您是在开发环境中运行应用,如IntelliJ IDEA或Eclipse,您可以在运行> 配置中添加VM选项:

复制代码
-Duser.name=EnglishName

这种方式适合开发和测试,但不适合生产环境。

考虑到您的用户名难以修改,我建议使用第二种或第三种方法,这样可以避免直接修改代码。如> 果您的应用是通过某种自动化方式部署的,您可能需要在部署脚本中添加相应的JVM参数设置。

相关推荐
阿正的梦工坊14 分钟前
【Rust】04-借用、引用与切片
java·数据库·rust
AOwhisky19 分钟前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
阿标在干嘛29 分钟前
政策平台的推送系统:消息队列、定时任务、AB测试的工程实践
服务器·数据库·ab测试
Upsy-Daisy39 分钟前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库
Tongpao_SSDHDD1 小时前
希捷酷鹰ST6000VX008实测解析:中小安防监控高性价比存储方案
大数据·数据库·人工智能
蓝鸟19742 小时前
Oracle超大DMP备份文件瘦身、日志精简、磁盘空间优化实战方案日志
数据库·oracle·数据库运维·生产运维实战·oracle避坑·磁盘空间优化·oracle日志清理
金融支付架构实战指南2 小时前
CQRS + 命令模式 + 事件驱动 + 数据库持久化
数据库·ddd·命令模式·领域驱动模型
sevenll072 小时前
DocKit agentic MongoDB GUI 客户端 - 用自然语言和你的数据对话
数据库·mongodb·nosql·agent·桌面客户端
团象科技2 小时前
从一线实操案例拆解不同出海团队落地海外VPS运维独立站的路径细节
大数据·数据库·人工智能
小马爱打代码3 小时前
框架 - 组件 - 中间件:生产级参数配置指引
数据库·中间件