달력

1

« 2025/1 »

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
2014. 5. 19. 16:40

Spring 의 SimpleJdbcCall 이용시 에러. 그거/Java2014. 5. 19. 16:40

spring 을 이용하여 Oracle 의 Stored procedure 를 호출하는데,

계속 인수가 맞지 않다고 에러를 뱉어낸다.

Junit test 돌려보면 지극히 정상인데.. 시스템에서는 에러를 내고 있으니. 당췌 원인을 알 수가 없다는.

jdbc driver 문제인가, 아니면 사용중인 library 가 문제인가.

여기 저기 뒤져보고.. 별 짓을 다 해봐도 안됐다는...


시스템 담당자에게 procedure 생성 script 달라고 해서 원인 분석


o. junit  test 환경

 - local db 에 abc user 로 접속

 - abc user 가 procedure 생성

 - test 수행 시 abc user 로 수행

 - procedure 정상 호출됨


o. system 환경

 - remote db 에 def user 로 접속

 - dba user 가 procedure 생성

 - dba user 가 생성한 procedure 에 대해 def user 에 synonym 생성

 - 생성된  procedure 에 대해서 def user 에 실행권한 부여

 - def user 로 procedure 호출

 - 인수가 맞지 않다고 오류 발생


마지막이란 심정으로다가, system 환경을 local 에서 재현해봄.

1. local db 에 def user 생성

2. abc user 가 생성한 procedure 에 대해 def user 에 synonym 생성

3. abc user 가 생성한 procedure 에 대해 def user 에게 실행권한 부여

4. def user 로 procedure 호출

=> 인수가 맞지 않다고 오류 발생


드디어 원인 발견!


실제 procedure 를 실행하는 db user 는 synonym 을 보고 있기 때문에,

다른 db user 가 생성한 procedure에 대한 meta 정보를 못가져오는듯 하다.

(짐작임)


그래서, SimpleJdbcCall 사용할 때 withSchemaName("abc") 을 하니 잘 되더란!

끝.

'그거 > Java' 카테고리의 다른 글

JSP 의 EL 과 JSTL  (0) 2013.08.09
enum 사용하기  (0) 2013.05.02
자바 소스 디컴파일 해보기.  (0) 2013.04.11
Runtime Data Access  (0) 2012.07.30
NoClassDefFoundError vs ClassNotFoundException  (0) 2011.10.11
:
Posted by 뽀기
2013. 8. 9. 17:45

JSP 의 EL 과 JSTL 그거/Java2013. 8. 9. 17:45

안쓰던거 쓰려니 몸이 고생....이 아니라 머리가 고생 -_-;


환경은 이렇다.

tomcat 6.0, servlet 2.4, jstl 1.1.2


JSTL 을 쓰려고 아래와 같이 코딩했다.


<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<%

String a = "str";

%>


<body>

<c:out value="${a}"/>


값이 안나온다. 젠장

별 뻘짓을 다 해도 데이터가 안나옴. ㅡㅡ;

아래와 같이 하니 나옴.


<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<c:set var="a" value="str"/>


<body>

<c:out value="${a}"/>


그렇다.

EL, JSTL 요놈들은 <% %> 에서 일반 변수 선언한건 안된다.

찾아보니,

<c:set/> 요놈이 page, request, session, application 4 영역에 attribute 를 저장하는 놈이다.

EL을 사용하려면 <c:set/> 을 이용해 지정한 변수만 사용가능하다는.. 

그렇지 않으면, 위 page, request, session, application 영역의 변수만 사용가능하다는거다.


다른 예제.


<%

String a = "DDDD:l";

pageContext.setAttribute("id", "lucky");

session.setAttribute("age", "36");

application.setAttribute("team", "FW");

request.setAttribute("name", "Choi");

%>


위와 같이 설정하고,


<c:set var="str" value="<%= a %>"/>

<%= a %><br>

