달력

52024  이전 다음

  • 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

윈도우 7 JAVA_HOME 설정하기

Posted by 행복한삶~!!
|


표준액션


<jsp:xxxxxx /> 형태의 action tag들.. 

대표적으로  <jsp:include .../>    < jsp:forward ....  />    

<jsp:useBean   .....   />    <jsp:getProperty .... /> <jsp:setProperty .....  /> 


참조할만한 글.. 

http://blog.naver.com/PostView.nhn?blogId=toplms78&logNo=70182158839

http://blog.naver.com/PostView.nhn?blogId=julymorning4&logNo=100194830950


JSTL - jstl.jar, standard.jar를  import 해야 사용가능함. 

<c:xxxx  .....   />  - Core  

<fmt:xxxx   />  - 포맷팅 관련 (숫자,날짜,시간, 국제화, 다국어 지원 기능을 제공 )

<fn:xxxx  /> - 문자열을 처리하는 함수 관련


 <sql:xxxx  /> <x:yyyy /> - 잘사용하지 않는다. 


참조할만한 글...


http://kimseunghyun76.tistory.com/326

http://www.cyworld.com/vattle/9918251

http://seven00.tistory.com/373


LPAS 소스 살펴보고, 사용여부에 따라서 사용한 문번들은 다시한번 정리해서 익히도록 합시당... 

'BackEnd > JSP&Servlet' 카테고리의 다른 글

서블릿 라이프사이클  (0) 2014.03.12
Expression Language  (0) 2014.03.11
JSP 기초 1 - Session/Cookie/URL 재작성/ 페이지 forward,include  (0) 2013.10.11
Posted by 행복한삶~!!
|

출처 : http://kwon37xi.egloos.com/3666564


초보 Java 웹 개발자들을 위한 학습 로드맵 프로그래밍

OKJSP에 자주 가서 요즘 자바 개발자들이 어떻게 살아가나를 보는 편인데, 아주 많이 반복적으로 올라오는 질문이 "대체 뭘 공부해야 하나요? 프레임워크는 Spring을 해야 할까요? iBATIS를 해야 할까요?" 하는 식의 질문들이다(이 질문은 사실 말이 안된다. 왜 그런지 읽다보면 나온다).

Java는 웹 관련 프레임워크들이 너무 다양하고, Ruby나 Python 같은 경우에는 RubyOnRails나 Django 처럼 하나의 프레임워크 안에 기능별 프레임워크들도 모두 다 All in one 형태로 들어 있어서 혼란을 주지 않는 반면, Java는 각 영역별로 프레임워크가 모두 다르고, 또한 각 영역별로 존재하는 프레임워크들의 종류도 많아서 초보 개발자들에게 극심한 혼란을 주고 있다.

그래서 나름대로 Java Web 개발자들을 위한 학습 로드맵을 정리해 보았다.

1. Java 그 자체
많은 웹 개발자들이 마치 JSP 코드를 짤 줄 알면 그걸로 Java 웹 개발을 할 줄아는 것이라 생각하고 Java 그 자체를 소홀히 하는 것을 본다.
말도 안되는 소리이다. Java를 모르고서 Java 웹 개발을 제대로 한다는 것은 어불 성설이다. Java 그 자체를 먼저 공부하라.

특히 Java 5 문법을 숙지하길 권한다. 이제 우리나라도 점차 Java 5가 대세가 되어 가고 있다. 대부분의 프레임워크들과 WAS(JSP와 서블릿을 구동하는 서버)도 모두 Java 5를 기준으로 바뀌었으며, JVM 자체도 버전이 높을 수록 성능이 더 좋다.

2. JSP와 Servlet 그리고 Model 1
모델 1은, JSP 하나에 DB에 접속해서 쿼리를 날리는 등의 모든 업무적인 기능(Business Logic)을 넣고, 그 아래에 HTML 코드를 박아 넣는 식으로 개발하는 것을 의미한다.
아직도 많은 개발자들이 여기에 길들여져 있는데, 일단 JSP 자체에 대한 기본기를 익힌 뒤로는 재빨리 버려야 할 습관이다.

