간단히 이해되는 Java 프레임워크는 재사용 가능한 디자인 구성 요소로, 애플리케이션 아키텍처를 규정하고 전체 디자인과 협업 구성 요소 간의 종속성, 책임 분배 및 제어 흐름을 명확하게 하며 일련의 추상 클래스와 A 메소드로 표현됩니다. 구성요소 재사용을 위한 컨텍스트 관계를 제공하는 인스턴스 간의 협업입니다.
일반적으로 사용되는 Java 프레임워크는 무엇입니까?
Struts, Hibernate 및 Spring은 Java 개발에서 일반적으로 사용되는 프레임워크입니다. 이들은 다양한 애플리케이션 시나리오에 가장 적합한 솔루션을 제공합니다. 그런데 이 유명한 프레임워크가 원래 어떻게 만들어졌는지 아시나요?
우리는 전통적인 Java 웹 애플리케이션이 JSP+Servlet+Javabean을 사용하여 구현된다는 것을 알고 있습니다. 이 모델은 가장 기본적인 MVC 계층화를 구현하여 프로그램 구조를 여러 개로 나눕니다. 프론트 엔드 디스플레이를 담당하는 JSP, 프로세스 로직 제어를 담당하는 서블릿, 데이터 캡슐화를 담당하는 Javabean을 포함한 계층. 그러나 이 구조에는 여전히 문제가 있습니다. 예를 들어 JSP 페이지는 많은 Java 코드를 포함하기 위해 기호를 사용해야 합니다. , 결과적으로 혼란스러운 페이지 구조가 발생합니다. 서블릿과 Javabean은 많은 수의 점프 및 작업, 긴밀한 결합, 낮은 프로그램 재사용성 등을 담당합니다.
이런 문제를 해결하기 위해 완벽한 MVC 구현인 Struts 프레임워크가 등장했습니다. 여기에는 중앙 제어 클래스(서블릿)가 있으며 다양한 비즈니스에는 페이지 점프 및 백그라운드 로직 작업을 담당하는 Action 클래스가 필요합니다. , 하나 이상의 JSP 페이지는 데이터의 입력 및 출력 표시를 담당하고 Form 클래스는 Action과 JSP 간의 데이터 전송을 담당합니다. Struts 프레임워크에서 제공하는 태그 세트를 JSP에서 사용할 수 있는데 이는 HTML 태그를 사용하는 것만큼 간단하지만 매우 복잡한 논리를 완성할 수 있습니다. 이제부터는 JSP 페이지에서 주변 Java 코드 줄을 가질 필요가 없습니다.
그러나 모든 작업 로직을 Struts의 Action에 넣으면 Action 클래스의 재사용성이 떨어지고 로직이 혼란스러워지므로 일반적으로 사람들은 전체 웹 애플리케이션을 세 개의 레이어로 나누는데, Struts는 비즈니스 레이어라고 불리는 디스플레이 레이어를 담당합니다. 작업 논리를 완료하기 위해 비즈니스 계층은 지속성 계층을 호출하여 데이터베이스 읽기 및 쓰기를 완료합니다. JDBC 연결을 사용하여 데이터베이스를 읽고 씁니다. 가장 일반적인 작업은 데이터베이스 연결을 열고, 복잡한 SQL 문을 사용하여 읽고 쓰고, 얻은 데이터를 변환하거나 캡슐화하는 것입니다. 이는 매우 번거로운 과정입니다. 이때 등장하는 Hibernate 프레임워크는 일련의 지속성 클래스를 생성해야 합니다. 각 클래스의 속성은 단순히 데이터베이스 테이블의 속성과 일대일 대응으로 간주할 수 있습니다. 물론 다양한 측면이 있습니다. 관계형 데이터베이스의 대응도 구현할 수 있습니다. 관련 작업이 필요할 때 더 이상 데이터베이스 테이블에 주의를 기울일 필요가 없습니다. 더 이상 데이터베이스를 한 줄씩 쿼리할 필요가 없으며 추가, 삭제, 수정 및 쿼리 기능을 완료하기 위해 지속성 클래스만 필요합니다. 우리의 소프트웨어 개발을 지저분한 코드 지향이 아닌 진정한 객체 지향으로 만드십시오. 내 느낌으로는 Hibernate를 사용하면 JDBC에 비해 프로그래밍 양이 80% 줄어든다는 것입니다. 이제 세 개의 레이어가 있는데 각 레이어 사이의 호출은 무엇입니까? 예를 들어 디스플레이 레이어의 Struts가 비즈니스 클래스를 호출해야 한다면 비즈니스 레이어에 필요한 새 비즈니스 클래스를 생성해야 합니다. 지속성 레이어를 호출하려면 사용할 새로운 지속성 레이어 클래스도 필요합니다. 이 새로운 방식으로 서로를 부르는 것은 소프트웨어 개발에서 최악의 디자인을 구현한 것이다. 간단히 말하면, 호출자는 호출 수신자에 의존하고 그들 사이에는 강한 결합이 형성됩니다. 클래스를 다른 곳에서 재사용하려면 이 클래스가 의존하는 다른 클래스도 포함되어야 합니다. 프로그램이 매우 혼란스러워지고 각 클래스는 서로 의존하고 서로 호출하며 재사용 정도가 매우 낮습니다. 클래스가 수정되면 해당 클래스에 의존하는 많은 클래스가 영향을 받습니다. 이를 위해 Spring 프레임워크가 나타납니다. Spring의 역할은 클래스 간의 종속성을 완전히 분리하는 것입니다. 클래스가 무언가에 의존한다면 그것은 인터페이스입니다. 이 인터페이스를 구현하는 방법은 중요하지 않습니다. 이 인터페이스를 구현하는 클래스만 있으면 xml 구성 파일을 통해 인터페이스를 호출하는 클래스에 구현 클래스를 쉽게 삽입할 수 있습니다. 모든 클래스 간의 이러한 종속성은 구성 파일로 완전히 대체됩니다. 따라서 Spring 프레임워크의 핵심은 소위 종속성 주입 및 제어 반전입니다. 현재 구조는 Struts가 디스플레이 계층을 담당하고, Hibernate가 지속성 계층을 담당하고, Spring이 중간 비즈니스 계층을 담당하는 구조입니다. 이 구조는 현재 중국에서 가장 널리 사용되는 Java 웹 애플리케이션 아키텍처입니다. 또한 Spring은 종속성 주입과 AOP(관점 지향 프로그래밍)를 사용하므로 내부 모델이 매우 우수하여 Spring 자체에서도 Spring MVC라는 종속성 주입을 사용하는 MVC 프레임워크를 구현했습니다. Spring은 Hibernate의 지속성 계층에서 비즈니스 계층으로 사물 관리를 향상시켜 사용하기 더 편리하고 강력하게 만드는 Hibernate를 통합합니다.위 내용은 자바 프레임워크의 용도는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!