Heim  >  Artikel  >  Java  >  Eine kurze Einführung in Web MVC in Java

Eine kurze Einführung in Web MVC in Java

巴扎黑
巴扎黑Original
2017-09-06 09:36:081298Durchsuche

Das MVC-Modell ist ein Architekturmodell, das selbst keine neuen Funktionen einführt. Es hilft uns lediglich, die Entwicklungsstruktur sinnvoller zu organisieren, um die Anzeige und das Modell, die Prozesssteuerungslogik, den Geschäftslogikaufruf und die Anzeigelogik zu trennen 🎜 >

Request-Response-Modell in der Webentwicklung:

In der Webwelt sind die spezifischen Schritte wie folgt:

1 , ein Webbrowser (z. B. IE) initiiert eine Anfrage.

2. Der Webserver (z. B. Tomcat) empfängt die Anfrage, verarbeitet die Anfrage (wenn beispielsweise ein Benutzer hinzugefügt wird, wird der Benutzer gespeichert) und generiert schließlich eine Antwort (normalerweise HTML).

3. Nachdem der Webserver die Verarbeitung abgeschlossen hat, gibt er den Inhalt an den Web-Client (normalerweise unseren Browser) zurück und der Client verarbeitet den empfangenen Inhalt (z. B. verarbeitet der Webbrowser die empfangene HTML-Inhaltswiedergabe). Kunden zeigen).

Deshalb gilt in der Web-Welt:

Es ist der Web-Client, der die Anfrage initiiert, und der Webserver empfängt, verarbeitet und generiert eine Antwort.

Im Allgemeinen können Webserver Web-Clients nicht proaktiv benachrichtigen, Inhalte zu aktualisieren. Obwohl es derzeit einige Technologien wie Server Push (wie Comet) und den aktuellen HTML5-Websocket gibt, kann der Webserver den Webclient aktiv benachrichtigen.

Jetzt verstehen wir das Anfrage-/Antwortmodell in der Webentwicklung. Als nächstes werfen wir einen Blick auf das Standard-MVC-Modell.

Überblick über das Standard-MVC-Modell

MVC-Modell: Es handelt sich um ein Architekturmuster, das selbst keine neuen Funktionen einführt, sondern uns nur hilft zu entwickeln Die Struktur ist sinnvoller organisiert, um die Anzeige vom Modell, der Prozesssteuerungslogik, dem Geschäftslogikaufruf und der Anzeigelogik zu trennen. Wie in Abbildung 1-2 gezeigt

Abbildung 1-2

Lassen Sie uns zunächst das Konzept des MVC-Triples (Model-View-Controller) verstehen:

Modell (Modell): Das Datenmodell stellt die anzuzeigenden Daten bereit und enthält daher Daten und Verhalten. Es kann als Domänenmodell oder JavaBean-Komponente (mit Daten und Verhalten) betrachtet werden, ist jedoch jetzt im Allgemeinen getrennt : ValueObject (Daten) und Serviceschicht (Verhalten). Das heißt, das Modell bietet Funktionen wie Modelldatenabfrage und Modelldatenstatusaktualisierung, einschließlich Daten und Geschäft.

Ansicht: Verantwortlich für die Anzeige des Modells, normalerweise der Benutzeroberfläche, die wir sehen und was Kunden sehen möchten.

Controller (Controller): Empfängt Benutzeranforderungen, delegiert sie zur Verarbeitung (Statusänderung) an das Modell und gibt die zurückgegebenen Modelldaten nach der Verarbeitung an die Ansicht zurück. Die Ansicht ist für deren Anzeige verantwortlich. Mit anderen Worten: Der Controller übernimmt die Aufgabe eines Dispatchers.

Aus Abbildung 1-1 sehen wir auch, dass das Modell im Standard-MVC aktiv Daten zur Aktualisierung an die Ansicht übertragen kann (Beobachter-Entwurfsmuster), die Ansicht am Modell registrieren und die Ansicht automatisch aktualisieren kann, wenn das Modell vorhanden ist aktualisiert), aber in der Webentwicklung kann das Modell nicht aktiv an die Ansicht gepusht werden (die Benutzeroberfläche kann nicht aktiv aktualisiert werden), da es sich bei der Webentwicklung um ein Anforderungs-Antwort-Modell handelt.

