File.list()闪退

在某一个目录中执行file.list,出现了闪退相关日志如下

java.io.UnixFileSystem.list(UnixFileSystem.java:346)
java.io.File.list(File.java:1131)
java.io.File.listFiles(File.java:1295)
-----
其他的日志
abort message:  JNI DETECTED ERROR IN APPLICATION: input is not valid Modified UTF-8: illegal continuation byte 0
string: '导入?'
input: '0xe5 0xaf 0xbc 0xe5 0x85 0xa5 0xe6 0xb5'
in call to NewStringUTF
from java.lang.String[] java.io.UnixFileSystem.list0(java.io.File)

大概就是出现了一个非法的编码文件名
然后在adb -shell -ls如下

Ahwad2024.xml             abc.kml                     yy.txt
Ahwad2024.xml.sjwb        area1                       zzrl-231122.apk
Ahwad2024cut.xml          ashp20240507                    zzrl-231123.apk
Ahwad2024cut.xml.sjwb         backups                     交点法17.road
Alarms                baxi.dwg                    导入\346\265

确实存在,在文件管理器中,找到它并删除
无法直接删除ls -ln

drwxrwx--x  5 0 1015      3488 2024-06-24 11:19 导入\346\265

问了ai,不断尝试解决方案如下

 

import android.content.Context
import android.net.Uri
import android.provider.DocumentsContract
import android.util.Log
import java.io.IOException
import java.nio.file.Files
import java.nio.file.Path
import java.nio.file.Paths
import java.nio.file.StandardCopyOption

private const val TAG = "FileOperation"

class MyFile {




    /**
     * 使用 Java NIO 删除含有非 ASCII 字符的文件
     */
    fun deleteNIOFile(filePath: String) {
        val path = Paths.get(filePath)
        try {
            Files.delete(path)
        } catch (e: IOException) {
            Log.e("FileOperation", "Failed to delete file: $filePath", e)
        }
    }

    /**
     * 使用 Java NIO 删除含有非 ASCII 字符的文件
     * @param directoryPath 要删除文件所在的目录路径
     * @param fileName 要删除的文件名,可能包含非 ASCII 字符
     */
    fun deleteNIOFile(directoryPath: String, fileName: String) {
        val filePath = "$directoryPath$fileName"
        val path = Paths.get(filePath)
     try {
            Files.delete(path)
        } catch (e: IOException) {
            Log.e("FileOperation", "Failed to delete file: $filePath", e)
        }
    }

    /**
     * 使用 SAF (Storage Access Framework) 重命名含有非 ASCII 字符的文件
     */
    fun renameSAFFile(context: Context, fileUri: Uri, newName: String) {
        try {
            val updatedUri =
                DocumentsContract.renameDocument(context.contentResolver, fileUri, newName)
            Log.d("FileOperation", "File renamed: $updatedUri")
        } catch (e: Exception) {
            Log.e("FileOperation", "Failed to rename file: $fileUri", e)
        }
    }

    /**
     * 使用 Java NIO 重命名含有非 ASCII 字符的文件
     */
    fun renameNIOFile(sourcePath: String, targetPath: String) {
        val source = Paths.get(sourcePath)
        val target = Paths.get(targetPath)
        try {
            Files.move(source, target, StandardCopyOption.REPLACE_EXISTING)
        } catch (e: IOException) {
         Log.e("FileOperation", "Failed to rename file: $sourcePath to $targetPath", e)
        }
    }

    fun deleteNonAsciiFiles(directoryPath: String) {
        Log.d(TAG, "deleteNonAsciiFiles: ")
        val directory = Paths.get(directoryPath)
        try {
            Files.list(directory)
//                .filter { Files.isRegularFile(it) }
//                .filter { containsNonAsciiChars(it.fileName.toString()) }
                .filter{
                    it.fileName.toString().contains("导入")
                }
                .forEach {
                    Log.d("FileOperation", "deleteNonAsciiFiles: ${it.fileName}")
//                    deleteFile(it)
                    deleteDirectoryRecursively(it)
                    //deleteNIOFile(it.fileName.toString())

                }
        } catch (e: IOException) {
            Log.e(TAG, "deleteNonAsciiFiles: ",e)
            println("Error occurred while deleting non-ASCII files: $e")
        }
        Log.d(TAG, "deleteNonAsciiFiles: --")
    }


    fun deleteFile(filePath: Path) {
        if (Files.exists(filePath)) {
            try {
                Files.delete(filePath)
                println("File deleted: $filePath")
            } catch (e: IOException) {
                println("Failed to delete file: $filePath")
                e.printStackTrace()
            }
        } else {
            println("File not found: $filePath")
        }

        try {
            Files.delete(filePath)
        } catch (e: Exception) {
            Log.e(TAG, "deleteFile: ",e )
        }
    }

    fun deleteNonAsciiDirectory(directoryPath: String) {
        val path = Paths.get(directoryPath)
        try {
            deleteDirectoryRecursively(path)
        } catch (e: IOException) {
            println("Error occurred while deleting directory: $directoryPath")
            e.printStackTrace()
        }
    }

    private fun deleteDirectoryRecursively(path: Path) {
        Files.walk(path)
            .sorted(Comparator.reverseOrder())
            .forEach { file ->
                Log.d(TAG, "deleteDirectoryRecursively: ${file.fileName}")
                try {
                    Files.delete(file)
                    println("Deleted: $file")
                } catch (e: IOException) {
                    println("Failed to delete: $file")
                    e.printStackTrace()
                }
            }
    }



    fun containsNonAsciiChars(filename: String): Boolean {
        return filename.toByteArray().any { it.toInt() > 127 }
    }
}

调用方法

    private void toDelete(){
        try {
            final MyFile myFile = new MyFile();
//            myFile.deleteNIOFile("/storage/emulated/0/","导入\346\265");
            myFile.deleteNonAsciiFiles("/storage/emulated/0/");
        } catch (Exception e) {
            Log.e(TAG, "toDelete: ",new Exception() );
        }
    }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,542评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,822评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,912评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,449评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,500评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,370评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,193评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,074评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,505评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,722评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,841评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,569评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,168评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,783评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,918评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,962评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,781评论 2 354

推荐阅读更多精彩内容