하... 거의 5일만에 포스팅이다..
티스토리 스킨제작을 한다고 시간을 보냈다~~
포스팅 하고싶었으나 하나에 집중하면 다른 하나는 잘 못하는 본인이라. .ㅋ;;
지난시간에는 일정 시간이 될때 특정 메소드(?)를 호출하여 System.out.println을 콘솔창에 출력시키는 것을 확인하였다
이번에는 지난 코드에 이어서 MyBatis까지 연동을 하여 특정 시간에 DB를 조회하는 샘플을 진행
해보도록 하겠다
본인은 SELECT쿼리를 진행 해보도록 하겠음
CRUD 관련은 포스팅 샘플을 기준으로 응용을 하시길...
해당 포스팅의 코드를 기준으로 기본 Mybatis 연동을 해보도록 하자
위와같은 구조로 정의를 하였다
그럼 일정 시간에 CALL 해주는 DB에 대하 DAO 코드 와 쿼리XML 코드를 각각 다음과 같이 정의
해보도록 하자
sql.xml
<select id="testquery" resultType="java.lang.String"> SELECT 'TEST 쿼리' </select>
Dao.java
@Repository public class Dao { @Autowired private SqlSession sql; public String testquery() throws SQLException { return sql.selectOne("sql.testquery"); } }
특정 시간 DB 호출을 위한 Scheduler.java 코드
package com.crontab; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import com.crontab.dao.Dao; @Component public class Scheduler { @Autowired private Dao dao; @Scheduled(cron = "00 45 23 * * *") public void cronTest1(){ try { //일정시간이 되면 DAO를 통하여 DB에 쿼리문 조회 String test = dao.testquery(); System.out.println("DB조회값:"+test); } catch (Exception e) { e.printStackTrace(); } } }
스프링3(spring3) 을 이용하여 간단 스케쥴러 세팅을 하도록 하자 (8) | 2014.09.20 |
---|---|
zxing 라이브러리를 이용하여 QR코드/큐알코드/바코드 이미지를 색상별로 생성해보도록 하자 (0) | 2014.08.29 |
class파일내에서 classpath에 존재하는 리소스 파일읽어오기 (0) | 2014.07.30 |
스프링3(Spring3) - 메이븐(maven) pom.xml에서 오라클 JDBC(ojdbc14.jar) 라이브러리 추가하기 (0) | 2014.07.30 |
스프링3(Spring3) - RedirectAttributes를 이용하여 리다이렉트 POST 방식으로 데이터 전송하기 (0) | 2014.07.30 |
우리는 프로젝트를 진행하면서 스케쥴러(일명 : 크론탭 배치실행) 를 종종 사용할때가 존재한다
보통 어떠한 데이터를 시간이 되면 DB에 insert를 한다던가
혹은 DB정보를 읽어 특정 파일을 생성을 하다던가 등이 존재한다
이러한 경우를 위해 간단하게 샘플을 만들어 보도록 하겠음
이번장은 크론탭 연동만 소개하고 다음 포스팅에는 db연동을 하여
위에 설명한 내용중 하나인 DB내용을 읽어서 파일을 생성하는 내용에 대하여 포스팅 해보도록 하겠다
그럼 세팅을 시작해보도록 하겠음
※ 본인의 포스팅은 STS를 기준으로 작업을 진행하였음
- 프로젝트명 : crontab
- spring version : 3.2.3
생성후 프로젝트 우클릭후 Maven -> Update Project를 해주는거 잊지말자
Tomcat에 생성한 프로젝트를 Add를 해준다음 크론탭 연동을 진행하도록 하겠음
※ 기존 웹프로젝트의 경우는 ContextRoot 설정을 기본으로 잡아주었지만
스케쥴러는 별도의 컨텍스트 설정이 필요없다
위와같이 기본설정이 mvc-config.xml이 잡혀있을텐데 beans 태그를 다음과 같이 변경해주자
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xmlns:task="http://www.springframework.org/schema/task" xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.1.xsd">
이어 beans 태그내에 다음 코드를 추가하자
<!-- 스케쥴러파일이 존재하는 패키지 설정 --> <context:component-scan base-package="com.crontab" /> <!-- 해당 태그들은 크론탭을 설정에 필요한 태그들 --> <task:scheduler id="jobScheduler" pool-size="10" /> <task:annotation-driven scheduler="jobScheduler" />
위 설정을 잡아다면 다음으로 xml설정 잡은 것처럼 패키지 생성을 하도록 하자
위 구조로 잡아주었다
crontab내에 여러개의 클래스를 잡아서 설정을 잡아 줄수도 있다
but, 본인은 하나의 클래스로만 작업을 ...
이제는 스케쥴러를 돌리기위한 코드를 작성하자
package com.crontab; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component public class Scheduler { /** * 1. 오후 05:50:00에 호출이 되는 스케쥴러 */ @Scheduled(cron = "0 50 17 * * *") public void cronTest1(){ System.out.println("오후 05:50:00에 호출이 됩니다 "); } /** * 2. 오후 05:51:00에 호출이 되는 스케쥴러 */ @Scheduled(cron = "0 51 17 * * *") public void cronTest2(){ System.out.println("오후 05:51:00에 호출이 됩니다 "); } }
위의 설정한 cron expression은 본인의 현재 시간에대 맞추어 테스트 해보도록 하자
본인은 현재 포스팅 시간대 기준으로 작업을 해본 것이다
예를들어 위 코드에서
"0 51 17 * * *"
라는 코드를 작성하였는데
앞에서부터 설명하자면
"초 분 시 일 월 요일"
이라는 것이다
'*' 이라는 expression은 모두 또는 항상을 의미한다
즉 상단 expression을 설명하면
17시 51분이 되면 해당 스케쥴러 호출이라는 의미다.
일/월/요일에 대해서는 '*' 설정을 잡아 주었으니 "매일 17시 51분이 되면 해당 스케쥴러를 호출하라"
라는 의미가 되는것이다
실행화면을 보도록 하자
상단 코드 작성후 tomcat start를 하고 기다리고 있었다
동작결과 정상적으로 코드 작성한 놈들이 특정 시간에 따라 호출이 정상적으로 되었다
다음 포스팅에는 DB연동을 하여 파일 생성하는 스케쥴러 제작을 진행하겠다
1. 지속적인 구독을 원하신다면 네이버 이웃추가 부탁드립니다
2. 도움이 되셨다면 공감한번 꾹! 눌러주세요
3. 궁금하신점이 있으시다면 댓글 GOGO
스프링3(spring3) 을 이용하면서 쿼츠/배치/스케쥴러 연동하기 -DB연동 (4) | 2014.09.28 |
---|---|
zxing 라이브러리를 이용하여 QR코드/큐알코드/바코드 이미지를 색상별로 생성해보도록 하자 (0) | 2014.08.29 |
class파일내에서 classpath에 존재하는 리소스 파일읽어오기 (0) | 2014.07.30 |
스프링3(Spring3) - 메이븐(maven) pom.xml에서 오라클 JDBC(ojdbc14.jar) 라이브러리 추가하기 (0) | 2014.07.30 |
스프링3(Spring3) - RedirectAttributes를 이용하여 리다이렉트 POST 방식으로 데이터 전송하기 (0) | 2014.07.30 |
요즘 모바일이 활성화되면서 사용되는 출력물 중 하나라고 생각되어서 포스팅 하게 되었다.
zxing 라이브러리를 이용하여 QR코드/큐알코드/바코드 이미지를 생성하고자 한다.
이번포스팅은 무척 심플하다
1. pom.xml dependency 추가를 해주도록 하자
<dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.1.0</version> </dependency>
2. QR코드 유틸제작
유틸이라고 하기엔 그렇고 그냥 만들어보았음
클래스명을 QRUtil라고 주고 생성메서드를 makeQR이라고 만들어봄
import java.awt.image.BufferedImage; import java.io.File; import javax.imageio.ImageIO; import com.google.zxing.BarcodeFormat; import com.google.zxing.client.j2se.MatrixToImageConfig; import com.google.zxing.client.j2se.MatrixToImageWriter; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; public class QRUtil { /** * QR코드 유틸 * @param url : QR에 작성할 URL이다 * @param width : QR 이미지 가로사이즈 * @param height : QR 이미지 세로사이즈 * @param file_path : 생성할파일의 디렉토리경로 * @param file_name : 생성할 파일의 파일명 */ public static void makeQR(String url,int width, int height, String file_path, String file_name){ try { File file = null; file = new File(file_path); if(!file.exists()) { file.mkdirs(); } QRCodeWriter writer = new QRCodeWriter(); url = new String(url.getBytes("UTF-8"), "ISO-8859-1"); BitMatrix matrix = writer.encode(url, BarcodeFormat.QR_CODE,width, height); //QR코드 색상 int qrColor = 0xFF2e4e96; MatrixToImageConfig config = new MatrixToImageConfig(qrColor,0xFFFFFFFF); BufferedImage qrImage = MatrixToImageWriter.toBufferedImage(matrix,config); ImageIO.write(qrImage, "png", new File(file_path+file_name)); } catch (Exception e) { e.printStackTrace(); } } }
3. QR 생성테스트를 위한 임의의 컨트롤러 호출
꼭 컨트롤러가 아니여도 상관없다 핵심은 QRUtil에 들어있는 makeQR이 핵심임
@RequestMapping(value="/makeqr") public void makeqr() throws WriterException, IOException { String url = "http://roqkffhwk.tistory.com"; int width = 50; int height = 50; String file_path = "D:"+File.separator+"qr"+File.separator; String file_name = "myblog.png"; QRUtil.makeQR(url, width, height, file_path, file_name); }
실행결과 브라우저에는 오류페이지만 뜨겠고, 우리가 여기서 확인해야 할 부분은
지정한 디렉토리 + 파일로 정상적으로 QR코드가 생성되었는지가 핵심이다.
※ 참고로 본인은 int qrColor 변수의 값을 변경하면서 다양한 색상으로 생성을 해보았다.
색상코드값 |
결과화면 |
0xFF2d64e9 |
|
0xFF2e4e96 |
|
0xFF106f63 |
|
0xFF766c15 |
|
0xFF004555 |
|
0xFF557615 |
|
0xFF764515 |
|
0xFFad1004 |
|
0xFFbd4700 |
|
위와같이 다양한 색깔로 잘 나왔다. 잘 사용하시길 ^^
1. 지속적인 구독을 원하신다면 네이버 이웃추가 부탁드립니다
2. 도움이 되셨다면 공감한번 꾹! 눌러주세요
3. 궁금하신점이 있으시다면 댓글 GOGO
스프링3(spring3) 을 이용하면서 쿼츠/배치/스케쥴러 연동하기 -DB연동 (4) | 2014.09.28 |
---|---|
스프링3(spring3) 을 이용하여 간단 스케쥴러 세팅을 하도록 하자 (8) | 2014.09.20 |
class파일내에서 classpath에 존재하는 리소스 파일읽어오기 (0) | 2014.07.30 |
스프링3(Spring3) - 메이븐(maven) pom.xml에서 오라클 JDBC(ojdbc14.jar) 라이브러리 추가하기 (0) | 2014.07.30 |
스프링3(Spring3) - RedirectAttributes를 이용하여 리다이렉트 POST 방식으로 데이터 전송하기 (0) | 2014.07.30 |
특정 xml파일이나 txt파일 등과 같은 리소스 파일들을 class부분에서 읽어와야 하는 일이 존재
하였다.
기존에는 D:\abc\ddd.txt 형식처럼 외부에 파일을 위치시키고 properties 파일에 경로를 지정한후 파일을 읽어왔는데 너무 번거롭다.
그래서 해결책을 찾아본 결과 spring에서는
import org.springframework.core.io.ClassPathResource; import org.springframework.core.io.Resource;
위 클래스를 이용하여 classpath안에 존재하는 파일의 정보를 가지고 올 수 있었다.
실행방법은 이렇다. 다음과 같은 임의의 파일을 calsspath 영역내에 위치 시키자.
본인은 test.txt라는 파일을 classpath에 위치시킴
그리고 다음과 같이 샘플구현을 하여 파일정보일부를 확인해 보았음
Resource resource = new ClassPathResource("test.txt"); System.out.println("파일사이즈::"+resource.getFile().length()); System.out.println("파일절대경로+파일명:"+resource.getURI().getPath().substring(1));
실행결과 콘솔내용
다음과같은 내용이 콘솔에 찍혔다.
그외의 작업들도 많은대 나머지는 여러분들의 몫~
도움이 되셨다면 공감클릭! 궁금하신점은 댓글!!
스프링3(spring3) 을 이용하여 간단 스케쥴러 세팅을 하도록 하자 (8) | 2014.09.20 |
---|---|
zxing 라이브러리를 이용하여 QR코드/큐알코드/바코드 이미지를 색상별로 생성해보도록 하자 (0) | 2014.08.29 |
스프링3(Spring3) - 메이븐(maven) pom.xml에서 오라클 JDBC(ojdbc14.jar) 라이브러리 추가하기 (0) | 2014.07.30 |
스프링3(Spring3) - RedirectAttributes를 이용하여 리다이렉트 POST 방식으로 데이터 전송하기 (0) | 2014.07.30 |
스프링3(Spring3) - @ResponseBody + jackson을 이용하여 심플하게 JSON 구현하기 (0) | 2014.07.30 |
maven repository에서 ojdbc 검색을 해서 dependency를 추가해주었는데
Missing artifact ojdbc:ojdbc:jar:14 라는 오류발생
삽입했던 dependency
<dependency> <groupId>ojdbc</groupId> <artifactId>ojdbc</artifactId> <version>14</version> </dependency>
뭘까 하다 확인해보니 다음과같이 해주어야 하더라
<dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc14</artifactId> <version>10.2.0.4.0</version> </dependency>
기존 dependency를 위와같이 변경해주고 repositories태그를 추가해주어야 함
pom.xml에 repositories 태그가 존재하지 않는다면 그냥 properties 태그위에 다음과 같이 작성
해주도록 하자
<repositories> <repository> <id>mesir-repo</id> <url>http://mesir.googlecode.com/svn/trunk/mavenrepo</url> </repository> </repositories>
위와 같이 변경하였다면 정상적으로 ojdbc14.jar 라이브러리가 정상적으로 추가된것을
확인할 수 있을 것이다.
다음에는 mssql 라이브러리를 추가하는법을 포스팅 하도록 하겠음!!
도움이 되셨다면 공감클릭! 궁금하신점은 댓글!!
zxing 라이브러리를 이용하여 QR코드/큐알코드/바코드 이미지를 색상별로 생성해보도록 하자 (0) | 2014.08.29 |
---|---|
class파일내에서 classpath에 존재하는 리소스 파일읽어오기 (0) | 2014.07.30 |
스프링3(Spring3) - RedirectAttributes를 이용하여 리다이렉트 POST 방식으로 데이터 전송하기 (0) | 2014.07.30 |
스프링3(Spring3) - @ResponseBody + jackson을 이용하여 심플하게 JSON 구현하기 (0) | 2014.07.30 |
스프링3(Spring3) - 인터셉터(interceptor) 설정 (4) | 2014.07.28 |