2010-12-20 4 views
2

2.1 년 전에 JSP와 EJB로 개발 된 기존 애플리케이션을 사용했다. 이제 새로운 기능으로 응용 프로그램을 향상시키고 자합니다. 새로운 기능을 추가하기 위해 이전의 동일한 애플리케이션 내에서 Spring 및 Hibernate 프레임 워크를 사용하거나 최신 프레임 워크를 사용하기 위해 새로운 애플리케이션을 개발해야 할 필요가있는 방법이 있습니까?기존 JSP/EJB 애플리케이션에 Spring 프레임 워크 추가하기

미리 감사드립니다.

답변

2

먼저, 왜 스프링을 추가하고 싶습니까? 그렇게하는 당신의 목표는 무엇입니까? 질문에 대답하기 위해, 예, 천천히 기존 앱에 통합하는 방법을 찾을 수는 있지만 제 생각에는 꽤 좋은 이유가 필요합니다.

중요한 변경 사항이 적용된 응용 프로그램을 '현대화'하고 싶다면 (정당성이 있음) 개인적으로 새로운 프로젝트를 시작하여 재사용 할 수있는 물건을 가져와야합니다.

시간이 지남에 따라 변경되는 응용 프로그램 (사실상 모든 응용 프로그램)은 점점 더 복잡해지고 오래된 "정크"를 많이 축적합니다. 결국 앱의 일부 SME가 다른 직업을 찾거나 또는 너무 혼란스럽고 깨지기 쉽기 때문에 결국은 유지할 수 없습니다. 내가 도울 수는 없지만 이와 같은 일을한다고 생각하면 (기존 앱에 추가하는 것) 노후화 과정을 가속화하는 것입니다. ("옛날"의 것들을 "그냥있는 그대로"그대로 두는 충동없이 어떻게 제거하겠습니까?) 할 수있는 동안 집을 청소하는 것이 훨씬 낫습니다. 꽤 좋은 모양의 작은 응용 프로그램을 말하는 것이 아니라면 내 경험이 거의없는 경우입니다.

1

Spring과 Hibernate를 기존 응용 프로그램에 추가 할 수 있습니다. (결국, 단지 jar 파일 만 포함하고 있습니다.) 그렇게하지 않는 것이 좋습니다.

우선, EJB 2.1과 EJB 2.1은 표준 JPA가 없으며 이전 EJB 쿼리 언어를 사용하므로 EJB 2.1과 Hibernate는 충돌합니다.

지속성을 위해 하나 또는 다른 것을 사용하고 혼합하지 않을 것을 제안합니다. EJB 2.1을 사용하여 작성된 데이터베이스 액세스 코드가 상당하다면 Hibernate를 혼입하지 마십시오. 그것은 엉망이 될 것입니다. 만약 당신이 JDBC를 사용하고 있다면, 나는 Hibernate가 잘 맞는 것 같아 보인다.

스프링은 프레임 워크이므로 응용 프로그램에 "봄을 추가하는 것"은 그다지 간단하지 않습니다. 봄은 거대하며 혜택이 무엇인지 스스로에게 물어야합니다. 어떤 부분을 사용하고 싶습니까? 의존성 주사 만? EJB 2.1에없는 추상화 계층은 무엇입니까? 쉬운 일이 아닙니다.

결론 : 응용 프로그램에 Spring과 Hibernate를 소개 할 수 있습니다. 특히 응용 프로그램이 큰 경우에는 지루하고 고통스럽고 시간이 오래 걸릴 것입니다.

+0

응답 해 주셔서 감사합니다. – ikvenu2000

+0

@ ikvenu2000 : 그런데 왜 어떤 대답을 수락하지 않았습니까? 당신은 1 년 넘게 Stackoverflow에 있습니다. – darioo

0

응답 해 주셔서 감사합니다.

내 오래된 응용 프로그램 (JSP + EJB 2.1)은 큰 문제입니다. 시스템에서 몇 가지 개선 사항이 있습니다. 이제 우리에게는 2 가지 선택 사항이 있습니다.

  1. 은 기존 시스템을 교체하고 미래의 새로운 기능/개선 사항을 추가하는 것은 구현하는 데 시간이 덜 소요되도록 규칙 엔진과 최신 프레임 워크 더 모듈 식 시스템을 개발한다. 거의 새로운 시스템으로 이전 시스템을 마이그레이션하는 데 1 년이 소요됩니다.

  2. 봄, 최대 절전, 규칙 엔진 등과 같은 최신 프레임 워크를 사용하여 기존 시스템에 기능을 추가하고 시간/예산에 따라 오래된 기술을 새로운 기술 플랫폼으로 천천히 마이그레이션하십시오. (이것이 기술적으로 효과가 있을지 확신하지 못합니다).

이제 더 많은 정보가 있었으므로 계속 진행하는 것이 가장 좋습니다.

관련 문제