파일을 업로드할 때에는 form의 enctype을 multipart/form-data 타입으로 지정해야 한다.
2.x의 ExtJS의 FormPanel에서는 이를 지정할 수 없어 별도의 플러그인인을 사용해오곤 했는데
3.x에서는 FormPanel에 FileUpload라는 속성이 추가되어 파일업로드를 할 수 있게 되었다.

new Ext.FormPanel({
    fileUpload: true,
    baseParams: {
        foo: 'bar'
    },
    url: 'myProcess.do',
    items: [{
        xtype: 'fileuploadfield',
        name: 'upload'
    }],
    buttons: [{
        text: 'Save',
        handler: function(){
            var fp = this.ownerCt.ownerCt,
                form = fp.getForm();
            if (form.isValid()) {
                form.submit();
            }
        }
    }]
});

업로드 성공시 
{'success':true}
 라는 JSON 객체를 반환하도록 구현하였는데.

아무런 반응도 없다. 반환하는 result 값으로 failure와 error도 만들어봐도 수신하지 못한다.
확인된 스크립트 에러는 JSON 유형에 맞지 않아 파싱할 수 없단다. -_-a
확인해보니 반환된 값은
 
<PRE>{'success':true}</PRE>

허걱. 갑자기 무슨 PRE 태그란 말인가? 덕분에 한참 삽질한 덕분에 알게된 사실.

기본적으로 BasicForm은 Ext.form.Action.Submit 인스턴스를 이용하여 ajax 를 통한 submit을 수행하는데
FileUpload 옵션을 사용하는 경우 Ajax submission이 수행되지 않기 때문에 XMLHttpRequests 를 받지 못하게 되기 때문에
발생한 문제....

해결방법은 두가지.
Ext.form.Action.Submit 인스턴스가 아닌 Ext.Ajax.request 로 수행되도록 하던지 (standardSubmit 의 config 옵션을 사용하는 방법은 FileUpload 옵션이 우선되어 적용되지 않는다.)
또다른 방법으로 Hidden 속성인 iFrame을 사용하여 target을 XMLHttpRequests가 아닌 수신받는 XMLHttpRequests를 참조하는별도의 페이지로 지정하면 된다.

예를 들어 result.jsp라는 것을 동적으로 XMLHttpRequests들  수신하게 만들어두고 target을 result.jsp로 지정하면
PRE 태그가 빠진 정상적인 JSON객체를 수신받을 수 있게 된다.

그냥 기존대로 쓸껄 하는 생각이 들지만 머 표현의 가능성은 선택이니..몰랐던 것을 알게된 것으로 만족하자....화이팅~
 
블로그 이미지

시반

시반(詩伴)이란 함께 시를 짓는 벗이란 뜻을 가지고 있습니다. 함께 나눌수 있는 그런 공간이길 바라며...

카테고리

분류 전체보기 (233)
개발 이야기 (73)
WEB2.0 (57)
DB2 (24)
MySQL (6)
오라클 (26)
기타 (44)
취미 (0)
잡담 (2)