Dann werfen wir einen Blick darauf, wie MVC im Web aussieht. Wir nennen es WebMVC, um es vom Standard-MVC zu unterscheiden.

WebMVC-Übersicht

Das Model-View-Controller-Konzept ist das gleiche wie das Standard-MVC-Konzept, siehe 1.2, nehmen wir ein Schauen Sie sich die WebMVC-Standardarchitektur an, Abbildung 1-3:

Abbildung 1-3

Im WebMVC-Modus kann das Modell Daten nicht aktiv in die Ansicht verschieben Wenn der Benutzer die Ansicht aktualisieren möchte, muss eine weitere Anfrage gesendet werden (dh das Anfrage-Antwort-Modell).

Das Konzept ist fast da. Lassen Sie uns etwas über den Entwicklungsprozess der Website-Entwicklung lernen und anhand von Code demonstrieren, wie WebMVC implementiert wird.

Entwicklungsgeschichte der Webentwicklung

Hier beschreiben wir kurz den Kernprozess, wie in Abbildung 1-4 dargestellt

Abbildung 1-4

CGI: (CommonGatewayInterface) Common Gateway Interface, eine auf dem Webserver verwendete Skripttechnologie, geschrieben in C oder Perl, zum Empfangen von Webbenutzeranfragen und Verarbeiten Sie sie und generieren Sie schließlich dynamisch eine Antwort an den Benutzer. Jede Anforderung generiert jedoch einen Prozess, der schwer ist.

Servlet: eine JavaEE-Webkomponententechnologie, eine serverseitig ausgeführte Webkomponente, die zum Empfangen und Verarbeiten von Webbenutzeranforderungen und schließlich zum dynamischen Generieren einer Antwort an den Benutzer verwendet wird. Jede Anfrage generiert jedoch nur einen Thread (und es gibt einen Thread-Pool), was leichtgewichtig ist. Und kann viele JavaEE-Technologien (wie JDBC usw.) nutzen. Die Essenz besteht darin, den HTML-Stream im Java-Code auszugeben. Die Aufrufe der Präsentationslogik, der Steuerlogik und der Geschäftslogik sind jedoch gemischt. Wie in Abbildung 1-5 gezeigt

Abbildung 1-5

Wie in Abbildung 1-5 gezeigt, ist dieser Ansatz absolut unerwünscht, wenn Steuerlogik, Präsentationscode und Geschäftslogikobjektaufrufe miteinander vermischt werden Das größte Problem besteht darin, HTML direkt in Java-Code auszugeben, sodass Front-End-Entwickler den Seitenstil usw. nicht entwerfen und ändern können. Selbst Änderungen sind sehr mühsam, daher ist dieser Ansatz in tatsächlichen Projekten nicht ratsam.

JSP: (JavaServerPage): Eine auf der Serverseite ausgeführte Webkomponente. Dabei handelt es sich um eine Vorlagenseitentechnologie, die in einer Standard-HTML-Seite mit einer darin eingebetteten Skriptsprache ausgeführt wird (unterstützt derzeit nur Java). Die Essenz besteht darin, Java-Code in HTML-Code einzubetten. JSP wird schließlich in ein Servlet kompiliert, aber das ist einfacher und bequemer als die Entwicklung einer reinen Servlet-Seite. Aber Präsentationslogik, Kontrolllogik und Geschäftslogikaufrufe sind immer noch gemischt. Wie in Abbildung 1-6 gezeigt

Abbildung 1-6

Abbildung 1-6, ist dieser Ansatz absolut nicht ratsam, Steuerlogik, Leistungscode, Geschäftslogik-Objektaufrufe werden gemischt, aber es ist besser, als HTML direkt im Servlet auszugeben. Front-End-Entwickler können einfache Seitenstile entwerfen und ändern (es ist jedoch schwierig, sie zu ändern, wenn zu viele eingebettete Java-Skripte vorhanden sind). Für konkrete Projekte ist dieser Ansatz nicht empfehlenswert.

