'분류 전체보기'에 해당되는 글 223건

  1. 2011.10.25 mybatis Oracle Procedure 호출하기
  2. 2011.10.24 모바일 페이지 작성시 가로,세로 모드에 따라 다른 css 파일 적용시키기
  3. 2011.10.24 네이버에서 제공해주는 PPT, DOC, HWP 서식(Template) 받자~ 1
  4. 2011.10.23 Sonatype Nexus #2 : 설정 및 maven 과 연결하기 4
  5. 2011.10.23 Sonatype Nexus #1 : 톰캣에 설치하기

mybatis Oracle Procedure 호출하기


개인적으로 getter, setter 클래스를 만드는걸 싫어함으로 그냥 map, list 로 결과를 받는 예제를 맹글어 보겠다.

대충 요렇게 선언된 PROCEDURE_NAME 이라는 프로시져가 있다고 가정하면~
CREATE OR REPLACE PROCEDURE PROCEDURE_NAME
(
	c_resurt OUT P_OUT_CURSOR.CURSORTYPE,
	v_year  in   varchar2,
	v_term  in   varchar2,
	v_no    in   varchar2
)
AS ....

요 프로시져를 호출하는 mapper xml 파일은 요렇다.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="test">
	<resultMap id="test" type="hashmap"></resultMap>
	
	<select id="test" statementType="CALLABLE">
		{ 
			CALL PROCEDURE_NAME(
				#{result, mode=OUT, jdbcType=CURSOR, javaType=ResultSet, resultMap=test},
				#{year},
				#{term},
				#{no}
			)
		}
	</select>
</mapper>

요기에서 보면 꼭 해줘야 될게

1. resultMap 을 hashmap 타입으로 하나 선언해 줘야 한다. (※ id 는 다른 xml 파일에 있는 resultMap id 와 중복되면 안된다.)

2. select 엘리먼트의 statementType 을 CALLABLE 로 설정해 줘야됨.

3. 프로시져 파라메터중 IN 타입은 잡다구리한거 설정할 필요가 없지만, OUT 타입은 위와 같이 선언해 주고 resultMap 에는 위에서 설정한 resultMap의 id를 적어줘야 한다.

요 세가지만 주의하면 mapper xml 작성은 끝~




다음으로 죠걸 호출하는 java 소스 부분이다. 편의상, 테스트 한다고 작성했던 Spring Controller 를 그대로 옮겨 적겠다. 다른데서 호출하는것도 호출방식은 다 똑같으니까 잘 땡겨다 쓸 수 있을것이라 생각한다.
package controller;

import java.util.HashMap;
import java.util.Map;

import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class Test {
	
	@Autowired SqlSessionTemplate oracle;
	
	@RequestMapping("/test")
	public void test(ModelMap model){
		// 파라메터 셋팅
		Map param = new HashMap();
		param.put("year", "2010");
		param.put("term", "xxx");
		param.put("no", "1234");
		
		// 프로시져 호출
		oracle.selectOne("test.test", param);

		// 결과보기
		System.out.println(param);
		
		// 파라메터로 넘겨준 HashMap 에 
		// mapper xml 에서 호출할때 선언했던 #{result, mode=OUT, ~~} 
		// 요부분의 result 라는 key로 결과를 담아준다.
		// #{output, mode=OUT, ~~} 이라고 했으면 param.get("output") 으로 받으면 된다.
		model.put("result", param.get("result"));
	}
}

대충보면 알겠지만 보통 쿼리인 경우는 selectOne() 메소드의 호출결과로 쿼리결과를 리턴받지만

프로시져에서 OUT 타입 변수로 결과를 리턴할 경우 selectOne() 의 결과로 아무것도 리턴되지 않는다.

대신 호출할때 넘겨준 파라메터에 결과를 담아서 넘겨준다 -_-;



그래서 리스트로 결과를 받기 위해서 굳이 selectList 로 호출을 안해도 되고 그냥 selectOne 만 쓰면된다.

쿼리 결과가 list 인 경우 위 예제같은 경우 result 에 ArrayList 안에 HashMap 들이 들어가 있는 형태로 결과를 넣어준다.





모바일 페이지 작성시 가로,세로 모드에 따라 다른 css 파일 적용시키기

모바일 웹페이지 작성시 가로로 볼때와 세로로 볼때 처럼 보여지는 방향에 따라 문서에 다른 css 파일을 적용시키고 싶은 경우가 있다.

고럴때는 다음과 같이 처리하면 깔쌈하게 해결이 가능하다.