a = ${a}<br>

a = <c:out value="${str}" default="none"/> <br>

a = ${str}<br>


id= ${id}<br>

age= ${age}<br>

name= ${name}<br>

team= ${team}<br>


<c:out value="id=${id}"/><br>

<c:out value="age=${age}"/><br>

<c:out value="name=${name}"/><br>

<c:out value="team=${team}"/><br>


요걸 찍어보면 아래와 같은 결과가 나옴.

DDDD:l
a = 
a = DDDD:l 
a = DDDD:l

id= lucky
age= 36
name= Choi
team= FW

id=lucky
age=36
name=Choi
team=FW


끝.

'그거 > Java' 카테고리의 다른 글

Spring 의 SimpleJdbcCall 이용시 에러.  (0) 2014.05.19
enum 사용하기  (0) 2013.05.02
자바 소스 디컴파일 해보기.  (0) 2013.04.11
Runtime Data Access  (0) 2012.07.30
NoClassDefFoundError vs ClassNotFoundException  (0) 2011.10.11
:
Posted by 뽀기
2013. 5. 2. 15:54

enum 사용하기 그거/Java2013. 5. 2. 15:54

enum 잘 안썼는데..  걍 정리해봄.


1. 단순 상수로 사용하기

public enum Gender { MALE, FEMALE };

public static void main(String[] args) {

System.out.println(Gender.MALE);

}


# 출력 #

MALE



2. 값 설정해서 사용하기

public enum Gender {

MALE(1), FEMALE(2);

private int value;

private Gender(int value) {

this.value = value;

}

public int getValue() {

return this.value;

}

}


public static void main(String[] args) {

System.out.println(Gender.MALE);

System.out.println(Gender.MALE.getValue());

}


# 출력 #

MALE

1



3. method override 해서 사용하기

public enum Gender {

MALE(1), FEMALE(2);

private int value;

private Gender(int value) {

this.value = value;

}

public int getValue() {

return this.value;

}

public String toString() {

switch(value) {

case 10 :

return "MAN";

case 20:

return "WOMAN";

default :

return "???";

}

}

}


public static void main(String[] args) {

System.out.println(Gender.MALE);

System.out.println(Gender.MALE.getValue());

System.out.println(Gender.FEMALE);

System.out.println(Gender.FEMALE.getValue());

}


# 출력 #

MAN

10

WOMAN

20



4. switch/case 에 사용하기

public enum Gender {

MALE(1), FEMALE(2);

private int value;

private Gender(int value) {

this.value = value;

}

public int getValue() {

return this.value;

}

public String toString() {

switch(value) {

case 10 :

return "MAN";

case 20:

return "WOMAN";

default :

return "???";

}

}

}


public static void main(String[] args) {

Gender male = Gender.MALE;

switch(male) {

case MALE:

System.out.println("MAN~~~");

break;

case FEMALE:

System.out.println("WOMAN~~~");

break;

default :

System.out.println("UHM.....");

break;

}

}


# 출력 #

MAN~~~


'그거 > Java' 카테고리의 다른 글

Spring 의 SimpleJdbcCall 이용시 에러.  (0) 2014.05.19
JSP 의 EL 과 JSTL  (0) 2013.08.09
자바 소스 디컴파일 해보기.  (0) 2013.04.11
Runtime Data Access  (0) 2012.07.30
NoClassDefFoundError vs ClassNotFoundException  (0) 2011.10.11
:
Posted by 뽀기
2013. 4. 11. 15:05

자바 소스 디컴파일 해보기. 그거/Java2013. 4. 11. 15:05


서버에 있는 class 파일과 PC 에 있는 class 파일의 크기가 달라서

서버의 class 파일과 PC의 class 파일을 decompile 해서 비교하다 보니 아래와 같이 알 수 없는 문장(?)들이 있어서


        break MISSING_BLOCK_LABEL_361;

        Exception exception;

        exception;

        if(bw != null)

            bw.close();

        throw exception;

        if(bw != null)

            bw.close();

