문서뷰어(FileOpener) 가이드 프로그램은 디바이스 API 실행환경을 활용하여 하이브리드 앱을 개발 시 참고 및 활용될 수 있도록 구현된 전자정부 디바이스 API에 대한 가이드 앱으로써, 모바일 스마트 디바이스의 FileOpener관련 기능을 JavaScript기반으로 구성 된 FileOpener DeviceAPI를 통하여 다운받은 문서를 볼수 있도록 내장 앱으로 연동하는 기능을 지원한다.
또한, 전자정부 표준프레임워크 기반의 웹 서버 어플리케이션과 연계하여 문서 목록 및 해당 문서를 다운받을 수 있는 조회 및 다운로드 기능으로 구성되어 있다.
본 가이드 프로그램에서는 웹 서버에서 문서 목록 및 해당 파일 다운로드 기능의 활용을 가이드 할 수 있도록 문서목록 조회, 문서뷰어로 열기(다운로드포함)
기능을 제공하고 있다.
구분 | 내용 |
Local 디바이스 개발 환경 | Xcode 8.0 (8A218a), Cordova 6.4.0 |
서버 사이드 개발 환경 | 전자정부표준프레임워크 개발환경3.6 |
Mash up Open API 연계 | N/A |
테스트 디바이스 | iPhone 6 , iPad Air |
테스트 플랫폼 | iOS 9.3, iOS 10.0 |
추가 라이브러리 적용 | N/A |
구분 | 내용 |
지원 디바이스 및 플랫폼 | N/A |
크로스 도메인 사용 | 폰갭에서 특정 외부 도메인이나 외부 도메인의 하위 도메인을 사용해야할 경우,
Res/xml/config.xml에서 <access origin=”” />에 외부 도메인 주소를 추가 설정해야 외부 도메인에 접속할 수 있다. |
라이선스 | N/A |
문서뷰어(FileOpener) 디바이스API 가이드 프로그램는 문서목록 조회, 문서 목록, 그리고 문서 클릭 시 문서열람 기능으로 구성되어 있다.(관련기능 부분참조)
유형 | 대상소스명 | 비고 |
CSS | assets/www/css/egovframwork/mbl/hyb/FileOpener.css | 문서뷰어 API 가이드 프로그램 주요 Cascading Style Sheets |
IMAGE | assets/www/images/egovframwork/mbl/hyb/ | 문서뷰어 API 가이드 프로그램 주요 Image 폴더 |
JS | assets/www/js/egovframwork/mbl/hyb/FileOpener.js | 문서뷰어 API 가이드 프로그램 주요 JavaScript |
HTML | assets/www/FileOpener.html | 문서뷰어 API 메인 페이지 |
HTML | assets/www/intro.html | 문서뷰어 API Intro 페이지 |
HTML | assets/www/license.html | 문서뷰어 API 라이센스 페이지 |
HTML | assets/www/overview.html | 문서뷰어 API 기능설명 페이지 |
RES | [Project_Name]/Resources/ | 문서뷰어 API 가이드 프로그램 주요 Resource 폴더 |
PLIST | [Project_Name]/Resources/[Project_Name]-Info.plist | iOS 어플리케이션 설정 파일 |
window.plugins.EgovInterface.request(url, params, onSuccess);
파라미터 | 설명 | 비고 |
url | 웹서버로 요청 할 URI | 서버 URL 설정은 환경설정 참조 |
parames | 입력 파라미터 | json Object 타입으로 입력 |
onSuccess | POST Method에 대한 성공시 리턴되는 함수 | json타입 데이터 처리 |
window.plugins.EgovFileOpener.fileDownload(url, params, onSuccess);
파라미터 | 설명 | 비고 |
url | 웹서버로 요청 할 URI | 서버 URL 설정은 환경설정 참조 |
parames | 입력 파라미터 | json Object 타입으로 입력 |
onSuccess | POST Method에 대한 성공시 리턴되는 함수 | json타입 데이터 처리 |
cordova.plugins.fileOpener2.open(filePath, fileMINEType, {error:function(){}, success:function(){}} );
파라미터 | 설명 | 비고 |
filePath | 디바이스 파일 경로 | 디바이스 내 파일 저장경로 |
fileMINEType | 파일의 마이타입 지정 | 예) PDF 파일 (application/pdf) * MINE TYPE |
{error: onError(), success: onSuccess()} | 합수에 대한 성공/실패의 콜백 함수 | |
유형 | 대상소스명 | 비고 |
Controller | egovframework.hyb.mbl.fop.web.EgovFileOpenerDeviceAPIController.java | 문서뷰어 API 가이드 프로그램 Controller Class |
Service | egovframework.hyb.mbl.fop.service.EgovFileOpenerDeviceAPIService.java | 문서뷰어 API 가이드 프로그램 Service Class |
ServiceImpl | egovframework.hyb.mbl.fop.service.impl.EgovFileOpenerDeviceAPIServiceImpl.java | 문서뷰어 API 가이드 프로그램 ServiceImpl Class |
VO | egovframework.hyb.mbl.fop.service.FileOpenerDeviceAPIVO.java | 문서뷰어 API 가이드 프로그램 VO Class |
DAO | egovframework.hyb.mbl.fop.service.impl.FileOpenerDeviceAPIDAO.java | 문서뷰어 API 가이드 프로그램 Dao Class |
QUERY XML | resources/egovframework/sqlmap/hyb/mbl/fop/EgovFileOpenerDeviceAPIGuide_SQL_xxx.xml | 문서뷰어 API 가이드 프로그램 QUERY XML |
테이블명 | 테이블명(영문) | 비고 |
문서목록 | file_opener_list | 문서 목록의 리스트 정보 |
파일상세정보 | file_detail_info | 파일의 상세정보 |
No | 컬럼ID | 컬럼명 | 타입 | 길이 | NULL | KEY |
1 | SN | 일련번호 | NUMERIC | 6 | NotNull | pk |
2 | USE_YN | 사용유무 | VARCHAR | 1 | Null | |
3 | UPD_DT | 업데이트날짜 | datetime | | Null | |
4 | FILE_SN | 파일상세정보 테이블의 일련번호 | NUMERIC | 20 | Null | fk |
No. | 컬럼 | 컬럼명 | 타입 | 길이 | Null | KEY |
1 | FILE_SN | 파일연번 | NUMERIC | 20 | NotNull | pk |
2 | FILE_STRE_COURS | 파일저장경로 | VARCHAR | 2000 | Null | |
3 | STRE_FILE_NM | 저장파일명 | VARCHAR | 255 | Null | pk |
4 | ORIGNL_FILE_NM | 원파일명 | VARCHAR | 255 | Null | |
5 | FILE_EXTSN | 파일확장자 | VARCHAR | 20 | Null | |
6 | FILE_CN | 파일내용 | BLOB | | Null | |
7 | FILE_SIZE | 파일크기 | NUMERIC | 8 | Null | |
문서뷰어(FileOpener) 디바이스API 가이드 프로그램에서 제공하는 문서목록 조회, 파일다운로드, 문서뷰어 연동을 위한 기능을 활용하기 위하여 필요한 항목 및 그 환경 설정은 다음과 같다.
<feature name="EgovFileOpener">
<param name="ios-package" value="EgovFileOpener" />
</feature>
<feature name="EgovZip">
<param name="ios-package" value="EgovZip" />
</feature>
<feature name="FileOpener2">
<param name="ios-package" value="FileOpener2" />
</feature>
#define kSERVER_URL @"Server_URL"
<sqlMap resource="egovframework/sqlmap/hyb/mbl/fop/EgovFileOpenerDeviceAPIGuide_SQL_[DB명].xml"/>
문서뷰어(FileOpener) API 가이드 프로그램은 웹서버 문서목록을 조회하여 해당 파일을 다운로드 후 디바이스 내 문서뷰어와 연동으 할 수 있는 기능으로 구성되어 있다.
function fn_egov_documentlist() {
var url = "/fop/FileOpenerDocumentList.do";
var accept_type = "xml";
var params = {};
window.plugins.EgovInterface.request(url, params, function(jsondata) {
resultJson = jsondata;
if(resultJson.resultState == "OK"){
var strhtml="";
$(resultJson.resultSet).each(function(){
var sn = this.sn;
var orignlFileNm = this.orignlFileNm;
var streFileNm = this.streFileNm;
var fileSize = this.fileSize;
var updDt = this.updDt;
fileorignlFileNm = this.orignlFileNm;
strhtml += '<li>';
strhtml += ' <a href="#" onclick="javascript:fn_egov_filelist_go(\'' + sn + ';'+ orignlFileNm + ';'+ streFileNm +'\')">';
strhtml += ' <h3>파일명: ' + orignlFileNm + '</h3>';
strhtml += ' <h3>파일크기: ' + fileSize + '</h3>';
strhtml += ' <h3>등록일: ' + updDt + '</h3>';
strhtml += ' </a>';
strhtml += '</li>';
});
var theList = $('#theList');
theList.html(strhtml);
$.mobile.changePage("#documentInfo", "slide", false, false);
theList.listview("refresh");
infoScroll.refresh();
}else{
$("#alert_dialog").click( function() {
jAlert('데이터 전송 중 오류가 발생 했습니다.', '전송 오류', 'c');
});
}
}, function(result){
alert("error > "+result);
});
}
문서목록 조회 화면 | 목록 상세화면 |
| |
[참고] 문서 종류에 따라 내장된 문서뷰어는 별도로 설치되어야 한다.
예) 문서가 PDF일 경우 PDF용 뷰어가 별도로 설치되어 있어야 한다.(Adobe Reader)
function fn_egov_fileDownload(input){
var url = "/fop/FileOpenerfileDownload.do";
var inputArray = input.split(";");
var inputTargetPath = cordova.file.externalDataDirectory;
var params = {sn : inputArray[0], orignlFileNm : inputArray[1], streFileNm : inputArray[2], targetPath : inputTargetPath};
var fileExt = inputArray[2].split(".");
var fileMINEType = "application/" + fileExt[fileExt.length-1];
console.log('File Download Start ');
console.log('>> inputTargetPath : ' + inputTargetPath);
console.log('>> fileMINEType : ' + fileMINEType);
window.plugins.EgovFileOpener.fileDownload(url, params, function(jsondata) {
jsonresult = jsondata;
console.log("jsondata > "+jsondata);
console.log('File Open Start ');
cordova.plugins.fileOpener2.open(
inputTargetPath + inputArray[1],
fileMINEType,
{
error : function(e) {
console.log('Error status: ' + e.status + ' - Error message: ' + e.message);
if(e.status == "9")
alert('문서를 실행할 수 있는 뷰어가 설치되어 있지 않습니다.');
},
success : function () {
console.log('file opened successfully');
}
}
);
}, function(result){
alert("error > "+result);
});
}
문서뷰어 연동 확인 화면 | 문서뷰어 연동(PDF) 화면 |
| |
문서에 맞는 연동 앱이 없는 경우 화면 |
|
디바이스 어플리케이션에서 발생한 오류 내용 확인 및 디버깅을 위해서는 폰갭 프레임워크에서 제공하는 console.log를 이용할 수 있다. console.log 함수는 자바스크립트 구문에서 사용할 수 있는 디버그 코드로 이클립스 및 Xcode에서 확인 할 수 있다.
function fn_egov_network_check(doCheck)
{
console.log('DeviceAPIGuide fn_egov_network_check');
var networkState = navigator.network.connection.type;
...
}
문서뷰어(FileOpener) 디바이스 API 가이드 다운로드 : Click
-
UX/UI 라이브러리 : jQuery Mobile
Click
Cordova 플러그인 정보 : cordova-plugin-file-opener2
Click