zxing라이브러리를 이용하여 큐알코드를 생성해보도록 하겠습니다.
기본 검정색바탕의 코드 생성말고도
추가로 코드의 색상들을 변경하는 기능까지 추가 구현하려 합니다.
먼저 라이브러리를 다운받아야 하겠지요?
https://github.com/zxing/zxing
상단 링크를 들어가셔서 Download ZIP 버튼을 클릭하여 라이브러리를 다운로드 받도록 합니다.
압축해제를 해주시면 다양한 종류의 라이브러리 코드들이 존재하는데
저는 샘플링을 위해 자바프로젝트에서 라이브러리를 이용할 것이므로
code 디렉토리와 javase 디렉토리내에 존재하는
/src/main/java/com 디렉토리를 각각 복사해서
저의 프로젝트 패키지에 적용하였습니다.
웹프로젝트로 진행하실 분들의 경우 저처럼 패키지들을 그대로 복사해서 사용하셔도 무관하나
pom.xml을 이용하시는 프로젝트에서는
<dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.1.0</version> </dependency>
위와같이 pom.xml에 dependency를 추가해주시면 되겠습니다.
샘플 코드는 다음과 같습니다.
public static void main(String ar[]) { try { File file = null; // 큐알이미지를 저장할 디렉토리 지정 file = new File("D:\\qrtest"); if(!file.exists()) { file.mkdirs(); } // 코드인식시 링크걸 URL주소 String codeurl = new String("http://hellogk.tistory.com".getBytes("UTF-8"), "ISO-8859-1"); // 큐알코드 바코드 생상값 int qrcodeColor = 0xFF2e4e96; // 큐알코드 배경색상값 int backgroundColor = 0xFFFFFFFF; QRCodeWriter qrCodeWriter = new QRCodeWriter(); // 3,4번째 parameter값 : width/height값 지정 BitMatrix bitMatrix = qrCodeWriter.encode(codeurl, BarcodeFormat.QR_CODE,200, 200); // MatrixToImageConfig matrixToImageConfig = new MatrixToImageConfig(qrcodeColor,backgroundColor); BufferedImage bufferedImage = MatrixToImageWriter.toBufferedImage(bitMatrix,matrixToImageConfig); // ImageIO를 사용한 바코드 파일쓰기 ImageIO.write(bufferedImage, "png", new File("D:\\qrtest\\qrcode.png")); } catch (Exception e) { e.printStackTrace(); } }
상세설명은 주석에 작성이 되어있으므로 설명은 제외 하도록 하겠습니다.
해당 샘플을 응용하셔서 유틸클래스로 변경후 웹프로젝트에 적용을 하시면 되실거 같네요.
실행한 결과 위처럼 바코드색상이 푸른계열로 만들어 졌습니다.
한번 정상적으로 모바일에서 인식을 하는지 테스트 해보도록 하겠습니다.
결과는 위와같이 바코드 스캐너 앱에서 생성 URL을 인식을 하네요 ㅎㅎ
ZXING는 큐알코드에 색상변경 또한 가능합니다
생상코드값은 안드로이드그래픽색상값을 사용해야 하는거 같네요 ㅎ
찾아보니 색상코드를 찾아주는 사이트가 존재하네요
링크사이트 이동후 검색을 클릭하시면 COLOR PICKER 화면이 뜨는데
원하시는 색상을 클릭하시거나 또는 일반 웹에서 사용되는 #ffffff 컬러색상
또는 red/white와 같은 문자열입력으로 검색이 가능합니다.
검색후 안드로이드그래픽 색상값을 확인하실 수 있습니다.
네이버의 녹색 계열의 배경색 코드를 예를들자면,
#44B316이네요 검색시 맨앞에 #을 제거해도 무관합니다.
RGB,RGBA,RYB,헥스,10진,안드로이드그래픽 칼라색상등
같은 색상을 다양한 코드로 출력을 시켜주네요.
ZXING는 안드로이드 그래픽칼라색상을 이용하니 "0xff44b316" 가 되겠습니다.
기존 샘플링코드 중 qrcodeColor 변수에 적용하여 큐알코드를 출력해보도록 하겠습니다.
큐알코드의 색상이 원하는대로 적용되어 출력되었습니다.
지금까지 zxing라이브러리를 이용하여 큐알코드를 생성해보았습니다 ^^
by 개발로짜
[JAVA 샘플] 트위터 앱생성 + twitter4j를 이용하여 타임라인(Timeline) 목록 출력하기 (3) | 2014.11.20 |
---|---|
JAVA opencsv를 이용하여 csv 파일생성하기 (2) | 2014.10.24 |
자바 다운로드 유틸을 만들어서 웹서버에 등록되있는 파일을 다운로드 하자 (5) | 2014.10.07 |
자바 POI를 이용한 엑셀(xls,xlsx)에 들어있는 데이터들 읽어오기 (8) | 2014.10.07 |
POI라이브러리를 이용하여 엑셀파일(xls,xlsx) 에 데이터 넣어서 파일로 만들기 (1) | 2014.10.07 |
이번 포스팅은 웹서버에 등록되어있는 파일을 다운로드 받아보기위한 코드를 구현하도록 해보겠습니다.
해당 다운로드 코드는 멀티브라우저 지원을합니다.
호환브라우저는 (IE,파이어폭스,오페라,크롬,사파리) 모두 지원이 되는 코드입니다
유틸성 코드는 다음과 같습니다.
public class DownUtil { public void download(HttpServletRequest request ,HttpServletResponse response ,String realfilepath ,String realfilename ,String originalfilename) { String defaultfilepath = request.getSession().getServletContext().getRealPath("/"); //해당 realfilepath 변수에 들어갈 파일경로는 "/경로1/경로2/ << 이런식으로 들어갈경우를 가정 //만약 경로1/경로2 이런식으로 줄경우 if문을 삭제 또는 주석처리 if(realfilepath.length() > 0) { realfilepath = realfilepath.substring(1); } //만약 웹소스 내에 존재하지 않는 파일일 경우 //defaultfilepath + realfilepath 부분을 실제 경로로만 변경해주면 됨 File downloadfile = new File(defaultfilepath + realfilepath + realfilename); if (downloadfile.exists() && downloadfile.isFile()) { response.setContentType("application/octet-stream; charset=utf-8"); response.setContentLength((int) downloadfile.length()); OutputStream outputstream = null; FileInputStream inputstream = null; try { response.setHeader("Content-Disposition", getDisposition(realfilename, check_browser(request))); response.setHeader("Content-Transfer-Encoding", "binary"); outputstream = response.getOutputStream(); inputstream = new FileInputStream(downloadfile); //Spring framework 사용할 경우 //FileCopyUtils.copy(fis, out); //일반 자바/JSP 파일다운로드 byte[] buffer = new byte[1024]; int length = 0; while((length = inputstream.read(buffer)) > 0) { outputstream.write(buffer,0,length); } } catch (Exception e) { e.printStackTrace(); } finally { try { if (inputstream != null){ inputstream.close(); } outputstream.flush(); outputstream.close(); } catch (Exception e2) {} } }else { System.out.println("파일존재하지 않음"); } } private String check_browser(HttpServletRequest request) { String browser = ""; String header = request.getHeader("User-Agent"); //신규추가된 indexof : Trident(IE11) 일반 MSIE로는 체크 안됨 if (header.indexOf("MSIE") > -1 || header.indexOf("Trident") > -1){ browser = "ie"; } //크롬일 경우 else if (header.indexOf("Chrome") > -1){ browser = "chrome"; } //오페라일경우 else if (header.indexOf("Opera") > -1){ browser = "opera"; } //사파리일 경우 else if (header.indexOf("Apple") > -1){ browser = "sarari"; } else { browser = "firfox"; } return browser; } private String getDisposition(String down_filename, String browser_check) throws UnsupportedEncodingException { String prefix = "attachment;filename="; String encodedfilename = null; System.out.println("browser_check:"+browser_check); if (browser_check.equals("ie")) { encodedfilename = URLEncoder.encode(down_filename, "UTF-8").replaceAll("\\+", "%20"); }else if (browser_check.equals("chrome")) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < down_filename.length(); i++){ char c = down_filename.charAt(i); if (c > '~') { sb.append(URLEncoder.encode("" + c, "UTF-8")); } else { sb.append(c); } } encodedfilename = sb.toString(); }else { encodedfilename = "\"" + new String(down_filename.getBytes("UTF-8"), "8859_1") + "\""; } return prefix + encodedfilename; } }
상단 사용은 객체 생성 후 "download" 메서드를 호출하는 것입니다.
우선 웹서버내에 파일이 등록되어있다 가정을 한후 jsp페이지를 호출해보도록 하겠습니다.
위에 이미지를 보시면 DownUtil.java 라는 클래스를 생성하여 상단 코드를 적용하였습니다.
이제 URL : download.jsp를 호출하여 roqkffhwk.xlsx 파일을 다운로드 받도록 해보겠습니다.
JSP 코드는 다음과 같습니다.
DownUtil downutil=new DownUtil(); downutil.download(request, response, "", "roqkffhwk.xlsx", "개발로짜.xlsx");
입력순서를 보시면
첫번째 parameter : request
두번째 parameter : response
세번째 parameter : 웹소스 상의 절대경로(""=웹루트 상단경로)
네번째 parameter : 다운로드받을 실제파일명
다섯번째 parameter : 다운로드후 사용자 pc에 다운로드 받기위한 원본파일명
(실제파일명을 넣어줘도 무관)
실행을 해보도록 해보겠습니다.
상단처럼 정상적으로 다운로드가 완료되었습니다.
하지만 콘솔 확인결과 Exception이 발생되었네요
getOutputStream() has already been called for this response Exception이 발생됐는대요
일반 SpringFrameWork의 경우 controller 같은곳에서 호출이 이루어 지므로 별도의 Exception이 발생되지 않습니다.
JSP페이지 내에서 해당 코드를 작성할 경우 response가 이미 호출되었는데 중복호출(?)로 인한 Exception이 발생하는걸로 알고있습니다.
이를 해결하기 위해서는
DownUtil downutil=new DownUtil();
위코드 바로 상단에
out.clear();
이라는 코드를 추가적으로 작성해주신다면 Exception이 발생되지 않고 정상적으로 파일다운로드가 이루어집니다.
그리고 다운로드 Util 샘플코드에 주석으로 spring용 wrtie코드인
FileCopyUtils.copy(fis, out);
부분을 해제해주시고 기존 byte white 부분을 주석처리 하신 후 사용하시면 되시겠습니다.
그럼 유용하시길...
by 개발로짜
JAVA opencsv를 이용하여 csv 파일생성하기 (2) | 2014.10.24 |
---|---|
자바 zxing를 이용하여 QR코드 생성 + 색상코드(hex,rgb,안드로이드그래픽색상) 적용법 (2) | 2014.10.16 |
자바 POI를 이용한 엑셀(xls,xlsx)에 들어있는 데이터들 읽어오기 (8) | 2014.10.07 |
POI라이브러리를 이용하여 엑셀파일(xls,xlsx) 에 데이터 넣어서 파일로 만들기 (1) | 2014.10.07 |
DTO,VO에 정의되어있는 변수명 및 갯수에 관계없이 변수명과 value값 한방에 가져오기 (0) | 2014.10.07 |
안녕하세요 개발로짜입니다.
지난 포스팅은 데이터들을 엑셀파일로 만드는 작업을 진행했었죠?
이번에는 이전 포스팅에 만든 엑셀파일을 반대로 읽어보는 내용을 진행하도록 하겠습니다.
지난 포스팅에서 만든 엑셀파일에 존재하는 데이터 출력입니다.
2014/10/07 - [코드저장소/java] - POI라이브러리를 이용하여 엑셀파일(xls,xlsx) 에 데이터 넣어서 파일로 만들기
위와 같이 엑셀파일내에 존재하는 내용들입니다.
이 생성된 파일을 콘솔에 각 셀마다 읽어보도록 하겠습니다.
이번에는 버전별 코드를 작성해보도록 하겠습니다.
//파일을 읽기위해 엑셀파일을 가져온다 FileInputStream fis=new FileInputStream("D:\\roqkffhwk.xls"); HSSFWorkbook workbook=new HSSFWorkbook(fis); int rowindex=0; int columnindex=0; //시트 수 (첫번째에만 존재하므로 0을 준다) //만약 각 시트를 읽기위해서는 FOR문을 한번더 돌려준다 HSSFSheet sheet=workbook.getSheetAt(0); //행의 수 int rows=sheet.getPhysicalNumberOfRows(); for(rowindex=1;rowindex<rows;rowindex++){ //행을 읽는다 HSSFRow row=sheet.getRow(rowindex); if(row !=null){ //셀의 수 int cells=row.getPhysicalNumberOfCells(); for(columnindex=0;columnindex<=cells;columnindex++){ //셀값을 읽는다 HSSFCell cell=row.getCell(columnindex); String value=""; //셀이 빈값일경우를 위한 널체크 if(cell==null){ continue; }else{ //타입별로 내용 읽기 switch (cell.getCellType()){ case HSSFCell.CELL_TYPE_FORMULA: value=cell.getCellFormula(); break; case HSSFCell.CELL_TYPE_NUMERIC: value=cell.getNumericCellValue()+""; break; case HSSFCell.CELL_TYPE_STRING: value=cell.getStringCellValue()+""; break; case HSSFCell.CELL_TYPE_BLANK: value=cell.getBooleanCellValue()+""; break; case HSSFCell.CELL_TYPE_ERROR: value=cell.getErrorCellValue()+""; break; } } System.out.println("각 셀 내용 :"+value); } } }
파일을 읽기위해 엑셀파일을 가져온다 FileInputStream fis=new FileInputStream("D:\\roqkffhwk2.xlsx"); XSSFWorkbook workbook=new XSSFWorkbook(fis); int rowindex=0; int columnindex=0; //시트 수 (첫번째에만 존재하므로 0을 준다) //만약 각 시트를 읽기위해서는 FOR문을 한번더 돌려준다 XSSFSheet sheet=workbook.getSheetAt(0); //행의 수 int rows=sheet.getPhysicalNumberOfRows(); for(rowindex=1;rowindex<rows;rowindex++){ //행을읽는다 XSSFRow row=sheet.getRow(rowindex); if(row !=null){ //셀의 수 int cells=row.getPhysicalNumberOfCells(); for(columnindex=0;columnindex<=cells;columnindex++){ //셀값을 읽는다 XSSFCell cell=row.getCell(columnindex); String value=""; //셀이 빈값일경우를 위한 널체크 if(cell==null){ continue; }else{ //타입별로 내용 읽기 switch (cell.getCellType()){ case XSSFCell.CELL_TYPE_FORMULA: value=cell.getCellFormula(); break; case XSSFCell.CELL_TYPE_NUMERIC: value=cell.getNumericCellValue()+""; break; case XSSFCell.CELL_TYPE_STRING: value=cell.getStringCellValue()+""; break; case XSSFCell.CELL_TYPE_BLANK: value=cell.getBooleanCellValue()+""; break; case XSSFCell.CELL_TYPE_ERROR: value=cell.getErrorCellValue()+""; break; } } System.out.println("각 셀 내용 :"+value); } } }
XLS 및 XLSX의 결과는 상단과 모두 동일하게 나올것입니다.
필요한 내용에따라 사용하도록 하세요 ㅎㅎ
by 개발로짜
자바 zxing를 이용하여 QR코드 생성 + 색상코드(hex,rgb,안드로이드그래픽색상) 적용법 (2) | 2014.10.16 |
---|---|
자바 다운로드 유틸을 만들어서 웹서버에 등록되있는 파일을 다운로드 하자 (5) | 2014.10.07 |
POI라이브러리를 이용하여 엑셀파일(xls,xlsx) 에 데이터 넣어서 파일로 만들기 (1) | 2014.10.07 |
DTO,VO에 정의되어있는 변수명 및 갯수에 관계없이 변수명과 value값 한방에 가져오기 (0) | 2014.10.07 |
Map객체의 key값을 읽어서 value값 한번에 추출하기 (0) | 2014.10.07 |