그래서, decompile 테스트 해봤다.


BufferedReader br = null;

try {

System.out.println("try >>");

br = new BufferedReader(new InputStreamReader(System.in));

br.readLine();

System.out.println("try <<");

} catch(Exception e) {

System.out.println("catch >>");

e.printStackTrace();

System.out.println("catch <<");

} finally {

System.out.println("finally >>");

if( br != null ) {

try { 

System.out.println("finally try >>");

br.close(); br = null; 

System.out.println("finally try <<");

} catch(Exception ignr) {

System.out.println("finally catch");

}

}

System.out.println("finally <<");

}

System.out.println("000");

ArrayList list = new ArrayList();

for(int i = 0; i < list.size();) {

Object o = list.get(0);

break;

}

System.out.println("111");


int j = 0;

if( j < list.size() ) {

Object o = list.get(0);

}

System.out.println("222");


for(int i = 0; i < list.size(); i++) {

Object o = list.get(i);

}

System.out.println("333");


위의 자바 소스를 컴파일 한 후 class 파일을 디컴파일 해보면 아래와 같다.


        BufferedReader bufferedreader = null;

        System.out.println("try >>");

        bufferedreader = new BufferedReader(new InputStreamReader(System.in));

        bufferedreader.readLine();

        System.out.println("try <<");

        System.out.println("finally >>");

        if(bufferedreader != null)

            try

            {

                System.out.println("finally try >>");

                bufferedreader.close();

                bufferedreader = null;

                System.out.println("finally try <<");

            }

            catch(Exception exception)

            {

                System.out.println("finally catch");

            }

        System.out.println("finally <<");

        break MISSING_BLOCK_LABEL_234;

        Exception exception1;

        exception1;

        System.out.println("catch >>");

        exception1.printStackTrace();

        System.out.println("catch <<");

        System.out.println("finally >>");

        if(bufferedreader != null)

            try

            {

                System.out.println("finally try >>");

                bufferedreader.close();

                bufferedreader = null;

                System.out.println("finally try <<");

            }

            catch(Exception exception2)

            {

                System.out.println("finally catch");

            }

        System.out.println("finally <<");

        break MISSING_BLOCK_LABEL_234;

        Exception exception3;

        exception3;

        System.out.println("finally >>");

        if(bufferedreader != null)

            try

            {

                System.out.println("finally try >>");

                bufferedreader.close();

                bufferedreader = null;

                System.out.println("finally try <<");

            }

            catch(Exception exception4)

            {

                System.out.println("finally catch");

            }

        System.out.println("finally <<");

        throw exception3;

        System.out.println("000");

        ArrayList arraylist = new ArrayList();

        int i = 0;

        Object obj;

        if(i < arraylist.size())

            obj = arraylist.get(0);

        System.out.println("111");

        i = 0;

        if(i < arraylist.size())

            obj = arraylist.get(0);

        System.out.println("222");

        for(int j = 0; j < arraylist.size(); j++)

        {

            Object obj1 = arraylist.get(j);

        }


        System.out.println("333");

        return;


디컴파일한 소스를 보면 finally 가 3번이나 나온다.

그리고, 1번만 실행되는 for문(2번 이상 실행되지 않는 for문)은

알아서 for 문의 조건만 포함한 if문으로 변경된다.


아. 젤 위에 있는 이상한 문장(?)들은 catch 와 finally 에 있는 코드들인듯 하돠.

뭐 새로울 건 없지만, 소스 분석하다가 재밌어서 올려봄.. ㅡ,.ㅡ;

'그거 > Java' 카테고리의 다른 글