Die Essenz von JSP ist immer noch Servlet. Schließlich wird zur Laufzeit ein Servlet generiert (z. B. Tomcat, das unter dem TomcatworkCatalinaweb-Anwendungsnamen orgapachejsp generiert wird), aber Dies macht das Schreiben von HTML einfacher, aber die Steuerlogik, der Präsentationscode und die Geschäftslogik-Objektaufrufe sind immer noch miteinander vermischt.

Modell 1: Es kann als erweiterte Version von JSP betrachtet werden, es kann als JSP + Javabean betrachtet werden, wie in Abbildung 1-7 gezeigt

Funktionen: Verwenden Sie die Standardaktion jsp:useBean automatisch Kapseln Sie Anforderungsparameter in JavaBean-Komponenten. Sie müssen auch Java-Skript verwenden, um die Steuerlogik auszuführen.

Abbildung 1-7

Hier können wir sehen, dass die Verwendung der Standardaktion jsp:useBean die Erfassung/Erstellung von Javabeans und die Anforderungsparameter Encapsulate vereinfachen kann Fügen Sie es in Javabean ein und werfen Sie einen Blick auf die Model1-Architektur, wie in Abbildung 1-8 dargestellt.

Abbildung 1-8 Model1-Architektur

In der Model1-Architektur ist JSP für die Steuerlogik, Präsentationslogik und Aufrufe von Geschäftsobjekten (Javabeans) verantwortlich. , was nur effizienter ist als reines JSP Vereinfachtes Abrufen von Anforderungsparametern und Kapseln von Anforderungsparametern. Es ist außerdem schlecht und sollte in Projekten (höchstens in Demos) nicht verwendet werden.

Modell2: In der JavaEE-Welt kann man es sich als das WebMVC-Modell vorstellen.

Die Modell2-Architektur kann man sich tatsächlich als das vorstellen, was wir das WebMVC-Modell nennen, mit der Ausnahme, dass der Controller Servlet verwendet. Das Modell verwendet JavaBean und die Ansicht verwendet JSP, wie in Abbildung 1-9 dargestellt

Abbildung 1-9 Model2-Architektur

Die spezifischen Codebeispiele sind wie folgt:

Wie aus der Model2-Architektur ersichtlich ist, sind die Ansicht und das Modell gleich getrennt, und die Steuerlogik und die Anzeigelogik sind getrennt.

Aber wir sehen auch gravierende Mängel:

Controller:

1. Die Steuerungslogik kann tatsächlich kompliziert sein Wenn beispielsweise der Anforderungsparameter subscribeFlag = toAdd ist, können wir die toAdd-Methode tatsächlich direkt aufrufen. 2. Um die Steuerlogik zu vereinfachen, ist für jedes Modul grundsätzlich ein Controller erforderlich, sodass die Steuerlogik möglicherweise kompliziert ist >3. Das Anfordern von Parametern für die Modellkapselung ist mühsam. Wenn wir dies dem Framework überlassen können, können wir die nächste Ansicht auswählen und uns stark auf ServletAPI verlassen oder fast unmöglich, die Ansicht zu ändern;

5. Die Verwendung von ServletAPI erfordert auch eine Änderung der Ansichtstechnologie, was sehr mühsam ist.

1 Modell:

Das Modell hier verwendet JavaBean, was dazu führen kann, dass die JavaBean-Komponentenklasse sehr groß ist. Im Allgemeinen verwenden Projekte jetzt eine dreistufige Architektur anstelle von JavaBean.

Ansicht

ist jetzt an JSP gebunden und es ist schwierig, Ansichten wie Velocity und FreeMarker zu ändern. Ich möchte beispielsweise Excel- und PDF-Ansichten unterstützen , usw.

Dienst für den Arbeiter: FrontController+ApplicationController+PageController+Context

