반응형
=================================
=================================
=================================
출처: http://androidhuman.tistory.com/entry/%EC%95%88%EB%93%9C%EB%A1%9C%EC%9D%B4%EB%93%9C%EC%9D%98-%ED%8C%8C%EC%9D%BC-%EC%9E%85%EC%B6%9C%EB%A0%A5%EC%97%90-%ED%95%84%EC%9A%94%ED%95%9C-%EA%B2%BD%EB%A1%9C%EB%A5%BC-%EC%96%BB%EB%8A%94-%EB%B0%A9%EB%B2%95-%EC%B4%9D%EC%A0%95%EB%A6%AC
애플리케이션을 제작하다 보면 파일을 입/출력 기능을 구현해야 하는 경우가 있습니다. 파일 입/출력을 수행하려면 파일의 경로를 꼭 알아야 하는데, 안드로이드에서 파일을 저장할 수 있는 경로는 다양합니다.
가장 크게 애플리케이션 데이터가 저장되는 영역(일반적으로 '내부 저장소(Internal Storage)'라 불림)와 사진, 비디오, 데이터 등을 저장하는 영역(일반적으로 '외부 저장소(External Storage)(주1)'라 불림)으로 나뉠 수 있으며, 각 영역별로 다시 캐시 데이터가 저장되는 영역, 데이터베이스가 저장되는 영역 등으로 나뉩니다.
(주1) 외부 저장소는 사용자 데이터(사진, 동영상, 등)이 저장되는 영역입니다. 일반적으로 이는 단말기의 외장 SD카드를 지칭하지만, 단말기에 따라서는 이 영역이 외장 SD카드가 아닌 단말기 내부에 탑재되어 있는 경우도 있었습니다. (넥서스S가 이에 해당) 또는, 단말기 내에 탑재된 외장 메모리 영역 외에 별도의 SD카드도 지원하는 단말기도 존재합니다. (갤럭시S가 이에 해당)
내부 저장소는 각 애플리케이션에서만 데이터를 읽고 쓸 수 있지만, 외부 저장소에는 특정 애플리케이션에서만 사용하는 애플리케이션 고유 영역과 공용 영역이 각각 존재합니다. 애플리케이션 고유 영역에는 각 애플리케이션에서 사용하는 데이터를 저장하며, 이 영역에 저장된 내용은 애플리케이션이 삭제될 때 같이 삭제됩니다.
공용 영역에는 사진, 비디오, 기타 파일 등을 저장하며 애플리케이션의 삭제에 영향을 받지 않습니다. 하지만, 외부 저장소에 저장된 데이터는 애플리케이션 고유 영역에 저장되어 있더라도 다른 애플리케이션에서 해당 데이터에 접근하는 것이 가능합니다.
각 영역의 경로가 필요할 때마다 해당 경로를 직접 써서 사용할 수도 있겠지만, 번거롭기도 하고 각 유형에 해당하는 경로를 그 때마다 찾아봐야 하므로 시간도 많이 소요됩니다. 이러한 이유로 안드로이드에서는 데이터가 저장되는 주요 경로를 간편하게 얻는 메서드를 제공합니다.
내부 저장소
1. 캐시(Cache) 저장 영역
캐시 디렉터리에는 애플리케이션에서 필요한 임시 파일들이 저장됩니다.
API
File Context.getCacheDir()
내부 저장소의 캐시 디렉터리 경로를 반환합니다.
내부 저장소의 캐시 디렉터리 경로는 다음과 같이 구성됩니다.
/data/data/[패키지 이름]/cache
패키지 이름이 com.androidhuman.app 일 경우, 이 애플리케이션의 캐시 디렉터리 경로는 다음과 같습니다.
/data/data/com.androidhuman.app/cache
2. 데이터베이스(Database) 파일
애플리케이션에서 사용하는 데이터베이스 파일들이 저장됩니다.
API
File Context.getDatabasePath(String name)
데이터베이스 파일의 경로를 반환합니다. 인자로 데이터베이스 파일의 이름을 넘겨줍니다.
데이터베이스 파일이 저장되는 경로는 다음과 같이 구성됩니다.
/data/data/[패키지 이름]/databases
패키지 이름이 com.androidhuman.app 일 경우, 데이터베이스 파일은 다음 경로에 저장됩니다.
/data/data/com.androidhuman.app/databases
3. 일반 파일 저장 영역
데이터베이스와 캐시를 제외한 애플리케이션에서 사용하는 일반 파일이 저장되는 영역입니다. 이 경로는 Context.openFIleOutput(String, int)를 사용하여 생성되는 파일이 저장되는 경로와 동일합니다.
API
File Context.getFilesDir()
애플리케이션에서 사용하는 일반 파일들이 저장되는 경로를 반환합니다.
파일이 저장되는 경로는 다음과 같이 구성됩니다.
/data/data/[패키지 이름]/files
패키지 이름이 com.androidhuman.app 일 경우, 일반 파일은 다음 경로에 저장됩니다.
/data/data/com.androidhuman.app/files
애플리케이션에서 사용하는 각 일반 파일들의 경로를 가져오려면 다음 메서드를 사용합니다.
API
File Context.getFileStreamPath(String name)
일반 파일이 저장된 공간에서 특정 이름을 가지는 파일의 경로를 반환합니다. 인자로 확장자를 포함한 파일 이름을 넘겨줍니다.
파일의 경로는 다음과 같이 구성됩니다.
/data/data/[패키지 이름]/files/[파일이름]
패키지 이름이 com.androidhuman.app 이고 파일 이름이 filename.ext일 경우, 파일의 경로는 다음과 같습니다.
/data/data/com.androidhuman.app/files/filename.ext
외부 저장소-공용 영역
1. 최상위 경로 얻기
외부 저장소(일반적으로 SD카드)의 최상위 경로를 의미합니다.
API
static File Environment.getExternalStorageDirectory()
외부 저장소의 최상위 경로를 반환합니다.
2.2 (Froyo) 이상을 기준으로 반환되는 최상위 경로는 일반적으로 다음과 같습니다.
/mnt/sdcard
2. 특정 데이터를 저장하는 영역
여러 애플리케이션에서 공용으로 사용할 수 있는 데이터들을 저장합니다. 데이터의 유형에 따라 별도의 디렉터리를 사용합니다.
API
static File Environment.getExternalStoragePublicDirectory(String type)
데이터 유형에 따른 외부 저장소의 저장 공간 경로를 반환합니다. 인자로 디렉터리의 유형을 넘겨줍니다.
안드로이드에서는 총 7개 데이터 유형에 대한 표준 저장 경로를 제공합니다. Environment.getExternalStoragePublicDirectory()의 인자로 넘겨줄 수 있는 인자 및 각 인자의 경로는 다음과 같습니다.
인자명 | 설명 | 경로 |
Environment.DIRECTORY_ALARMS | 알람으로 사용할 오디오 파일을 저장합니다. | /mnt/sdcard/Alarms |
Environment.DIRECTORY_DCIM | 카메라로 촬영한 사진이 저장됩니다. | /mnt/sdcard/DCIM |
Environment.DIRECTORY_DOWNLOADS | 다운로드한 파일이 저장됩니다. | /mnt/sdcard/Download |
Environment.DIRECTORY_MUSIC | 음악 파일이 저장됩니다. | /mnt/sdcard/Music |
Environment.DIRECTORY_MOVIES | 영상 파일이 저장됩니다. | /mnt/sdcard/Movies |
Environment.DIRECTORY_NOTIFICATIONS | 알림음으로 사용할 오디오 파일을 저장합니다. | /mnt/sdcard/Notifications |
Environment.DIRECTORY_PICTURES | 그림 파일이 저장됩니다. | /mnt/sdcard/Pictures |
Environment.DIRECTORY_PODCASTS | 팟캐스트(Poacast) 파일이 저장됩니다. | /mnt/sdcard/Podcasts |
외부 저장소-애플리케이션 고유 영역
1. 특정 데이터를 저장하는 영역
애플리케이션 고유 영역에도 공용 영역과 마찬가지로 각 데이터 유형별로 데이터를 저장하는 표준 디렉터리를 제공합니다.
API
File Context.getExternalFilesDir(String type)
애플리케이션 고유 영역의 데이터 유형에 따른 외부 저장소의 저장 공간 경로를 반환합니다. 인자로 디렉터리의 유형을 넘겨줍니다.
각 경로의 역할은 공용 영역과 동일합니다.
인자명 | 경로 |
Environment.DIRECTORY_ALARMS | /mnt/sdcard/Android/data/[패키지 이름]/files/Alarms |
Environment.DIRECTORY_DCIM | /mnt/sdcard/Android/data/[패키지 이름]/files/DCIM |
Environment.DIRECTORY_DOWNLOADS | /mnt/sdcard/Android/data/[패키지 이름]/files/Downloads |
Environment.DIRECTORY_MUSIC | /mnt/sdcard/Android/data/[패키지 이름]/files/Music |
Environment.DIRECTORY_MOVIES | /mnt/sdcard/Android/data/[패키지 이름]/files/Movies |
Environment.DIRECTORY_NOTIFICATIONS | /mnt/sdcard/Android/data/[패키지 이름]/files/Notifications |
Environment.DIRECTORY_PICTURES | /mnt/sdcard/Android/data/[패키지 이름]/files/Pictures |
Environment.DIRECTORY_PODCASTS | /mnt/sdcard/Android/data/[패키지 이름]/files/Podcasts |
null | /mnt/sdcard/Android/data/[패키지 이름]/files |
2. 캐시 데이터를 저장하는 영역
애플리케이션에서 사용하는 임시 데이터를 외부 저장소에 저장합니다.
API
File Context.getExternalCacheDir()
외부 저장소의 캐시 디렉터리를 반환합니다.
외부 저장소의 캐시 저장 경로는 일반적으로 다음과 같이 구성됩니다.
/mnt/sdcard/Android/data/[패키지 이름]/cache
패키지 이름이 com.androidhuman.app 일 경우, 캐시 저장 경로는 다음과 같습니다.
/mnt/sdcard/Android/data/com.androidhuman.app/cache
/mnt/sdcard/Android/data/com.androidhuman.app/cache
=================================
=================================
=================================
출처: http://maluchi.cafe24.com/xe/index.php?mid=MyAndroidTips&sort_index=readed_count&order_type=asc&page=2&listStyle=webzine&document_srl=26721
1. 현재 설치된 패키지 경로 얻는 방법
1.
getApplicationContext().getFilesDir().getAbsolutePath().replace(
"files"
,
""
);
2.
//data/data/com.maluchi.ModuleDemo/files
3.
//data/data/com.maluchi.ModuleDemo/
2. assets 폴더의 특정 파일을 설치된 패키지의 특정경로로 복사하는 방법
01.
//Environment.getDataDirectory().getAbsolutePath()
02.
private
int
saveDefaultModule(String assetsfile)
03.
{
04.
AssetManager mgr = getResources().getAssets();
05.
if
(mgr !=
null
)
06.
{
07.
FileInputStream fis =
null
;
08.
BufferedInputStream bis =
null
;
09.
FileOutputStream fos =
null
;
10.
11.
try
{
12.
InputStream is = mgr.open(assetsfile);
13.
bis =
new
BufferedInputStream(is);
14.
//fis = new FileInputStream(bis);
15.
16.
Log.d(
"maluchi"
,
"package path: "
+getApplicationContext().getFilesDir().getAbsolutePath());
17.
18.
String path = getApplicationContext().getFilesDir().getAbsolutePath().replace(
"files"
,
"module"
);
19.
File f =
new
File(path);
20.
if
(!f.exists())
21.
f.mkdirs();
22.
23.
String outfile = path +
"/"
+assetsfile;
24.
Log.d(
"maluchi"
,
"path: "
+outfile);
25.
26.
f =
new
File(outfile);
27.
if
(!f.exists())
28.
{
29.
fos =
new
FileOutputStream(f);
30.
31.
int
readBytes =
0
;
32.
byte
[] buf =
new
byte
[
1024
];
33.
while
((readBytes = bis.read(buf,
0
,
1024
)) != -
1
) {
34.
fos.write(buf,
0
, readBytes);
35.
}
36.
}
37.
38.
if
(fos !=
null
)
39.
fos.close();
40.
if
(bis !=
null
)
41.
bis.close();
42.
mgr.close();
43.
}
catch
(IOException e) {
44.
// TODO: handle exception
45.
Log.e(
"maluchi"
, e.getMessage());
46.
47.
try
{
48.
if
(fos !=
null
)
49.
fos.close();
50.
if
(bis !=
null
)
51.
bis.close();
52.
mgr.close(); }
catch
(Exception e2) {
53.
// TODO: handle exception
54.
}
55.
}
=================================
=================================
=================================
퍼미션
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
package kr.co.SDCard;
import! java.io.File;
import! java.io.FileInputStream;
import! java.io.FileNotFoundException;
import! java.io.FileOutputStream;
import! android.app.Activity;
import! android.os.Bundle;
import! android.os.Environment;
import! android.view.View;
import! android.widget.Button;
import! android.widget.EditText;
public class SDCard extends Activity {
EditText mEdit;
String mSdPath;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mEdit = (EditText)findViewById(R.id.edittext);
findViewById(R.id.test).setOnClickListener(mClickListener);
findViewById(R.id.save).setOnClickListener(mClickListener);
findViewById(R.id.load).setOnClickListener(mClickListener);
String ext = Environment.getExternalStorageState(); // 외부 저장소 상태 반환
if(ext.equals(Environment.MEDIA_MOUNTED)){
mSdPath = Environment.getExternalStorageDirectory().getAbsolutePath();
} else {
mSdPath = Environment.MEDIA_UNMOUNTED;
}
}
Button.OnClickListener mClickListener = new View.OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
switch(v.getId()){
case R.id.test:
// 루트 디렉토리 경로 반환
String rootdir = Environment.getRootDirectory().getAbsolutePath(); // 반환값 : /system
// 데이터 디렉토리 경로 반환
String datadir = Environment.getDataDirectory().getAbsolutePath(); // 반환값 : /data
// 캐시 디렉토리 경로 반환
String cachedir = Environment.getDownloadCacheDirectory().getAbsolutePath(); // 반환값 : /cache
mEdit.setText(String.format("ext = %s\nroot=%s\ndata=%s\ncache=%s", mSdPath, rootdir, datadir, cachedir));
break;
case R.id.save:
File dir = new File(mSdPath + "/dir");
dir.mkdir(); // 디렉토리 생성
File file = new File(mSdPath + "/dir/file.txt"); // 파일 생성
try{
FileOutputStream fos = new FileOutputStream(file); // 파일 출력 스트림 생성
String str = "This file exists in SDCard";
fos.write(str.getBytes()); // 쓰기
fos.close();
mEdit.setText("Write success");
} catch (FileNotFoundException e){
mEdit.setText("File not found Exception");
} catch (SecurityException e) {
mEdit.setText("Security Exception");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
break;
case R.id.load:
try{
FileInputStream fis = new FileInputStream(mSdPath + "/dir/file.txt");
byte[] data = new byte[fis.available()];
while(fis.read(data) != -1) { ; }
fis.close();
mEdit.setText(new String(data));
} catch (FileNotFoundException e) {
mEdit.setText("File not found");
} catch (Exception e) {
mEdit.setText(e.getMessage());
}
break;
}
}
};
}
출처 : http://blog.daum.net/haha25/5387371
=================================
=================================
=================================
반응형
'스마트기기개발관련 > 안드로이드 개발' 카테고리의 다른 글
안드로이드 스크롤 있는 컨트롤들 자동으로 아래(밑)으로 스크롤 관련 (0) | 2011.06.28 |
---|---|
안드로이드 setVisibility - gone와 invisible 와 visible 차이 (0) | 2011.06.27 |
안드로이드 웹을 이용한 이미지 관련 (0) | 2011.06.24 |
안드로이드 제공 searchable 이용해서 검색창 넣기 (1) | 2011.06.20 |
안드로이드 ListView CHOICE_MODE_MULTIPLE 멀티초이스(리스트뷰 체크박스 같이 연동) 관련 (4) | 2011.06.17 |