그리고 많은 개발자들이 Servlet을 무시하고 JSP만 하는 것을 보곤 하는데, Servlet에 대한 학습이 제대로 이뤄지지 않으면 더 나은 웹 개발이 곤란하다. Servlet에 대한 기초 개념을 확실히 잡길 권한다.
모델 1은 제가 알기로는 HTML과 로직을 모두 한 JSP에 넣는 방식이 아니라 jsp:beans를 이용하는 방식입니다. 모델 1에서도 여전히 비즈니스 로직과 UI는 분리할 수 있죠. thin controller, fat model에는 더 맞는 방식이라고도 할 수 있습니다. - 영록, 그리고 Servlets and JSP Pages Best Practices에서 Model 1 관련 부분 참조

모델 1은 JSP나 혹은 서블릿 하나가 요청에 대한 처리, 데이터 유효성 검사, 비즈니스 로직 처리, 응답 생성을 모두 다 책임지는 방식이다. 모델 1은 작고, 간단한 애플리케이션에서 개발을 쉽게하고자 할때 사용된다.

In Model 1, a request is made to a JSP or servlet and then that JSP or servlet handles all responsibilities for the request, including processing the request, validating data, handling the business logic, and generating a response. The Model 1 architecture is commonly used in smaller, simple task applications due to its ease of development. - Wikipedia


3. Model 2 - 프레임워크의 등장
JSP로 열심히 개발을 하다보니 프로젝트 규모도 커지기 시작하고, JSP 파일 크기도 수천줄에 달하는등 엄청나게 커진다.
그런데 이 JSP에다 두서없이 모든 기능을 다 때려 넣다보니 JSP마다 똑같은 기능들이 Copy&Paste로 들어가고, JSP 안에 들어 있는 Java 코드들에서 에러가 발생하면 찾아내서 디버깅 하는 일이 지옥같이 느껴지기 시작한다.

여기서 Model 2가 구원자로 등장한다.

Model 2는 말만 멋드러졌지 실제로는 간단한 개념이다.

JSP에서 수행하던 DB 쿼리 등의 작업을 Servlet에게 넘겨주고 JSP에서는 오로지 화면 출력만 담당하는 것이다.

Servlet에서 DB 쿼리등 화면 출력과는 상관없는 비지니스 로직을 일단 먼저 모두 수행하고, 그 결과를 request.setAttribute("key",결과객체);로 담은 다음 JSP 페이지로 포워딩(forward)을 하면 JSP에서는 request.getAttribute("key")로 그 객체를 받아서 화면에 뿌려주기만 한다.
이런 업무 수행단/화면 출력단의 철저한 역할 분리가 Model 2이다.

여기서 이러한 각 역할을 "MVC - Model View Controller" 라고 한다. 그래서 Model 2는 MVC와 동일한 의미로 사용하기 도 한다. MVC의 의미는 공부하면서 찾아보라.

이게 뭐가 좋냐고? 개발 기간이 좀 길어지고 프로젝트 규모가 쬐끔 커지고, 기존 프로젝트를 유지보수를 해보면 얼마나 좋은지 몸소 뼈져리게 느끼게 된다.

Model 2의 기능을 정형화해서 쉽게 구현하게 해주는 것이 MVC Framework들의 역할이다.
가장 유명한 Model 2 웹 프레임워크들은 다음과 같은 것들이 있다.

스트럿츠 1 - Struts 1
스트럿츠 2 - Struts 2
스프링 MVC - Spring MVC
* 기타 덜 유명한 Wicket, Stripes, JSF, Tapestry 등.

Struts 1은 MVC의 효시라고 할 수 있다. 우리에게 MVC라는 축복을 주기는하였으나, 나온지 오래된 만큼 낡은 개념들이 많이 녹아있고 쓸데 없이 복잡하고 배우기도 어려운 편이다.

오히려 Struts 2와 Spring MVC가 더 배우기 쉬울 것이며, 개발도 더 쉽다. 현재 추세는 Struts 2와 Spring MVC이다. 대형 포탈이나 SI 업체들도 Spring/Struts 2를 주로 채택하는 추세로 가고 있는 것으로 알고 있다.

둘 중 하나의 개념만 확실히 이해해도 다른 것을 배우는데 어려움이 별로 없으므로 그냥 둘중에 골라서 배우길 권한다. 나는 Spring을 선호한다.

그리고 MVC 프레임워크를 사용하기 시작하면서 View를 만드는 JSP에 대해서도 재조명이 시작된다. 기존에 Java 코드를 JSP에 직접 넣던 관행을 버리고 JSTL과 태그 라이브러리를 사용하거나 아예 JSP를 버리고 다른 템플릿 엔진으로 만들기도 한다. 이에 관해서는 맨 마지막에.

