728x90
반응형

compile : 컴파일 할때 필요. 테스트 및 런타임에도 클래스 패스에 포함 된다. scorp 을 설정 하지 않는 경우 기본값이다.
runtime : 런타임에 필요. JDBC 드라이버 등이 예가 된다. 컴파일 시에는 필요하지 않지만, 실행 시에 필요한 경우.
provided : 컴파일 시에 필요하지만, 실제 런타임 때에는 컨테이너 같은 것에서 제공되는 모듈. servlet, jsp api 등이 이에 해당. 배포시 제외된다.
test : 테스트 코드를 컴파일 할때 필요. 테스트시 클래스 패스에 포함되며, 배포시 제외된다.

예시)
 <dependency>
   <groupId>javax.servlet</groupId>
   <artifactId>servlet-api</artifactId>
   <version>2.5</version>
   <scope>provided</scope>
  </dependency>

  <dependency>
   <groupId>javax.servlet.jsp</groupId>
   <artifactId>jsp-api</artifactId>
   <version>2.1</version>
   <scope>provided</scope>
  </dependency>

728x90
반응형
728x90
반응형

이클립스에서 웹개발을 위한 tomcat의 시작, 종료를 할 수 있고 이클립스 console에서 log를 볼 수 있는 Tomcat Plugin을 설치해보겠습니다. 

Tomcat을 사용하는것은 크게 3가지로 나눌 수 있습니다

1. Tomcat 직접 시작

2. 이클립스의 Run Server기능을 이용하여 Tomcat 시작

3. Tomcat Plugin으로 Tomcat 시작

위의 세가지 방식중 이 포스팅에서는 3번을 알아 볼 것이며, 이런 저런 방법으로 일해보면서 Tomcat Plugin인을 이용한 방법이 가장 편했다고 생각합니다.

1번은 log를 보기가 힘들고, 2번은 이런저런 알수없는 오류들을 겪었습니다.


------------설치------------

1. http://www.eclipsetotale.com/tomcatPlugin.html#A3 접속

2. tomcatPluginV33.zip 를 다운로드 (2012년 4월2일 기준 ) 

(Tomcat Plugin 3.3버전에서는 이클립스 3.6까지만 지원한다고 나와있지만 이클립스 3.7.2버전에서도 정상 작동을 확인 했습니다.)

3. 압축풀면 com.sysdeo.eclipse.tomcat_3.3.0 라는 폴더가 나오는데 이것을 이클립스의 plugins폴더 안에 복사합니다, Tomcat Plugin은 별도의 install없이 이클립스 내부에 플러그인 폴더를 복사하는것으로 설치가 됩니다.

4. 이클립스를 재시작하면 아래와같이 Tomcat 이미지가 생기고, 좌로부터 시작, 종료, 재시작 입니다.


5. 이클립스의 window -> preferences -> Tomcat 항목에서 Tomcat version은 6을 선택하고, Tomcat home은 톰캣이 있는 디렉터리를 지정하는데 bin, conf, work와 같은 폴더가있는 바로 상위 폴더를 지정해야 합니다.


6. 이제 Tomcat startup 아이콘을 클릭하면 console창에 로그들이 지나가고 정보: Server startup in ~~~ ms 로그가 나오면 정상.


728x90
반응형
728x90
반응형
1. SYNONYM의 개념 

  - 내 계정에서 다른 계정의 특정 테이블을 내 계정에서 볼 때

    Alias(별칭)를 정해놓고, 그 테이블을 참조할 때 Alias로 참조한다.

 

2. SYNONYM의 사용 

  - ORACLE0904 라는 계정에서 SCOTT 계정의 DEPT(부서테이블)을 보려 한다면,

     통상적으로 이렇게 사용한다.

    예) SELECT * FROM SCOTT.DEPT

 

  - 하지만, 이렇게 사용한다면, 나중에 SQL문이 길어질 때, SQL문의 복잡함에 한 몫을 더한다는 점과

     다른 스키마(여기서는 SCOTT)에 있는 오브젝트(여기서는 DEPT)의 위치를

     노출시킨다는 점에서 보안성에도 문제가 있을 수 있다고 한다.

 

  - 그래서 SCOTT.DEPT 라는 부분을 내 계정에서 간단히 줄여 별칭으로 사용하기 위함이 SYNONYM이다.

    예를 들어, 별칭....이라...음. 나는 앞으로 SCOTT.DEPT를 'DEPT2'라는 별칭으로 사용하기 위해

    내 계정에서 별칭을 정하는 작업을 다음과 같이 한다.

    예) CREATE SYNONYM DEPT2 FOR SCOTT.DEPT

 

  - 이렇게 별칭을 설정하여 놓고, SELECT * FROM DEPT2 라는 쿼리를 수행하면,

    SELECT * FROM SCOTT.DEPT 쿼리 수행 결과와 결과가 같음을 확인할 수 있다.

    쿼리문 길이 및 보안유지에도, 조금이나마 도움이 된다는 취지에서 SYNONYM을 사용한다.

 

  * 만약 ORACLE0904 계정에서 SCOTT 계정의 테이블을 SELECT 할 권한이 없다면,

    SCOTT 계정으로 접속하여, 다음과 같이 권한을 주고 작업하면 된다.

    예) GRANT SELECT ON DEPT TO ORACLE0904 
            
