투케이2K

756. (Android/Java) [유틸 파일] : directoryFileList : 특정 디렉토리에 저장된 파일 리스트 목록 확인 - File listFiles 본문

Android

756. (Android/Java) [유틸 파일] : directoryFileList : 특정 디렉토리에 저장된 파일 리스트 목록 확인 - File listFiles

투케이2K 2024. 4. 1. 19:37
반응형

[개발 환경 설정]

개발 툴 : AndroidStudio

 

[소스 코드]

    // -----------------------------------------------------------------------------------------
    // TODO [SEARCH FAST] : [RETURN] directoryFileList : 특정 디렉토리에 저장된 파일 리스트 목록 확인
    // -----------------------------------------------------------------------------------------
    public static ArrayList<File> directoryFileList(Context mContext, String path) {

        /**
         * // -----------------------------------------
         * [directoryFileList 메소드 설명]
         * // -----------------------------------------
         * 1. 특정 디렉토리에 저장된 파일 리스트 목록 확인
         * // -----------------------------------------
         * 2. 호출 방식 :
         *
         *   C_App.directoryFileList(A_Main.this, Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS).getAbsolutePath());
         *
         * // -----------------------------------------
         * 3. 리턴 데이터 : [/storage/emulated/0/Download/test.dat, /storage/emulated/0/Download/test.apk]
         * // -----------------------------------------
         * 4. 추가로 외부 저장소에 파일 읽기 및 쓰기를 위해서 Manifest 권한 필요 및 인텐트 이동 수행
         *
         * 권한 : <uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE" />
         *
         * 인텐트 이동 : Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION
         * // -----------------------------------------
         * 5. 참고 설명 :
         *
         * 해당 권한을 추가 시 마켓에 특정 용도로 사용하는 앱 목적을 밝혀야합니다 (앱 등록 및 업데이트 리젝 될 수 있습니다)
         *
         * 외부 저장소 경로 : /storage/emulated/0
         * // -----------------------------------------
         * */


        // [리턴 값 선언]
        ArrayList<File> returnData = new ArrayList<>();
        String M_LOG = "";


        // [로직 처리 실시]
        try {

            // [데이터 널 체크]
            if (C_Util.stringNotNull(path) == true){

                // [File 생성]
                File file = new File(path);

                // [해당 디렉토리 존재 확인]
                if (file.isDirectory() == true){

                    // [파일 리스트 확인]
                    File [] list = file.listFiles();

                    if (list != null && list.length > 0){

                        // [리턴 데이터 삽입]
                        returnData.addAll(Arrays.asList(list));
                        M_LOG = "[SUCCESS] : File List Check";
                    }
                    else {
                        M_LOG = "[ERROR] : File List Is Null";
                    }
                }
                else {
                    M_LOG = "[ERROR] : Directory Is Null";
                }

            }
            else {
                M_LOG = "[ERROR] : Input Path Is Null";
            }

        } catch (Exception e) {
            S_Log._printStackTrace_(mContext, S_FinalMsg.LOG_BUG_STATE, null, e);

            M_LOG = "[EXCEPTION] : " + String.valueOf(e.getMessage());
        }


        // [로그 출력 실시]
        // ===============================================================
        S_Log._D_("특정 디렉토리에 저장된 파일 리스트 목록 확인", new String[]{
                "INPUT [PATH] :: " + String.valueOf(path),
                "M_LOG :: " + String.valueOf(M_LOG),
                "RETURN :: " + String.valueOf(returnData)
        });
        // ===============================================================


        // [리턴 반환 실시]
        return returnData;
    }
 

[결과 출력]

 

D///===========//: ================================================
I/: [LOG :: CLASS PLACE :: com.example.javaproject.C_App.directoryFileList(C_App.java:9971)]
I/: ----------------------------------------------------
I/: [LOG :: NOW TIME :: 2024-04-01 15:05:21 월요일]
I/: ----------------------------------------------------
I/: [LOG :: DESCRIPTION :: 특정 디렉토리에 저장된 파일 리스트 목록 확인]
I/: ----------------------------------------------------
I/: [LOG :: INPUT [PATH] :: /storage/emulated/0/Download]
I/: ----------------------------------------------------
I/: [LOG :: M_LOG :: [SUCCESS] : File List Check]
I/: ----------------------------------------------------
I/: [LOG :: RETURN :: [/storage/emulated/0/Download/test.dat]]
D///===========//: ================================================

 

반응형
Comments