Codemwnci Asked: 2010-10-27 23:50:31 +0800 CST2010-10-27 23:50:31 +0800 CST 2010-10-27 23:50:31 +0800 CST CRON 正在改变编码? 772 我有一个输出 SQL 脚本的遗留 Java 程序。然后,我使用 Apache Derby 在目标数据库(与 CRON 不在同一台服务器上)上运行该 SQL。 当通过腻子运行时,这工作正常。在 Windows 中运行时,它工作正常。使用 CRON 运行时,Derby 将 £ 符号读取为 ?。 如果我查看生成的 sql 脚本(使用 VI),它包含 £ 符号。但是,如果我检查数据库,它包含?。 为什么在 CRON 下运行它会使程序的行为有所不同? files cron encoding 2 个回答 Voted Best Answer Codemwnci 2010-10-28T12:50:04+08:002010-10-28T12:50:04+08:00 看来 CRON 是问题所在。当 Java 程序运行并将结果输出到文件时,它无法正确写入。我正在阅读的 SQL 文件指向了错误的版本。 为了解决这个问题,我在 CRON 脚本顶部附近添加了以下代码 export LANG = en_US.UTF-8 这确保了 £ 符号的格式正确。 snickers2k 2015-04-08T19:16:08+08:002015-04-08T19:16:08+08:00 对我来说,上述解决方案不起作用。我读到的另一个解决方案是设置 “/etc/environment”文件中的“LANG=en_US.UTF-8”。 但也没有工作。 对我有用的是打开 crontab 文件 crontab -e 并在开头设置: LANG=de_DE.UTF-8 LANGUAGE=de LC_CTYPE=de_DE.UTF-8 PYTHONIOENCODING=utf8 这也设置了环境变量。 这必须对您要运行这些变量的每个用户进行。对于 root 在进入 crontab 之前运行“sudo -s”。
看来 CRON 是问题所在。当 Java 程序运行并将结果输出到文件时,它无法正确写入。我正在阅读的 SQL 文件指向了错误的版本。
为了解决这个问题,我在 CRON 脚本顶部附近添加了以下代码
这确保了 £ 符号的格式正确。
对我来说,上述解决方案不起作用。我读到的另一个解决方案是设置
“/etc/environment”文件中的“LANG=en_US.UTF-8”。
但也没有工作。
对我有用的是打开 crontab 文件
并在开头设置:
这也设置了环境变量。
这必须对您要运行这些变量的每个用户进行。对于 root 在进入 crontab 之前运行“sudo -s”。