--> ORACLE0904 계정에게 DEPT 테이블의
 SELECT 권한 부여

 

  * 또한 나중에 이 별칭을 사용하지 않게 된다면, 해당 SYNONYM을 다음과 같이 없애줘 버리면 그만이다.

    예) DROP SYNONYM DEPT2

728x90
반응형
728x90
반응형

c:out 의 기능은 풀어서 얘기하면
<c:out value="abc">def</abc>

if(value="존재"){ 
abc
}else{
def 


의 표현식이 되겠네요... 널값에 대한 예비 표현식이라 생각합니다.

물론 c:out 을 쓰면 null error 는 잡을수 있겠지요~? 

728x90
반응형
728x90
반응형

자바스크립트의 보안 정책 중 하나인 SOP(Same-Origin Policy) 때문에 데이터를 호출하는 도메인과 데이터를 반환하는 도메인의 주소가 다르면 Ajax를 이용할 수 없다. 그러나 JSONP 라는 형식이나 Proxy 매시업 페이지를 통해 해결 할 수 있는데 여기서는 JSONP를 이용한 방법을 설명하겠다.

원래 Ajax의 코드는 아래와 같다. 그러나 아래 코드로는 Cross Domain에 직면했을때 정상적인 responseText를 얻을 수가 없다.

1
2
3
4
5
6
7
8
9
10
11
12
13
$.ajax({
  type: "POST",
  url: "search.do",
  data: $('#searchbox').val(),
  contentType: "application/x-www-form-urlencoded; charset=UTF-8",
  success: function(data) {
    if (data != null) {
      // ...
    } else {
      //....
    }
  }
});

그러므로 우리는 새로운 방법을 사용해야 한다.


JSONP(JSON with Padding) 을 이용한 Ajax 통신

 - 반환되는 데이터 (JSON)가 아래와 같다고 하자.

1
2
3
4
{
  'result': 'user',
  'go': '테스트'
}


 - 정상적인 데이터를 받기 위해서는 아래와 같이 작성해야 한다. (두 가지 방법 중 아무거나 해도 상관없다.)

 1. $.getJSON()

1
2
3
4
5
    function(data) {
            alert(data.result + ", " +  data.go);
    }
);
 
 2. $.ajax();

1
2
3
4
5
6
7
8
9
10
11
$.ajax({
    url : "http://ip:8080/jsp/upload",
    data : "id=user",
    dataType : "jsonp",
    jsonp : "callback",
    success: function(data) {
        if(data != null)    {
            alert(data.result + ", " +  data.go);
        }
    }
});
 

jQuery 1.2부터는 JSONP 호출에 대한 네이티브 지원이 제공되고 있다. JSONP 콜백을 지정한 경우 다른 도메인에 있는 JSON 데이터를 로드할 수 있으며 JSON 콜백은 url?callback=? 라는 구문을 사용하여 지정할 수 있다.

$.getJSON() 방식을 살펴보면 url 맨 끝에 callback=이라는 문자열과 함께 실제 함수 이름 대신 ? 기호를 콜백 함수 이름으로 입력하는 것을 볼 수 있다. 이는 jQuery가 ? 기호를 인라인 함수를 호출하는 생성된 함수 이름(예:jsonp1234568416)으로 바꾸기때문이다. 굳이 ? 을 적을 필요는 없고 따로 처리하는 콜백함수가 있다면 해당 함수의 이름을 적어줘도 무방하다. 그러나 익명 메소드로 바로 처리할 경우 반드시 ? 를 써줘야 한다.


데이터 반환 (Servlet)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  request.setCharacterEncoding("UTF-8");
  response.setCharacterEncoding("UTF-8");
 
  // 전송된 데이터를 추출(id와 콜백 메소드명)
  String id = request.getParameter("id");
  String callBack = request.getParameter("callback");
 
  // 반환 될 데이터
  JSONObject obj = new JSONObject();
  obj.put("result", id);
  obj.put("go", "테스트");
 
  // 호출 할 javascript 콜백 메소드를 지정 해 준다.
  PrintWriter out = response.getWriter();
  out.write(callBack + "(" + obj.toString() + ")");
  System.out.println(callBack + "(" + obj.toString() + ")");
 
  out.flush();
  out.close();
}

Serlvet으로 구현한 데이터 반환 메소드이다. JSONP는 Get방식으로만 데이터를 가져올 수 있으므로 doGet메소드에 로직을 작성하였다. 
위 코드를 살펴보면 먼저 전달받은 데이터들을 json 형태로 구성한 뒤 콜백함수의 이름으로 감싸줘야 한다. 

최종적으로 반환해야 할 문자열은 아래와 같다. 말 그대로 JSONP(json with padding)이다.

 jQuery17204359748272690922_1338291446125({"result":"user","go":"테스트"})


결과


출처 : http://warmz.tistory.com/739


728x90
반응형

'Web Programming > java-jsp' 카테고리의 다른 글

[펌] eclipse 톰캣 환경 설정하기~  (0) 2015.06.16
오라클 시노님, grant 설정  (0) 2015.06.01
암호화 MD5 vs SHA256  (0) 2015.04.07
DWR 사용시 Session 값 얻기  (0) 2015.04.07
USB 디버깅 ?  (0) 2015.04.06

+ Recent posts