4. 퍼시스턴스 프레임워크 : JDBC 반복 작업에 짜증이 나기 시작하다.
현대 웹 개발에서 가장 큰 역할을 차지하는 것은 뭐니뭐니해도 단연 Database 작업이다.
지금까지는 아마도 JDBC에서 DB 커넥션을 맺고, 쿼리를 날리고 그 결과 ResultSet을 JSP로 넘겨주어서 출력하는 식으로 했을 것이다.
이미 다들 알고 있겠지만 JDBC를 사용하면 똑같은 코드가 굉장히 많이 반복해서 나온다. 한마디로 "삽질"의 전형이 JDBC 작업이다.
이것을 깨달은 많은 개발자들이 조금 어정짱하게 반복작업을 해결해주는 Util 클래스들을 프로젝트별로 만들어서 사용하곤 한다.
하지만, 물론 이에 대해 정형화하고 깔끔하고 훨씬 더 사용하기 쉬게 만들려는 노력이 이미 수년에 걸쳐 이루어졌다.

이렇게 DB관련된 작업을 정형화한 것들을 Persistence Framework 라고 한다.

아이바티스 - iBATIS : SQL Mapper - JDBC보다 더 쉽게 배우고, 더 편하게 사용한다.
하이버네이트 - Hibernate : 객체지향을 객체지향답게, 개발 기간을 엄청나게 단축시켜주다.

퍼시스턴스 프레임워크의 양대 산맥은 iBATIS와 Hibernate이다. 이 둘 모두 우리나라에 책이 나와 있다.
iBATIS는 SQL Mapper의 한 종류이고, Hibernate는 ORM의 한 종류이다.

이 둘의 차이는 iBATIS는 개발자가 SQL 쿼리를 직접 작성한 것을 객체에 매핑시켜주는 것이고, ORM은 DB 스키마와 객체간의 관계를 설정파일로 만들면 자동으로 쿼리를 만들어주는 것이다.

자, 이 둘을 보면 미국에서는 Hibernate가 인기가 좋고, 우리나라에서는 iBATIS가 사실상 SI 업계를 평정했다.
그러니까, 일단은 우리나라에서는 iBATIS를 공부하면 된다고 보면 된다.

이렇게 말하니까 마치 이 둘이 경쟁자 같은데, 사실 이 둘은 경쟁 상대라기 보다는 보완해주는 역할을 한다. SI에서 처럼 DB 테이블이 정규화 되어 있지 않은 경우에는 Hibernate같은 ORM을 사용하면 프로젝트를 말아먹을 수 있다.

iBATIS는 테이블 정규화에 무관하게, 개발자가 작성한 SQL을 객체로 매핑하기 때문에 DB 스키마가 마구 꼬여 있는 상황에서도 유연하게 작동하고, 개발자가 직접 SQL 튜닝을 할 수 있다는 장점이다.

그리고 Hibernate는 배우기가 굉장히 어려운 프레임워크이고 튜닝이 매우 어렵다. Hibernate책을 보면 캐싱을 통해 성능을 향상시키라고 하지만 캐싱은 iBATIS도 못지않게 잘 지원한다. 하지만 일단 배우면, 그로인한 코딩 생산성이 iBATIS가 감히 넘볼 수 없을 정도록 급격히 향상된다.

Hibernate는 DB 정규화가 잘되어 있는 웹 포탈 업체나 패키지 소프트웨어 제작시에 강력히 권장할만 하다.

5. IoC와 DI - 객체의 생성주기와 의존성을 관리하고 싶어지다
사실 내가 경험한 SI를 보면 4단계 까지만 가도 막장은 아닌 프로젝트라고 본다. 아직도 신규 프로젝트를 하면서도 Model 1에 JDBC로 코딩하는 것을 많이 보았기 때문이다.

앞서, MVC라는 형태로 웹 애플리케이션의 역할을 철저하게 분할해서 처리하라고 했었다.

이제 여기서 좀 더 역할을 분할하기 시작한다.

Database를 관장하는 코드(DAO)와 Database 처리 결과를 가지고 그외 비지니스 로직을 추가로 수행하는 코드(Service), 그리고 웹으로 들어온 요청을 받아서 비지니스 로직을 호출하고, 그 결과를 다시 웹(HTML 등)으로 내보내는 코드(Controller)로 분할을 하면 유지보수가 더 쉽고, DB가 Oracle에서 DB2 로 변경되는 식의 중대 변화가 있을 때도 DAO만 바꾸면 되는 식으로 변화에 대한 대처가 유연해 진다는 것을 깨닫기 시작한다.