JSP 의 EL 과 JSTL  (0) 2013.08.09
enum 사용하기  (0) 2013.05.02
Runtime Data Access  (0) 2012.07.30
NoClassDefFoundError vs ClassNotFoundException  (0) 2011.10.11
Eclipse 에서 Maven 이용해서 remote repository 에 deploy 하기  (0) 2011.10.05
:
Posted by 뽀기
2012. 7. 30. 10:06

Runtime Data Access 그거/Java2012. 7. 30. 10:06

Java 의 변수 구분


- Class Variables

- Member Variables

- Parameter Variables

- Local Variables


- Class Variable

static 변수. Class 에 속해 있는 변수.

Method Area 의 Class Variable 영역에 할당.

모든 Thread 에 의해 공유.


- Member Variable

instance 변수. instance 에 속해 있는 변수


- Parameter Variable

method 의 매개변수. method 에 속해 있는 변수.

변수의 정보는 Method Area 의 Method Information에 포함.

JVM Stacks 에 할당.


- Local Variable

Parameter Variable 과 동일한 부류. method 내에서 정의되는 변수.

Local Variable 은 Parameter Variable 과 같이 Method Information 에 변수 정보가 위치하고 JVM Stacks 에 할당.


Class VariableArrange {

static int ci = 3 ;    // Class Variable

int mi = 4;            // Member Variable


void method(int pi, String ps) {    // Parameter Variable

int li = 5;                            // Local Variable

}

}



중요!!!

Parameter Variable 과 Local Variable 은 Thread Safe 변수.

사용자가 Method 내에서 선언한 Local Variable 의 값에 대해 다른 Thread 의 접근이 불가능.

JVM Stacks 는 다른 Thread 에 의해 접근이 불가능하기 때문.


- 출처 : Java Performance Fundamental (김한도 지음) -

:
Posted by 뽀기
2011. 10. 11. 16:41

NoClassDefFoundError vs ClassNotFoundException 그거/Java2011. 10. 11. 16:41


NoClassDefFoundError
- 컴파일 시점
에는 존재했으나, 실행 내부적으로 loading 되는 class가 없을 때

예제) 아래와 같은 java 자원들을 컴파일 한 후 B.class 파일을 삭제하고 java C 하면 NoClassDefFoundError 발생

Class A extends B {
}

