1

我的源代码中有一个用于处理目录路径和文件名的方法。某些路径和文件名有时会使用 '´' 或 'ñ' 字符。

问题是具有特殊字符的目录路径不被识别为目录并被识别为文件。我偶尔需要读取文件扩展名,当文件具有该字符时,代码不起作用并且没有达到 de 扩展名。

public static void listarDirectorio(File f, String separador) {

    File[] ficheros = f.listFiles();
    File ficheroTratado = null;

    logM.escribeLog(separador + "Ruta listada: " + f.getName(), false);

    for (int x = 0; x < ficheros.length; x++) {

        ficheroTratado = null;
        ficheroTratado = ficheros[x];

        if (!ficheros[x].isDirectory()) {
            if (esBorrable(ficheroTratado.getName())) {
                //  logM.escribeLog(
                //      "Fichero borrado: " + ficheroTratado.getName(),
                //  true);
            }
        }

        if (ficheros[x].isDirectory()
                && !ficheros[x].getName().startsWith("@")) {

            String nuevo_separador;
            nuevo_separador = separador + " # ";
            listarDirectorio(ficheros[x], nuevo_separador);
        }
    }
}

public static boolean esBorrable(String nFichero) {
    boolean esBorrable = false;

    try {
        String extension = "";
        int extIndex = nFichero.lastIndexOf(".");
        String ruta = "";

        //logM.escribeLog("nombre de fichero: " + nFichero, false);
        extension = nFichero.substring(extIndex, extIndex + 4);
        //logM.escribeLog("extension que tengo: " + extension, false);

        for (int i = 0; i < instance.getArrayExtensiones().size(); i++) {
            ruta = "";
            ruta = instance.getArrayExtensiones().get(i);

            if (ruta.equalsIgnoreCase(extension)) {
                //( logM.escribeLog("Este es borrable", false);
                esBorrable = true;
            } else {
                esBorrable = false;
            }
        }
    } catch (Exception e) {
        logM.escribeLog("Problema al tratar el fichero: " + nFichero, false);
        e.printStackTrace();
        return false;
    }

    return esBorrable;
}

我希望你能帮助我解决这个问题。

4

1 回答 1

1

好的,我已经复制了您的问题,但需要做一些事情!当语言环境或 file.encoding 与文件名的编码不匹配时,会出现此问题。请记住,在 Linux 中,文件系统名称只是一个 8 位字符串,并且没有强制编码。

要复制:

  1. Linux 机器,可能带有 ext2/ext3 文件系统。在 Windows 7 x64 上没有问题
  2. 使用 Windows-1252/ISO-88591-15 编码创建一个名为“dirñ”的目录。这可以通过将您的 Term 模拟器(例如 Putty)设置为 Windows-1252 Translation 来完成,然后:mkdir dirñ.
  3. 将您的语言环境设置为“en_US.UTF-8”
  4. 运行您的 Java 应用程序
  5. 包含非 UTF-8 字符的目录将被归类为文件。

解决方案

事实证明这是一个已知的错误,但唯一的解决方案是使用 Java 7 的 NIO2 实现:http://jcp.org/en/jsr/detail?id=203已经对此进行了测试,它确实按预期工作。在新的世界秩序中,您可以编写一个目录过滤器,如下所述:http: //docs.oracle.com/javase/tutorial/essential/io/dirs.html#filter

另一种解决方案是将所有文件名都使用相同的编码,例如 UTF-8,并确保您的语言环境匹配。问题在于,如果您知道现有编码是什么并且在您的文件中保持一致,则只能转换为新编码。

于 2013-10-10T17:46:09.440 回答