이제는 각 역할별로 클래스를 분할하고 컨트롤러 객체는 서비스 객체에 서비스 객체는 DAO 객체에 의존해서 작동하도록 코드를 바꾸기 시작한다. 그리고 객체의 생성과 파괴 주기도 관리해야만 하게 된다. 객체를 하나만 생성하면 되는데 불필요하게 매번 new를 할 필요는 없으니까.

이렇게 객체의 생성/파괴 주기를 관리하고 객체간의 의존성을 관리해주는 프레임워크를 IoC 컨테이너라고 부른다.

1. Spring Framework
2. EJB 3.0

사실상 대세는 Spring Framework로 굳어졌다. EJB 3.0은 내가 안써봐서 뭐라 말은 못하겠다.

Spring MVC는 이 Spring Framework의 일부분이다.

Spring은 또한 AOP도 지원한다.

AOP 의 개념이 상당히 어려운 편이라서 개념 자체를 확실히 한마디로는 표현하지 못하겠다. 어쨌든 개발자들에게 가장 쉽게 다가오는 표현으로 하자면, AOP는 동일한 패턴으로 반복적으로 해야하는 일을 설정을 통해 자동으로 해주는 것이다.
이에 관한 가장 보편적인 예가 바로 트랜잭션이다.
지금까지는 아마도 비지니스 로직이 시작될 때 트랜잭션이 시작되고, 비지니스 로직이 끝날 때 트랜잭션을 종료하는 코드를 매번 작성해서 넣었을 것이다.
AOP를 사용하면, 비지니스 로직의 역할을 하는 메소드가 무엇인지 설정파일에 넣어주기만 하면 자동으로 메소드가 시작될 때 트랜잭션을 시작시키고, 메소드가 끝날 때 트랜잭션을 종료시켜준다. 물론 예외가 발생하면 트랜잭션을 rollback도 해준다. 따라서 Spring을 사용한 프로젝트에서는 트랜잭션 관련 코드를 볼 수 없을 것이다.

Spring 프레임워크는 기본적으로 IoC 컨테이너 역할을 하는 것이 핵심이다. 따라서 Spring을 사용한다고 해서 꼭 Spring MVC를 사용할 필요는 없다. Struts 2 + Spring + iBATIS 나 SpringMVC + Spring + Hibernate 등... 어떠한 조합이라도 가능하다.

6. 그 외
◈ Template Engine : JSP 보다 더 간결하면서 강력한게 필요해!
   * JSP + JSTL : Sun이 지정한 산업표준이다. JSTL은 당연히 쓰고 있으리라 믿는다.
   * Freemarker : 가장 권장할 만하다.
   * Velocity : 굉장히 배우기 쉽다. JSTL보다 더 빨리 배워서 쓸 수 있다. 가독성도 좋다. 그러나 Freemarker 만큼 편하고 강력하지는 못하다.
많은 사람들이 Java 웹 개발을 그냥 "JSP 개발"이라고도 부르는데, MVC가 도입되고, Freemarker 같은 다른 템플릿 엔진을 사용하게 되면 더이상 JSP는 코빼기도 안보이게 된다. 그러므로.. JSP 개발이라는 말은 쓰지 않았으면 좋겠다.

◈ Layout Engine
   * Sitemesh : 헤더 푸터 처럼 동일 패턴이 반복되는 레이아웃을 관리해준다.

◈ XML 도우미 : W3C DOM은 너무 어렵고 난잡하다. 좀 더 편한 XML관련 개발을 원한다면..
   * JDOM : Java 표준으로 지정됐다고 한다.
   * DOM4J
둘 다 비슷하게 편한거 같다. 예전엔 JDOM을 썼었는데, 나 같은 경우 현재 프로젝트에서는 DOM4J를 사용한다. Hibernate가 DOM4J를 사용하기 때문에, 별도의 라이브러리 더 넣는게 귀찮아서.

◈ 단위 테스트
   * jUnit : 코드를 철저하게 테스트하자.

◈ 소스코드 버전관리
   * CVS
   * Subversion : 현재 대세는 Subversion