Class B {


Class C {
    public static void main(String[] args) {
        A a = new A a();
    }


예제)  아래와 같은 java 자원들을 컴파일 한 후 D.class 파일을 삭제하고 java E 하면 NoClassDefFoundError 발생

class D {
}

 Class E {

    public static void main(String[] args) {

        D d = new D();

    }



ClassNotFoundException
해당 class 파일이 없을 때(클래스를 로딩하려는 명시적인 시도가 실패할 경우)

예)  아래와 같은 java 자원들을 컴파일 한 후 C.class 파일을 삭제하고 java C 하면 ClassNotFoundException 발생

Class A extends B {

}


Class B {


Class C {

    public static void main(String[] args) {

        A a = new A a();

    }



정리하면,

ClassNotFoundException
 => ClassLoader가 로딩하려고 하는 class가 존재하지 않을 경우 발생
NoDefFoundClassError
 => 
ClassLoader가 로딩하는 명시적인 class 내부에서 묵시적으로 로딩하고자 하는 class가 존재하지 않을 경우 발생
:
Posted by 뽀기

$MAVNE_HOME/conf/settings.xml 파일 수정

   <server>

      <id>RepoID</id>

      <username>admin</username>

      <password>fw1234</password>

   </server>


Remote repository(Nexus) 에 repository 추가하기

Repository ID : RepoID
Repository Name : Repository
Repository Policy : SNAPSHOT 

 
 pom.xml 에 배포 정보 추가하기

<distributionManagement>

<repository>

<id>RepoID</id>

<name>Repository</name>

<url>http://1.0.0.0:8081/nexus/content/repositories/repo-id</url>

</repository>

</distributionManagement>

 
settings.xml 파일의 <id> 값과 pom.xml 파일의 <id> 값을 같도록 설정해줘야 한다.

해당 프로젝트에서 Run As > Run Configuration 에서 "goal" 항목에 deploy 입력하고 Run 하면 된다.

혹시 Uploading 중에 401 오류가 발생하면 settgins.xml 파일의 사용자 정보를 확인해본다.
 

'그거 > Java' 카테고리의 다른 글

Runtime Data Access  (0) 2012.07.30
NoClassDefFoundError vs ClassNotFoundException  (0) 2011.10.11
Java에서 Cookie 값 꺼내쓰기 유틸..  (0) 2011.09.30
MSSQL의 JDBC 로의 컬럼 타입 매핑  (0) 2011.08.08
String.sprlit() 의 사용..  (0) 2011.07.12
:
Posted by 뽀기
2011. 9. 30. 10:02

Java에서 Cookie 값 꺼내쓰기 유틸.. 그거/Java2011. 9. 30. 10:02


걍.. 만들어 봄 ㅎㅎ

makeCookie.jsp

<%@ page language="java" contentType="text/html; charset=EUC-KR" pageEncoding="EUC-KR"%>

<%@ page import="java.util.*" %>

<%@ page import="java.net.*" %>

<%

Cookie cookie1 = new Cookie("CJW1", URLEncoder.encode("cAT=A&cBT=B&cCT=C&cDT=D", "euc-kr"));

Cookie cookie2 = new Cookie("CJW2", URLEncoder.encode("cAT=A&cBT=B&cCT=C&cDT=D", "euc-kr"));

Cookie cookie3 = new Cookie("CJW3", URLEncoder.encode("cAT=A&cBT=B&cCT=C&cDT=D", "euc-kr"));

Cookie cookie4 = new Cookie("CJW4", URLEncoder.encode("cAT=A&cBT=B&cCT=C&cDT=D", "euc-kr"));

response.addCookie(cookie1);

response.addCookie(cookie2);

response.addCookie(cookie3);

response.addCookie(cookie4);


%>

<!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=EUC-KR">

<title>Insert title here</title>

</head>

<body>

<a href="getCookie.jsp">getCookie</a>

</body>

</html>

 
getCookie.jsp 

<%@ page language="java" contentType="text/html; charset=EUC-KR" pageEncoding="EUC-KR"%>

<%@ page import="java.util.*" %>

<%@ page import="java.net.*" %>

<%!

class CookieBook {

private Cookie[] cookies = null;

private HashMap<String, String> cookiesMap = new HashMap<String, String>();

public CookieBook(Cookie[] cookies) {

this.cookies = cookies;

makeCookiesMap();

}

private void makeCookiesMap() {

for(Cookie cookie : cookies) {

String value = null;

String key = cookie.getName();

try {

value = URLDecoder.decode(cookie.getValue(), "euc-kr");

} catch(Exception e) {

value = cookie.getValue();

}

cookiesMap.put(key, value);

if( value.indexOf("&") > 0 ) {

parseData(key, value);

}

}

}

public String getCookieValue(String key) {

if( cookiesMap.containsKey(key) ) {

return cookiesMap.get(key);

} else {

return null;

}

}

private void parseData(String key, String value) {

System.out.println(value);

String[] datas = value.split("&");

for(String data : datas) {

int idx = data.indexOf("=");

if( idx != -1 ) {

String tmpKey = key + "." + data.substring(0, idx);

String tmpData = data.substring(idx+1);

cookiesMap.put(tmpKey, tmpData);

}

}

}

public HashMap<String, String> getMap() {

return cookiesMap;

}

}

%>

<%

CookieBook cookBook = new CookieBook(request.getCookies());

%>

<!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=EUC-KR">

<title>Insert title here</title>

</head>

<body>

<table border=1>

<tr>

<th>KEY</th><th>VALUE</th>

</tr>

<%

Iterator<String> keys = cookBook.getMap().keySet().iterator();


while(keys.hasNext()) {

String key = keys.next();

%>

<tr>

<td><%= key %></td><td><%= cookBook.getCookieValue(key) %></td>

</tr>

<%

}

%>

</table>

</body>

</html>

 
CookieBook 이라는 유틸 클래스 만들어서 사용 ㅎ

 KEY  VALUE
CJW4.cCT   C
CJW4  cAT=A&cBT=B&cCT=C&cDT=D
JSESSIONID  HgjlTGnbyRp75pBBPGCXGN3myQgyL7pYVTFvfGgFvBgTpPYhzzTM!-702582978

요딴식으로 보임.
 
:
Posted by 뽀기
2011. 8. 8. 14:18

MSSQL의 JDBC 로의 컬럼 타입 매핑 그거/Java2011. 8. 8. 14:18

MSSQL                          : JDBC
-------------------------------+----------------
char, nchar                    : CHAR
varchar, nvarchar              : VARCHAR
text, ntext                    : LONGVARCHAR
binary, timestamp              : BINARY
varbinary                      : VARBINARY
image, udt                     : LONGVARBINARY
bit                            : BIT
tinyint                        : TINYINT
smallint                       : SMALLINT
int                            : INTEGER
bigint                         : BIGINT
numeric                        : NUMERIC
decimal, money, smallmoney     : DECIMAL
real                           : REAL
double, float                  : DOUBLE
datetime, smalldatetime        : TIMESTAMP

:
Posted by 뽀기
2011. 7. 12. 19:10

String.sprlit() 의 사용.. 그거/Java2011. 7. 12. 19:10


   String str = "SELECT * FROM ( "+

   " SELECT ROWNUM AS RNUM, A.* FROM( SELECT * FROM EX_TABLE WHERE 1=1"+

   "  ) A "+

   ") WHERE RNUM >= 1 AND RNUM < 51";

   

   String[] sss = str.split(" ");

   

   for(String s : sss) {

    System.out.println("#" + s + "#");

   }


위와 같이 한 후 돌려보면
 

#SELECT#

#*#

#FROM#

#(#

##

#SELECT#

#ROWNUM#

#AS#

#RNUM,#

#A.*#

#FROM(#

#SELECT#

#*#

#FROM#

#EX_TABLE#

#WHERE#

#1=1#

##

#)#

#A#

#)#

#WHERE#

#RNUM#

#>=#

#1#

#AND#

#RNUM#

#<#

#51#

 
이런 결과를 얻게된다.

white space 를 기준으로 String을 쪼개고 싶을 때는 아래와 같이 하자!

   String str = "SELECT * FROM ( "+

   " SELECT ROWNUM AS RNUM, A.* FROM( SELECT * FROM EX_TABLE WHERE 1=1"+

   "  ) A "+

   ") WHERE RNUM >= 1 AND RNUM < 51";

   

   String[] sss = str.split("\\s+");

   

   for(String s : sss) {

    System.out.println("#" + s + "#");

   }

 
그러면, 아래와 같이 나온다.

#SELECT#

#*#

#FROM#

#(#

#SELECT#

#ROWNUM#

#AS#

#RNUM,#

#A.*#

#FROM(#

#SELECT#

#*#

#FROM#

#EX_TABLE#

#WHERE#

#1=1#

#)#

#A#

#)#

#WHERE#

#RNUM#

#>=#

#1#

#AND#

#RNUM#

#<#

#51#

 
## 이 놈들이 사라졌다. 

'그거 > Java' 카테고리의 다른 글

Java에서 Cookie 값 꺼내쓰기 유틸..  (0) 2011.09.30
MSSQL의 JDBC 로의 컬럼 타입 매핑  (0) 2011.08.08
String.intern() 메소드  (0) 2011.05.02
Use of String in Java  (0) 2011.05.02
Profiling by using NetBeans.  (0) 2011.04.28
:
Posted by 뽀기