플래시 플레이어는 기본적으로 AMF데이터를 지원하고 있다. 이 AMF라는 것은 오브젝트 인코딩 데이터로서 액션스크립트에서 사용되는 데이터들을 바이트 형태로 저장 / 전송 할 수 있는 방식이다.
가령 액션스크립트의 NetConnection을 사용하여 리모트 콜을 하면 데이터는 자동으로 AMF 형태로 직렬화 하고 사용하는 객체나 클래스에서는 이를 다시 AMF 형태에서 역직렬화 하여 사용한다. 마찬가지로 Shared Object 에 저장을 할때는 자동으로 AMF로 저장되고 Shared Object에서 읽어올 때는 액션스크립트 객체로 역직렬화 한다.
[ AMF 통신 구조 ]
[액션스크립트 객체] <- [AMF] -> [시스템이나 서버 등]
AMF 방식에는 AMF0과 AMF3의 두 종류가 있다.
AMF0은 AVM1과의 호환성을 지원하고 AMF3은 AVM2와 AIR를 지원한다.
보통 런타임 초기에 AMF데이터로 사용할 객체를 registerClassAlias로 매핑해야 한다.
registerClassAlias( "별명" , 실제 클래스 이름 )
이후 런타임시 필요한 데이터를 AMF로 사용할 객체에 데이터를 저장하고 사용하다가 필요할 때 해당 객체를 생성하여 대괄호 연산식([]) 등을 사용하여 꺼내쓴다.
Flex인 경우에는 [RemoteClass(alias="별명") 메타 태그를 AMF로 사용할 객체에 코딩하여 액션스크립트 객체를 매핑하고, 이 후 [Bindable]을 사용하여 등록한 매핑 클래스를 가져와 사용하여야 한다.
'AS3.0 Cookbook/지속성 데이터'에 해당되는 글 4건
- 2008.12.27 AMF 직렬화 방식 사용법
- 2008.09.06 서로 다른 무비간 공유객체 데이터 공유
- 2008.09.06 공유객체에 데이터 저장과 Client PC에 기록하기
- 2008.09.01 super cookies 또는 flash cookies라 불리는 LSO(local shared object)
getLocal(name:String, localPath:String = null, secure:Boolean = false);
localPath : 매개 변수를 "/" , "/apps" , "/apps/filename.swf" 로 설정할 수 있다
이중 /는 모든 보안에 대해 개방을 하므로 총돌이 일어날 가능성이 매우 크다.
secure : HTTPS 연결을 통해 전달된 SWF 파일만이 이 공유 객체에 액세스할 수 있도록 제한할지
여부를 결정
true : Flash Player가 보안 공유 객체를 새로 만들거나 기존 보안 공유 객체에 대한 참조를
가져옵니다. 공유 객체는 secure 매개 변수가 true로 설정된 SharedObject.getLocal()을
호출하는 HTTPS를 통해 전달되는 SWF 파일에 의해서만 읽거나 쓸 수 있습니다.
false : Flash Player는 비 HTTPS 연결을 통해 전달되는 SWF 파일에서 읽거나 쓸 수 있는
새로운 공유 객체를 만들거나 기존 공유 객체에 대한 참조를 가져옵니다.
위에 2번째 파라미터를 "/"등으로 설정하면 다른 무비간에 데이터를 공유할 수 있다. 물론 같은 도메인에서만 가능한 얘기이다.
따라서 서로 다른 무비가 같은 공유객체를 만들거나 읽어오도록 같은 값으로 설정하면 값을 서로 설정하거나 읽어 올 수 있다. 단 동기화에는 문제가 있어보인다. A무비에서 기록한 데이터는 항상 데이터 기록과 함께 즉시 값을 보여주지만 B무비에서는 한 단계 이전의 데이터를 불러온다. 기록 시점과 읽어오는 시점에 차이가 있는것 같다.
우선 AS3에서 제공하는 SharedObject의 deletage를 만든 다음 생성자 없이 getLocal()를 통해
데이터를 만들거나 읽기를 한다.
이후 객체에 데이터를 설정하기 위해서는 SharedObject.data를 통해 이름과 값을 설정한다.
단 getLocal("이름")의 이름과 data에 저장하는 변수의 이름이 같으면 안된다.
[ 공유객체 생성/로드 ]
var so:SharedObject = SharedObject.getLocal("jys");
[ 공유객체의 data를 통해 데이터를 설정 ]
so.data.userName = "jeong youn soo";
so.data.text = "공유객체에 이 내용을 저장한다.";
so.data.ary = ["a" , "b" , "c"];
so.data.date = new Date();
so.data.obj = {key1:"예시" , key2:-20 , key3:null }
위처럼 공유객체에서 지원하는 data라는 속성을 사용하여 데이터를 선언하여야 한다. 선언할 수 있는 데이터 타입은 문자,숫자,Date,오브젝트등 AS3에서 제공하는 대부분의 데이터 타입을 저장 할 수 있으면 심지어 인스턴스 클래스까지 저장 할 수 있다.
단 아래처럼 공유객체에 직접 데이터를 설정하면 에러를 발생한다.
so.text = "이것은 컴파일 에러를 발생한다.";
위에서 처럼 SharedObject에 데이터를 설정하면 자동으로 클라이언트 Pc에 기록된다.
그러나 기본 100kb를 넘어서거나 사용자가 저장 용량을 저장할 데이터 보다 적게 선언하였을 때는
저장 하지를 못한다.
이때 이를 체크할 수 있도록 SharedObjectFlushStatus는 저장 성공/실패 여부를 반환한다.
이를 체크하기 위해서는 SharedObject의 상태를 확인할 수 있는 flush()라는 메서드를 사용한다.
[ 저장상태를 체크 ]
var flushResult:String = so.flush();
저장이 성공하면 flush()메서드는 "flushed"를 반환하며 저장이 실패하면 "pending"을 넘겨준다.
이들은 SharedObjectFlushStatus에 상수로 설정되어있다.
if( flushResult == SharedObjectFlushStatus.FLUSHED ) {
저장 성공 액션
}else if( flushResult == SharedObjectFlushStatus.PENDING ){
저장 실패 액션
}
만약 저장에 실패하였을 경우에는 사용자에게 저장 여부를 확인하여야 한다.
따라서 Security.showSettings( SecurityPanel.LOCAL_STORAGE )를 try~catch문에 삽입하여
에러가 발생하면 SecurityPanel창을 띄워 저장 공간을 늘리게하거나 저장 허용하도록 한다.
이때 넘어오는 이벤트가 NetStatusEvent이벤트이다.
저장 실패시 이러한 이벤트를 SharedObject에 리스너를 등록하고 사용자가 승인또는 비승인을 체크하여
프로세스를 이어가야 한다.
SecurityPanel에서 승인이 발생하면 SharedObject.Flush.Success를 건네주고
그렇지 않으면 SharedObject.Flush.Failed를 건네준다.
액션스크립트는 대부분 메모리에 데이터가 저장되어 사용하다가 무비가 종료하면 데이터도 사라지게 된다. 하지만 무비가 종료되더라도 데이터를 남겨 사용하고 싶거나 같은 클라이언트에서 다른 무비들간에 데이터를 공유하고 싶을 때는 SharedObject(공유객체)라는 것을 사용한다.
SharedObject()는 쿠키보다 더 큰 데이터(최고 100kb)를 저장 할 수 있으며 AS3의 데이터 타입을 그대로 저장/사용 할 수 있다. 이 객체를 사용하여 사용자 컴퓨터에 데이터를 저장하게 되면 "sol"이라는 확장자의 바이너리 데이터를 C:\Documents and Settings\Administrator\Application Data\Macromedia\Flash Player\#SharedObjects\[랜덤폴더명]..와 같은 경로에 생성하게 된다.
client : Object 콜백 메서드가 호출되는 객체를 나타냅니다. |
data : Object [read-only] 객체의 data 속성에 할당된 특성 모음입니다. 이러한 특성은 공유 및 저장이 가능합니다. |
defaultObjectEncoding : uint [static] SWF 파일에서 만들어진 모든 로컬 공유 객체에 대한 기본 객체 인코딩(AMF 버전)입니다. |
fps : Number [write-only] 공유 객체에 대한 클라이언트의 변경이 서버로 전송되는 초당 횟수를 지정합니다. |
objectEncoding : uint 이 공유 객체의 객체 인코딩(AMF 버전)입니다. |
size : uint [read-only] 공유 객체의 현재 크기(바이트)입니다. |
clear():void 로컬 공유 객체의 경우, 모든 데이터를 제거하고 디스크에서 공유 객체를 삭제합니다. |
close():void 원격 공유 객체와 서버 간의 연결을 종료합니다. |
connect(myConnection:NetConnection, params:String = null):void 지정된 연결을 통해 서버의 원격 공유 객체에 연결합니다. |
flush(minDiskSpace:int = 0):String 로컬 영구 공유 객체를 로컬 파일에 즉시 기록합니다. |
getLocal(name:String, localPath:String = null, secure:Boolean = false):SharedObject [static] 현재 클라이언트에만 사용 가능한 로컬 영구 공유 객체에 대한 참조를 반환합니다. |
getRemote(name:String, remotePath:String = null, persistence:Object = false, secure:Boolean = false):SharedObject [static] Flash Media Server와 같은 서버를 이용하여 여러 클라이언트 간에 공유할 수 있는 객체에 대한 참조를 반환합니다. |
send(... arguments):void 메시지를 보낸 클라이언트를 포함하여 지정된 원격 공유 객체에 연결된 모든 클라이언트로 메시지를 브로드캐스트합니다. |
setDirty(propertyName:String):void 공유 객체의 속성 값(data 속성으로 정의)이 변경되었음을 서버에 알립니다. |
setProperty(propertyName:String, value:Object = null):void 공유 객체의 속성 값(data 속성으로 정의)을 업데이트하고 해당 속성의 값이 변경되었음을 서버에 알립니다. |
이벤트 |
요약 |
asyncError |
기본 비동기 코드에서 비동기적으로 예외가 발생할 때 전달됩니다. |
netStatus |
SharedObject 인스턴스가 상태 또는 오류 상황을 보고할 때 전달됩니다. |
sync |
서버에서 원격 공유 객체(SharedObject)를 업데이트하면 전달됩니다. |