내가 최고 막장으로 꼽는 프로젝트는 아직도 FTP로 소스 관리하는 프로젝트이다. 이런 프로젝트에는 절대로 참여하지 않을 것이라고 굳게 맹세하고 또 맹세했다. --;
소스 코드 버전관리는 여러 개발자들이 동시에 개발할 때 소스코드를 저장하고 충돌을 관리해주며, 소스 변경 내역을 계속해서 추적해서 과거 소스로 언제든지 돌아갈 수 있도록 도와준다.
현재 대세는 Subversion이지만 CVS로도 버전관리의 이점을 충분히 만끽할 수 있다. 그리고.. 사실 CVS가 사용법을 익히기는 더 쉽다.

◈ 자동 빌드
   * Ant : Ant 면 만사 Ok!
   * Maven
아직도 javac 로 컴파일하고 있고, FTP로 파일 올려서 복사하고 있다면.. 이 모든일을 자동으로 명령 한방에 처리하도록 해야 실수도 적고, 퇴근도 일찍한다.
Ant로 빌드와 배포를 자동화 하자.

결론

내가 권하는 조합은
* SI 업체에서 일하는 경우 : Struts 2 혹은 SpringMVC + iBATIS + JSP/JSTL + 가능하다면 Spring Framework
* 웹 포털등과 같은 업계, 패키지 소프트웨어 제작 업체 : Struts 2 혹은 Spring MVC + Hibernate + Spring Framework + Freemarker + Sitemesh


성윤's Comment !! 

Back end 개발자 위주로 나름 잘 정리되어 있네요.. 

Front end까지 더 보탠다면... Javascript 각종 Framework, Android , PhoneGap 등이 포함되겠네요.. 

Posted by 행복한삶~!!
|

서블릿은  init(), destroy() 함수에 초기화 및 종료 코드를 기술할 수 있다. 

서블릿에서 반복해서 사용될 먼가를 구현하거나,초기화 할때, 공통되는 종료처리를 할때 사용하면 좋을듯.. 


JSP의 경우 jspInit(), jspDestory()를 정의해서 사용하면 된다. 


서블릿 init()의 경우 서블릿이 최초 실행될때 그때 수행이 되는데, 이렇게 하면 최초 실행될때 그 만큼의 시간이 더 소요되는데 

최초에 application이 초기화되는 시점 web.xml이 로딩되는 시점에 초기화를 수행하도록 할 수 있다. 

방법은 web.xml 에 등록하는것이다.. 


예> 

<servlet>

      <servlet-name>   ....  </servlet-name>  

       <servlet-class> .... </servlet-class>

             <load-on-startup /> 

</servelt>


서블릿의 초기화 파라미터

<servlet>

      <servlet-name>  xxx       </servlet-name>

       <servelt-class> xxx </servlet-class>

       <init-param>   

               <param-name>  file_name </param-name>

                <param-value> agreement.txt </param-value>  

        </init-param>

</servlet>


소스에서 해당정보를 얻어오려면.. 


String filename = getInitParameter("file_name"); 



// 유사하게 jsp 파일의 초기화 파라미터를 지정하고 읽어올수도 있다.
그렇게 하기 위해서는 해당 jsp 파일을 servlet으로 web.xml 에 등록해야 한다.  거의 쓸일이 없을것 같아서 생략.. 
( 뇌를 자극하는 JSP Servlet 302 페이지... ) 


웹 어플리케이셔 전체의 초기화 파라미터 

<web-app ... >

       <context-param>   

               <param-name>  file_name </param-name>

                <param-value> agreement.txt </param-value>  

        </context-param>

</web-app> 


소스에서 해당정보를 얻으려면.. 
String str = application.getInitParameter("file_name");


로그 메시지를 기록하는 log 메서드 
application.log("xxxx"); 

Tomcat의 경우 logs 폴더 아래의 해당 날짜파일에 로그가 기록됨. 




page, request, session, application 객체에서 setAttribute, getAttribute, removeAttribue 함수 사용하여 정보 공유하기 

Posted by 행복한삶~!!
|

Servlet 에서 

request.setAttribute("result", total);


JSP에서

$(result)  형태로 간단히 출력가능함.. 


스크립트릿으로 출력하려면 더 복잡함.. 

<%= request.getAttributes("result") %>



JSP 2.0에서 추가됨. 


HTML로 결과 출력을 더 간편하게 하도록 도와주는 문법. 

<%= xxxx.getAtrribute("yyyy") %>  을  간단히   $( "yyyy" ) 형태로 표기가능하다. 


내장객체를 사용하여 application,page,session, request 의 getAttribute를 할수 있고,,, 
post나 get 방식으로 넘어온 파라미터들에 접근,  header, initParam, cookie, pageConext등에 접근가능하다. 


