$.ajaxFileUpload({
url:"http://192.168.0.222:8080/Erp_V0.1/admin/upload/uploader.php", //이미지 처리를 위한 스크립트 경로
유형: '게시물', //제출 방법
데이터: upload_arr,//맞춤 매개변수
secureuri:false, //보안 제출 활성화 여부
fileElementId:id, //파일 제어 ID
dataType: "jsonp",//데이터 유형은 jsonp입니다.
jsonp: "jsonpCallback",//서버는 콜백 호출의 함수 이름 매개변수를 수신하는 데 사용됩니다.
성공: 함수(데이터){ //제출 성공 후 자동으로 실행되는 처리 함수
경고(1111);
경고(데이터);
},
오류:함수(데이터,상태,e){
경고(2222);
경고(e);
경고(JSON.stringify(data));
경고(상태);
}
})
jsonp 크로스 도메인은 get 모드만 지원합니다. 프런트엔드가 post 모드로 설정되어 있어도 자동으로 get 모드로 변환됩니다.
으아악jsonp의 구현 방법은 ajax의 jsonp가 이를 캡슐화한다는 점을 제외하면 실제로 스크립트 요청 주소와 동일합니다. jsonp는 POST 방법을 지원하지 않습니다. 따라서 서버측 코드가 post 메소드를 사용하는 경우에는 요청할 수 없습니다.
물론 크로스도메인 통신을 위해 억지로 포스트 방식을 사용하게 된다면 할 수 있는 일이 없습니다.
클라이언트 측 변경:
``
추가: crossDomain: true
수정: dataType: "json"
``
서버 측 추가:
할 수는 있지만 단점도 있고 요청 시간이 상대적으로 길다는 점은 직접 판단해보시면 좋을 것 같습니다.
마지막으로 Stackoverflow에 관련 질문 게시물을 첨부하세요:
http://stackoverflow.com/ques...
도메인 전반에 걸쳐 Get for Jsonp를 사용한 기억이 납니다. .근데 굳이 포스팅을 하라고 하면 http://www.jb51.net/article/6...이 있는데 해보지는 않았습니다.
먼저 크로스 도메인과 jsonp 관련 지식을 정리해보겠습니다
jsonp는 스크립트 태그로 만들어집니다
글이 크로스 도메인일 경우 백엔드에 Access-Control-Allow-Origin을 추가해야 합니다