※ 아이패드2와 안드로이드폰에서 테스트 해봤는데 훅훅 화면이 돌아갈때 마다 다른 css 파일로 적용이 잘된다. 
※ pc 에서 해당 페이지를 로딩할 경우 기본적으로  가로모드 css 파일이 적용된다.


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 
Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
	<title>CSS Orientation Test</title>

	<!-- 세로모드일때 적용될 CSS -->
	<link rel="stylesheet" media="all and (orientation: portrait)" href="portrait.css" />
	
	<!-- 가로모드일때 적용될 CSS -->
	<link rel="stylesheet" media="all and (orientation: landscape)" href="landscape.css" />
</head>
<body>
	<p>방향 테스트</p>
	<div id="cont">
		가가가가가가가가가가가가가가가가가
		나나나나나나나나나나나나나나나나나
	</div>
</body>
</html>



portrait.css
body{background-color: black;}
p{font-size: 20pt;color: white;}
#cont{width:900px;border:1px solid #ddd;}


landscape.css
body{background-color: red;}
p{font-size: 20pt;}
#cont{width:200px;border:1px solid #ccc;}




네이버에서 제공해주는 PPT, DOC, HWP 서식(Template) 받자~

네이버에서 깔쌈한 몇가지 문서 템플릿을 다운로드 받을 수 있도록 공개했다.

파워포인트, MS WORD, 한글 템플릿 파일을 받을 수 있다.

깔끔한 템플릿들이 몇개 있으니 받아 뒀다가 낸중에 활용하면 될것 같다~ 




다운로드 받는 사이트 주소 :  http://hangeul.naver.com/document

※ 네이버에서 무료로 제공하는 나눔폰트를 설치해야 깔쌈한 템플릿을 볼수 있음. 








Sonatype Nexus #2 : 설정 및 maven 과 연결하기

Sonatype Nexus 를 설치 했다고 해서 바로 사설 리파지토리 기능을 하는건 아니다.

몇가지 설정을 쪼물쪼물 해줘야 된다.

사실 다른 자료들을 찾아보고 설치까지는 했는데 그 뒤 설정하는걸 설명안해주고 설치만 하면 다되는것 처럼 적혀 있어서 난 도대체 왜 안될까 하면서 Nexus 개후짐 이라고 결론을 내릴뻔 했다. 나의 무식때문에 만든다고 용써준 사람을 욕하다니.


관리자로 로그인 한 다음 왼쪽 메뉴중에 Repositories 를 클릭하면 디폴트로 등록된 리파지토리들 목록이 나온다.




먼저 목록중에 Public Repositoires 를 클릭하면 아래쪽에 상세내용이 나오는데 Configuration 탭으로 이동한다.


Ordered Group Repositories 에 디폴트로 여러개가 등록도 있을껀데 일단 Maven Central 만 남기고 다 빼버리자, 나중에 원하는걸 필요할때마다 맨들어서 추가해 주면 된다.

요부분에서도 그동안의 고정관념 때문에 살짝 삽질을 했는데, 나의 고정관념 상으로는 죠렇게 박스 두개가 있으면 오른쪽 박스가 당연히 선택할 대상들이 들어가는 박스라고 생각해서 아무리 설정을 해도 안되는 것이였다 -_-;

외국 사람들은 반대로 생각하나 보다 -_-;  아무튼 결론적으로 하나로 묶어줄 애들은 왼쪽 Ordered Group Repositories 에다 추가시켜주면 된다 -_-

죠렇게 해 준다음에 아래쪽에 Save 버튼을 눌러 저장을 해준다.





고 다음으로 설정할 것은 리파지토리 목록중에 Maven Central 을 설정하는 것이다. 역시 클릭하면 아래쪽에 상세화면이 나오는데 Configuration 탭으로 이동하자.


여기서 할일은 Download Remote Indexes 가 디폴트로 False 로 되 있을건데 고걸 True 로 바꿔준다음 Save!

Download Remote Indexes 가 True 로 되있으면, Remote Storage Location 으로 설정된 http://repo1.maven.org/maven2 에 접속해서 인덱스 파일을 받아와서 고 인덱스 파일이랑 똑같이 나의 서버에 인덱스를 맨들어 준다.

Save 를 하면 인덱스파일을 다운로드 받아 인덱스를 업데이트 하는 작업이 시작된다. 이 작업이 완료되면 리프레쉬를 한다음에, 상단의 탭중Browse Index 탭을 클릭해보면 전에 하나도 안보이던 목록들이 쪽 생성이 되 있을 것이다.



인덱싱하는 작업이 쪼매 오래 걸리는데 작업이 완료 됬는지 계속 작업중인지 볼려면 왼쪽 메뉴중 Administration > Scheduled Tasks 를 클릭해 보면 알수 있다.