EL의 내장객체

  • pageScope : page scope 의 변수들
  • requestScope: request scope 의 변수들
  • sessionScope : session scope 의 변수들
  • applicationScope : application scope 의 변수들
  • param : parameter 변수들 문자열
  • paramValues: parameter 변수들 문자열 배열
  • header: HTTP request 헤더
  • headerValues: HTTP request 헤더 문자열 배열
  • initParam : 컨텍스트 초기 변수 web.xml 에서 지정
  • cookie : 쿠키 변수들
  • pageContext : 현재 페이지의 pageContext 객체


각종 산술연산 및 논리연산이 가능하다. 

배열, ArrayList, Map 객체에 접근가능하다. 

자바빈 객체에 손쉽게 접근가능하다. 

자바 정적 메소드 호출도 가능하다.  ( 아래 EL 함수 예제 참조 )


EL 함수 예제

http://seung-jun.tistory.com/222

Posted by 행복한삶~!!
|

http://www.okjsp.net/bbs?seq=45969

SimpleDateFormat 에서 시간을 24시간타입으로 나오게 할려면요?어떻게?

java.text.SimpleDateFormat formatter=new java.text.SimpleDateFormat("yyyyMMddHHmmss");

 

위처럼 하면 오후 1시면 01로 나오는데 13시로 나오게 할수 없나요?

HH로 하시면 될텐데요....? 
hour에 관련된 pattern문자는 

HH : 0 -23 
kk : 1 - 24 
KK : 0 -11 
hh : 1 - 12 
이렇게 정의되어 있습니다. 
일반적인 24시간 표시일 경우... 
0 - 23인 HH를 쓰는게 맞습니다.



http://ra2kstar.tistory.com/123


JAVA 현재 시간 구하기




JAVA에서 제공하는 다양한 메서드는 굉장히 편하다. 이번에는 그 중에서 현재 시간을 구하는 메서드를 알아본다. 


System.currentTimeMillis(); 


currentTimeMillis()의 리턴형은 long 값이며, 1/1000초의 값을 리턴한다. 

(검색을 통해서 좀 알아보니 1970년 1월 1일 부터 계산된 것이란다.) 


이 메서드를 통하여, 현재 시간을 계산 할 수 있고, 프로그램의 실행 시간 또한 나타낼 수 있다. 


  현재 시간 출력 및 실행 시간 출력

public class trunc_tweet_tag {

public static void main(String [] args){

long time = System.currentTimeMillis(); 

SimpleDateFormat dayTime = new SimpleDateFormat("yyyy-mm-dd hh:mm:ss");

String str = dayTime.format(new Date(time));

System.out.println(str);

long start = System.currentTimeMillis() ; 

new trunc_tweet_tag("./message/");

long end = System.currentTimeMillis(); 

System.out.println((end-start)/1000 +" 초 걸림");

}

......



'BackEnd > Java' 카테고리의 다른 글

윈도우 7 JAVA_HOME 설정하기  (0) 2014.09.16
초보 Java 웹 개발자들을 위한 학습 로드맵  (0) 2014.03.12
Posted by 행복한삶~!!
|

Kill process

BackEnd/Unix 2013. 12. 26. 14:55

Unix에서 process 강제로 죽이는 방법


먼저 해당 process id를 찾는다. 예를 들어 myserver라면..

ps -ef | grep myserver


출력 결과 예.. 

relnapp1 13631     1   0   Dec 13 ?          12:18 myserver  .:/relnreg4/path...


kill -9 13631 



Posted by 행복한삶~!!
|

Unix C Socket Programming

BackEnd/C 2013. 12. 26. 14:46

처음부터 만든건 아니고.. 기존에 있던 Unix c socket program을 수정할 일이 있었다.

C사에서 예전부터 만들어둔 소스인데 미리 정해둔 client가 아닌경우 접속을 허용하지 않도록 하는것이었다. 

기존에는 client의 ip에 상관없이 해당 port로 접속시도가 들어오면 무조건 connect를 하도록 되어 있었다. 


unix c Socket 통신 기본 익히기 ..

http://forum.falinux.com/zbxe/index.php?document_srl=433968&mid=C_LIB


server 및 client 소스는 컴파일하면 link 오류가 발생하여 아래 명령어로 해결했다. 

cc -w -D_REENTRANCE -g -lpthread  -lnsl -lsocket -c server.c -o server.o

cc -w -D_REENTRANCE -g -lpthread  -lnsl -lsocket server.o -o server