Das heißt, Front-End-Controller + Anwendungscontroller + Seitencontroller (auch Aktion genannt) + Kontext, der auch WebMVC ist Nur dass die Verantwortlichkeiten klarer sind, wie in Abbildung 1-10 dargestellt:

Abbildung 1-10

Der Vorgang ist wie folgt:

Verantwortlichkeiten:

FrontController: Front-End-Controller, verantwortlich für die Bereitstellung eines einheitlichen Zugriffspunkts für die Präsentationsschicht, wodurch doppelte Steuerlogik vermieden wird Das erscheint in Model2 (einheitlicher Rückruf durch den Front-End-Controller. Entsprechende funktionale Methoden, z. B. die vorherige Anmeldemethode gemäß „submitFlag=login“) und können eine gemeinsame Logik für mehrere Anforderungen bereitstellen (z. B. Vorbereitung des Kontexts usw.). Auswahl bestimmter Ansichten und spezifische funktionale Verarbeitung (z. B. Kapselung von Anforderungen bei der Anmeldung, Parameter für das Modell und Aufruf von Geschäftslogikobjekten) sind getrennt.

ApplicationController: Nachdem der Front-End-Controller bestimmte Ansichten und bestimmte Funktionen getrennt und ausgewählt hat, muss jemand sie verwalten. Der Anwendungscontroller wird verwendet, um bestimmte Ansichtstechnologien (Ansichtsverwaltung) und bestimmte Funktionen auszuwählen. Die Verarbeitung (Seitencontroller/Befehlsobjekt/Aktionsverwaltung), eine Anwendung strategischer Entwurfsmuster, kann problemlos Ansichten/Seitencontroller wechseln, ohne sich gegenseitig zu beeinflussen.

PageController(Befehl): Seitencontroller/Aktion/Prozessor: Funktionsverarbeitungscode, Parameter sammeln, Parameter in das Modell kapseln, Geschäftsobjektverarbeitungsmodell übertragen, den logischen Ansichtsnamen an den Front-End-Controller zurückgeben ( und Entkopplung der spezifischen Ansichtstechnologie) delegiert der Front-End-Controller an den Anwendungscontroller, um eine bestimmte Ansicht zur Anzeige auszuwählen, bei der es sich um die Implementierung des Befehlsentwurfsmusters handeln kann. Seitencontroller werden auch Handler oder Aktionen genannt.

Kontext: Kontext, erinnern Sie sich an die Modelldaten, die für die Ansicht in Model2 angezeigt werden sollen. Wir fügen sie direkt in die Anfrage ein (ServletAPI-bezogen). Mit dem Kontext können wir die relevanten Daten in den Kontext stellen. Daher Der Zugriff auf/das Festlegen von Modelldaten, die nichts mit dem Protokoll zu tun haben (z. B. ServletAPI), wird im Allgemeinen über den ThreadLocal-Modus implementiert.

An dieser Stelle haben wir den Entwicklungsverlauf der gesamten Webentwicklungsarchitektur überprüft. Verschiedene Web-Layer-Frameworks haben möglicherweise unterschiedliche Details, aber der Zweck ist derselbe:

Clean Web Präsentationsschicht:

Trennung von Modell und Ansicht;

Trennung von Steuerlogik und funktionaler Verarbeitung im Controller (Sammeln und Kapseln von Parametern in Modellobjekten und Geschäftsobjektaufrufen);

Die Ansichtsauswahl im Controller ist von der spezifischen Ansichtstechnologie getrennt.

Dünne Webpräsentationsschicht:

Je weniger Dinge Sie tun, desto besser, sie ist dünn und sollte keinen irrelevanten Code enthalten.

ist nur verantwortlich Sammeln und organisieren Sie Parameter in Modellobjekten und rufen Sie Geschäftsobjekte auf.

Der Controller gibt nur den logischen Ansichtsnamen zurück und der entsprechende Anwendungscontroller wählt die zu verwendende spezifische Ansichtsstrategie aus Verwenden Sie möglichst Framework-spezifische APIs, um ein einfaches Testen zu gewährleisten.

Das obige ist der detaillierte Inhalt vonEine kurze Einführung in Web MVC in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn