• 분류 전체보기 (160)
    • 개인프로젝트 (5)
      • 시연영상모음 (4)
      • 주저리주저리.. (1)
    • 자바스크립트이야기 (69)
      • ExtJS (30)
      • ExtJS 유의사항 (3)
      • HTML5 (1)
      • jQuery (17)
      • jQuery플러그인소개 (9)
      • jQuery UI 소개 (9)
    • 스프링연동하기 (23)
      • spring3 mvc 설정 (4)
      • spring3 mybatis 설정 (4)
      • spring3 기타설정 (11)
      • ibatis and mybatis (4)
    • DB (26)
      • MySQL vs MS-SQL vs O.. (5)
      • MySQL (10)
      • MSSQL (5)
      • Oracle (6)
    • 서버에웹환경구축하기 (13)
      • 1.VirtualBox+CentOS .. (5)
      • 2.JAVA(JDK) 설치 (1)
      • 3.Apache+Tomcat 설치 (3)
      • 4,SVN Server 설치 (1)
      • 5.마리아DB(MariaDB) 설치 (2)
      • 6.몽고DB(MongoDB)설치 (1)
    • 샘플소스 (14)
      • 샘플소스(JAVA) (7)
      • 샘플소스(JSTL) (4)
      • 샘플소스(jQuery/스크립트) (3)
    • 에디터연동 (5)
      • NAVER-스마트에디터 (4)
      • DAUM-다음에디터 (1)
    • 블로그팁 (3)
    • 디지털이야기 (2)
댓글
스프링연동하기/spring3 기타설정
11
/209
2014. 9. 28. 23:51
스프링3(spring3) 을 이용하면서 쿼츠/배치/스케쥴러 연동하기 -DB연동

하... 거의 5일만에 포스팅이다.. 슬퍼3

티스토리 스킨제작을 한다고 시간을 보냈다~~ 

포스팅 하고싶었으나 하나에 집중하면 다른 하나는 잘 못하는 본인이라. .ㅋ;;


지난시간에는 일정 시간이 될때 특정 메소드(?)를 호출하여 System.out.println을 콘솔창에 출력시키는 것을 확인하였다


이번에는 지난 코드에 이어서 MyBatis까지 연동을 하여 특정 시간에 DB를 조회하는 샘플을 진행

해보도록 하겠다



2014/09/20 - [스프링연동하기/spring3 기타설정] - 스프링3(spring3) 을 이용하여 간단 스케쥴러 세팅을 하도록 하자



본인은 SELECT쿼리를 진행 해보도록 하겠음

CRUD 관련은 포스팅 샘플을 기준으로 응용을 하시길...



2014/07/23 - [스프링연동하기/spring3 mybatis 설정] - 스프링3(Spring3) - mybatis 연동(1)



해당 포스팅의 코드를 기준으로 기본 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();
		}
	}
}



저작자표시 비영리 변경금지 (새창열림)

'스프링연동하기 > spring3 기타설정' 카테고리의 다른 글

스프링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
/201
2014. 9. 20. 18:07
스프링3(spring3) 을 이용하여 간단 스케쥴러 세팅을 하도록 하자

우리는 프로젝트를 진행하면서 스케쥴러(일명 : 크론탭 배치실행) 를 종종 사용할때가 존재한다

보통 어떠한 데이터를 시간이 되면 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 


Bye



저작자표시 비영리 변경금지 (새창열림)

'스프링연동하기 > spring3 기타설정' 카테고리의 다른 글

스프링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
/173
2014. 8. 29. 15:01
zxing 라이브러리를 이용하여 QR코드/큐알코드/바코드 이미지를 색상별로 생성해보도록 하자

요즘 모바일이 활성화되면서 사용되는 출력물 중 하나라고 생각되어서 포스팅 하게 되었다.

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 


Bye



저작자표시 비영리 변경금지 (새창열림)

'스프링연동하기 > spring3 기타설정' 카테고리의 다른 글

스프링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
/124
2014. 7. 30. 18:25
class파일내에서 classpath에 존재하는 리소스 파일읽어오기

특정 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));

실행결과 콘솔내용




다음과같은 내용이 콘솔에 찍혔다. 

그외의 작업들도 많은대 나머지는 여러분들의 몫~



슈퍼맨슈퍼맨슈퍼맨



도움이 되셨다면 공감클릭! 궁금하신점은 댓글!!

저작자표시 (새창열림)

'스프링연동하기 > spring3 기타설정' 카테고리의 다른 글

스프링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
/123
2014. 7. 30. 16:10
스프링3(Spring3) - 메이븐(maven) pom.xml에서 오라클 JDBC(ojdbc14.jar) 라이브러리 추가하기

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 라이브러리를 추가하는법을 포스팅 하도록 하겠음!!




슈퍼맨슈퍼맨슈퍼맨



도움이 되셨다면 공감클릭! 궁금하신점은 댓글!!

저작자표시 (새창열림)

'스프링연동하기 > spring3 기타설정' 카테고리의 다른 글

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
이전 1 2 3 다음

티스토리툴바