  or 

cc server.o -o server


cc -w -D_REENTRANCE -g -lpthread  -lnsl -lsocket -c client.c -o client.o

cc -w -D_REENTRANCE -g -lpthread  -lnsl -lsocket client.o -o client

  or 

cc client.o -o client


너무 잘 정리되어 있어서 바로 이해를 했다. 

그리고 소스 분석을 하니... 흐름을 파악할수 있었다. 

다중 쓰레드를 고려하여 만들어져 있어서 완벽히 이해하려면 더 시간이 필요했지만... 

필요한만큼 수정하고 작업에 들어갈수 있었다. 

  • hostname 으로 부터 IP얻기 
int hostname_to_ip(char * hostname , char ip[][IP_LEN_MAX])
{
    struct hostent *he;
    struct in_addr **addr_list;
    int i;

    // get the host info
    if ( (he = gethostbyname( hostname ) ) == NULL)
    {
    	CLOGFATAL("\t host lookup error!!  [%s]",hostname );
    	//CLOGINFO("\t host lookup error!!  [%s]",hostname );
        return -1;
    }

    addr_list = (struct in_addr **) he->h_addr_list;

    for(i = 0; addr_list[i] != NULL; i++)
    {
    	if( i>= IP_COUNT_MAX )  // 각 hostname당 최대 4개의 ip를 가질수 있는것을 가정하였다.
    	{
        	CLOGFATAL("\t IP Address count is over MAX(%d) for [%s]",IP_COUNT_MAX,hostname );
    	}
        strcpy(ip[i] , inet_ntoa(*addr_list[i]) );
        CLOGINFO("\t hostname : %s, ip = %s", hostname, ip[i]);
    }

    return i;
}

출처 : http://www.binarytides.com/hostname-to-ip-address-c-sockets-linux/

  • Client Reject하기 .. 
    server에서 accept를 하면 client의 ip를 알수 있는데, 여기서 유효한  ip인지를 보고, 유효하지 않으면 Reject를 하도록 하였다. Reject를 하는 방법은..  아래와 같이 accept할때 받은 FD를 사용하여 close() 하면 된다. 

    client_FD = accept(); 
    close(client_FD); 

    이렇게 하면 서버단에서 다시 socket() 생성하고 bind() 할 필요없이 계속 listen(), accept()를 하면서 유효한 client 들어올때 접속을 하면 된다. 
  • 그외...에 도움된 소스들..
  • 입출력 다중화 방식의 socket 통신이해
    http://blog.naver.com/PostView.nhn?blogId=idkhs04&logNo=40105901046


Posted by 행복한삶~!!
|

union 및 union all

BackEnd/Oracle 2013. 11. 20. 16:27

 개별 subquery 결과를 합할때 유용하다. 

기본 개념잡기는 아래를 참고할것. 


http://intomysql.blogspot.kr/2011/01/union-union-all.html

http://www.w3schools.com/sql/sql_union.asp


Posted by 행복한삶~!!
|
  • 현재 페이지의 상태와 데이터를 그대로 유지시켜 주며 다른 페이지로 이동하기
    request.getReeustDispatcher("이동할페이지").forward( request, response );
    pageContext.forward( "이동할페이지") ;

    <jsp:forward page="target page">

  • 상태 유지 없이 다른 페이지로 이동하기
    response.sendRedirect( "이동할페이지" );
    response.encodeRedirectURL( "이동할페이지" );

    우선브라우저에게 http response를 하고, 브라우저가 다시 이동할페이지를 호출하는 형식임. 
    이동할 페이지로 파라미터 정보를 넘기려면... target.jsp?name=value&name2=value2 형태로 값을 넘길수 있다. 
    파라미터에 한글이 포함된다면 URLEncoder.encode() 를 사용해야 한다. 

    String param = URLEncoder.encode ( "이름=값", "EUC-KR"); 
    param을 target 주소뒤에 붙이면 됨..

    encodeRedirectURL() 함수는 cookie사용이 제한된경우 URL 재작성을 해야 하는 경우에 사용하는 함수이다. 
    주어진페이지 주소에 JSESSIONID=B2KKKEK2U2U2I8JODE8KEKD 형태의 SESSION ID를 붙여서 Target URL을 재작성한다. 

  • 동적페이지 Include
    pageContext.include("삽입할페이지");  // 페이지의 결과가 삽입되는 것임...
    <jsp:include page="">