이 메뉴는 현재 Nexus 에서 돌아가고 있는 Task 를 보거나 아니면 원하는 Task를 스캐쥴링 하도록 등록하는 메뉴인것 같다.

아무튼 Task 목록을 보면 Maven Central 리파지토리의 인덱스를 다운로드 받아서 인덱싱을 하는 작업이 진행중인것을 볼수 있다.

작업이 완료되면 목록에서 사라지는데, 상단의 리프레쉬 버튼을 클릭하다 보면 언젠가는 사라질 것이다. -_-;



인덱싱 작업이 완료되면 이제부터 정상적인 사설 리파지토리 기능을 수행할 수 있다.!!




인덱싱된 결과를 볼려면 Pubic Repositories 를 클릭한다음 Browse Index 탭을 클릭해 보자.


인덱싱을 하기전에는 안보이던 여러가지 목록들이 간지나게 쫙 펼쳐져 있다.

※ Browse Index 탭에 보여지는 것들은 내가 맨든 사설리파지토리로 제공가능한 디펜던시들이지 아직 나의 서버로 다운로드가 된 상태는 아니다.
※ 나의 서버로 누군가가 디펜던시를 요청하면 일단 최초로 proxy 대상 리파지토리에서 해당 디펜던시를 다운로드 받아 이후 요청부터 캐싱을 하게 된다
※  현재 다운로드 받아 캐싱하고 있는 디펜던시들을 볼려면 Browse Storage 탭을 클릭해 보면 된다.





여기까지만 하면 일단 설정을 대충 다 끝났고 maven 에서 나의 서버를 바라보게 설정만 해주면 된다.

위 스크린샷에서 보면 리파지토리 목록 왼 오른쪽에 있는 Repository Path를 요렇게 pom.xml 파일의 repository 로 설정해 주거나 바꿔주면 된다.

많은 현재 디폴트로 등록된 리파지토리들이 많이 있지만 이중에서 다른 리파지토리들을 하나로 묶어주는 group 타입의 public 리파지토리를 메이븐에서 바라보도록 설정하자~

<repositories>
	<repository> 
		<id>central</id>
		<url>http://127.0.0.1:8080/content/groups/public</url>
		<releases><enabled>true</enabled></releases>
		<snapshots><enabled>true</enabled></snapshots>
	</repository>
</repositories>

<pluginRepositories>
	<pluginRepository>
		<id>central</id>
		<url>http://127.0.0.1:8080/content/groups/public</url>
		<releases><enabled>true</enabled></releases>
		<snapshots><enabled>true</enabled></snapshots>
	</pluginRepository>
</pluginRepositories>


Nexus 설명서를 보면 maven 의 settings.xml 파일인가 고걸 수정하게 하던데 그러면 다른 개발자들도 settings.xml 을 귀찮게 수정해야 하기 때문에 나는 svn으로 공유되는 pom.xml 파일을 수정했다.


아무튼 요렇게 한 후 나의 서버가 잘 돌아가나 테스트를 해보기 위해 pom.xml 파일에 디펜던시를 아무거나 하나 추가해 보자.
<dependency>
	<groupId>abbot</groupId>
	<artifactId>abbot</artifactId>
	<version>0.12.3</version>
</dependency>



음~ 잘되는 것 같다. 확실히 확인하기 위해서 위에서 설명했던 현재 캐싱된 디펜던시들을 보여주는 Browse Storage 탭을 클릭해 보면 pom.xml 파일에 추가했던 abbot 뭐시기가 캐싱된 것을 확인할 수 있다.



지금까지 한 설정은 딸랑 maven central 리파지토리만 바라보도록 설정했는데, 필요에 따라 다른 외부 리파지토리를 proxy 타입으로 추가 시킨다음

하나로 묶어주는 기능을 하는 group 타입의 Public Repositories 에다 포함 시켜주고 maven 에서는 이 public 리파지토리만 바라보도록 하면

pom.xml 파일에 추가적으로 <repository/> 를 추가할 필요도 없고 한번 캐싱된건 나의 서버에서 빠르게 다운로드 받을 수 있을 것이다.




이건 기본적인 사설 리파지토리 기능이고, 다음 포스트에서는 이렇게 맨들걸 쪼매 더 활용할 수 있도록 이것저것 다른 설정들을 쪼물거려 보겠다.





Sonatype Nexus #1 : 톰캣에 설치하기


메이븐을 빌드툴로 써서 개발하다 보면 편안하긴 편안하지만 인터넷으로 라이브러리나 훌러그인을 다운로드 받는 시간이 쫌 걸린다는게

