连接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参数设置。

相关推荐
科技小花1 天前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸1 天前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain1 天前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希1 天前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神1 天前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员1 天前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java1 天前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿1 天前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴1 天前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU1 天前
三大范式和E-R图
数据库