    그에 비해서 <%include file="삽입대상페이지" %>는 include될 대상의 코드를 복사하여 그대로 include되는 정적인 include 이다.

  •  Cookie 에 대해서.. 

    • Cookie는 HTTP Header에 저장되어 브라우저와 web server간에 전송된다. 

    • 브라우저에서는 javascript로 cookie 정보를 조회,변경,삭제 가능하다.

    • JSP/Servlet에서는 Cookie 객체를 통해서 조회,변경,삭제 가능하다. 

      • 조회 : Cookie cookies[] = request.getCookie(); 

      • 변경 및 추가 : response.addCookie( new Cookie("NAME", "VALUE");    // NAME이 기존에 있다면 수정, 없다면 추가된다. 

      • 삭제 : 삭제기능은 좀 특이하다. 별도의 삭제함수가 있는것이 아니라, Cookie.setMaxAge()를 통해서 수명을 조절하는 방식으로 삭제한다. 

        cookie.setMaxAge(3600); // 한시간으로 남은 수명 지정..
        cookie.setMaxAge(0);     // 쿠키를 바로 삭제 하도록 만든다. 
        cookie.setMaxAge(-1);   // 웹 브라우저가 끝날때 끝날때 삭제되도록 만든다.  default 임.

    • setPath()를 통해서 특정경로에만 Cookie가 전송되도록 조절할 수 있다. 

    • setDomain()를 통해서 여러 웹서버로 전송되도록 할수 있다. 
      웹 서버가 여러개인 경우, setDomain() 을 통해서 여러 웹서버로 전송되도록 할 수 있다.  이렇게 하지 않으면.. A Page를 읽을때 A web server, B 페이지를 읽을때 B Web Server가 호출되었다면  서로 host name정보가 다르기 때문에 Cookie 정보는 공유되지 않는다. 그래서 cookie 정보를 공유하려면 꼭 setDomain()을 사용해야 한다. 

  • Session에 대해서
    • Servlet 과 JSP에서 사용법이 약간 다르다. 
      Servlet 에서는  HTTPSession session = request.getSession(); 으로 session 정보를 얻어서 사용해야 한다. 
      JSP 에서는 그냥 예약된 session 인스턴스를 사용하면 된다. 

    • 주요 메소드
      session.setAttribute( "ID", value );  value 는 object 형태
      Object obj = session.getAttribute("ID");    // 필요시 적절하게 cast해서 target object로 할당한다. 
      session.removeAttribute("ID); 
      session.invalidate();  // 세션을 끝내는 메소드 

  • URL 재작성

    • Session 기술에서도 사실 cookie가 사용된다. seesion을 구별하기 위해서 Session id를 cookie 형태로 만들기 때문이다. JSESSIONID=JDKDKK3ID93KD9E9GKD9D  와 같은 형태임.. 

    • 그래서 cookie를 사용하지 않도록 브라우저 설정이 되어있다면 session이 잘동작하지 않기 때문에 그럴경우.. 

    • URL 재작성이라는 기법을 사용해야 한다.

    • URL 재작성이란 URL로 SESSION ID를 주고 받으며 session을 구분하도록 하여 session 객체를 사용하는 방법이다. 

    • 브라우저와 web server가 주고받는 모든 주소 정보뒤에는 항상 JSESSIONID=DKKDK3K93939DD9D 를 붙이도록 한다. 

    • SESSION ID를 URL에 붙이는 자작업이 상당히 귀찮은 작업이 될수도 있는데.. response.encodeURL()를 통해서 쉽게 할수 있는 방법을 제공한다.  예를 들어 ..... 
      <A href=<%= response.encodeURL( "xxxxx.jsp ") %>   
      와 같이 하면 자동으로 xxxxx.jsp 뒤에 session id정보가 붙는다.

      또 다른 함수가 하나 더 있는데.. . response.encodeRedirectURL() 이다...  
      다른페이지로 redirect 할때 사용하는 함수이다.
      참고로 redirect는 다음과 같이 동작한다. 
      [  (웹서버)브라우저로 응답 -> (브라우저)주어진 주소로 http request -> (웹서버)주어진 주소에 대한 응답 ]


'BackEnd > JSP&Servlet' 카테고리의 다른 글

표준 액션 및 JSTL (Java Standard Template Library)  (0) 2014.03.17
서블릿 라이프사이클  (0) 2014.03.12
Expression Language  (0) 2014.03.11
Posted by 행복한삶~!!
|