살짝 불편한 점이긴 하다. 뭐 물론 나의 로컬로 라이브러리가 한번 다운로드되면 그 뒤론 다시 다운로드 받지 않아서 빠르긴 하지만

컴퓨터를 포맷하거나 했을때는 다시 다운로드 받는 과정을 거쳐야 하기 때문에 아주 사소히 불편스럽다.


요런 시간 소모를 해소하기 위해 사설 메이븐 리파지토리를 맹글어 보겠다.

메이븐 사설 리파지토리를 맹글어 주는 제품은 많다고 하던데 기능이야 뭐~ 다 비슷비슷 하겠고 UI 가 쫌 깔쌈하다는 Sonatype Nexus 를 설치해 보겠다. 


웹사이트 :  http://nexus.sonatype.org/
다운로드 사이트 : http://nexus.sonatype.org/downloads/

이 글을 작성하는 시점에서 제일 최신버전이 1.9.2.3 버전이다.



다운로드 사이트에 가면 파일들 목록이 쪽 나오는데 그중에서  nexus-webapp-1.9.2.3.war 요런 war 파일을 다운로드 받으면 된다.



war 파일이라서 톰캣이나 다른 것들에 설치하는건 일도 아니다.

모를 사람도 있으니 간단히 설명하겠다. 먼저  nexus-webapp-1.9.2.3.war 파일명을 ROOT.war 로 바꾼다.

※ 나는 http://127.0.0.1:8080 으로 접근하기 위해서 ROOT.war 로 바꾼것이지 만약 http://127.0.0.1:8080/nexus 로 접근하고 싶다면 nexus.war 로 파일명을 바꾸면 된다.

파일명을 바꿨으면 고 파일을

톰캣 설치디렉토리/webapps/ 아래에다 복사를 하고 톰캣을 시작하면 설치가 끝난다. 




브라우져로 주소창에 http://127.0.0.1:8080 을 입력하고 접속해 보자~ 


뽓 하고 정상적으로 접근이 된다.




관리자로 접속을 하기 위해서는 오른쪽 귀퉁이에 있는 Log In 버튼을 클릭하고 아이디/패스워드에 admin / admin123 을 입력하면 된다.



이게 심하게 보안이 필요할것 같진 않지만 그래도 기분상 Security > Change Password 에 가서 관리자의 패스위드도 변경해 주자.

왼쪽 메뉴중에 Repositories 를 클릭해 보면 친절하게 디폴트로 등록해준 메이븐 리파지토리들이 보인다.

지금 당장은 미리 등록해준 리파지토리들이 다 필요하진 않고 Public Repositories 랑 Maven Central 요거 두개 정도만 필요하다.




리파지토리 타입을 보면 group, hosted, proxy, virtual 같은게 보이는데 간단하게 설명하면

group 은 hosted, proxy 타입등 등록된 리파지토리들을 논리적으로 묶어주는 리파지토리 타입이다.
▣ hosted 는 maven 야리꾸리한 듣보잡 라이브러리나 상용제품에서 제공하는 라이브러리 같이 maven 리파지토리에 등록이 안된 라이브러리를 등록해 주는 리파지토리 타입이다. 따로 jar 파일 같은걸 등록하고 싶다면 요 타입을 쓰면 된다.
▣ proxy 는  http://repo1.maven.org/maven2/ 은 같은 인터넷상의 다른 메이븐 리파지토리를 캐싱해 주는 리파지토리 타입이다. 이 타입이 아마 가장 많이 쓰일것같다.
virtual 은 maven1, maven2 리파지토리를 상호변환 해주는 것인데 거의 쓸일은 없을것 같다.




대충 요런 타입들의 리파지토리들을 적절하게 짬뽕시켜 나만의~ 우리회사만의~ 리파지토리를 만들면 된다.  


대부분, 원하는 외부 주요 리파지토리들을 proxy 타입으로 여러개 등록하고, maven 리파지토리에 없는 라이브러리 등록용 hosted 타입도 하나 등록하고,

요것들을 group 타입 리파지토리로 하나로 묶어서 group 만 바라보면 되도록 하는 구성을 많이 쓰는 것 같다. 






아무튼 이렇게 하면 Nexus 설치는 끝나지만, 살짝 설정도 바꾸고, 리파지토리 인덱스도 업데이트 해줘야 maven 이랑 연결시켜서 사설 리파지토리의 역할을 할 수 있게 된다.

고건 다음 포스트에!!




prev 1 ··· 27 28 29 30 31 32 33 ··· 45 next