01-Java Web——JSP+Servlet+JavaBean開發模式
01-Java Web——JSP+Servlet+JavaBean開發模式
前言:在Struts1出現之前曾經有這麼一種開發模式風靡整個Java Web界,這就是JSP+Servlet+JavaBean的模式。
分析:由Servlet來接收客戶端傳送過來的請求,Servlet中只包含控制邏輯和簡單的前端處理;控制邏輯部分交給Java Bean來完成,其實這也是很有道理的,畢竟前期Java Bean只用來跟資料庫進行簡單的互動,互動完之後又傳給JSP進一步處理,為啥不讓Java Bean直接進行邏輯處理呢。Java Bean完成了複雜的邏輯處理之後,最後將結果給JSP進行展示。這時候分工很明確了,JSP只負責顯示邏輯的部分。這就是非常經典的Java Bean+JSP+Servlet(MVC),這也就是著名的MVC設計模式。由於Model 2 引入了MVC模式,實現了元件化的管理,因此也具有了更好地擴充套件性。
雖然現在已經很少人這麼開發了,但是為了更好地跟之後的Spring MVC進行對比,這裡也說明一下此設計的專案構建過程(此處我以Maven為例進行專案構建,雖然在Maven出現之前大家都是將Jar包放在專案的lib目錄下實現的):
第一步:
建立Maven專案(此處以STS開發環境為例子)
選擇Create a simple project,點選“Next”
填寫專案名等內容,點選“Finish”(此處注意打包方式選擇“war”)
第二步:新增依賴,編寫pom檔案
修改完POM檔案後需要執行右鍵maven->updateproject
(若不知道如何新增依賴的請參考Maven入門實戰(一)
https://blog.csdn.net/vander1991/article/details/78988568)
pom檔案具體內容:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.cmit</groupId> <artifactId>mvc-demo-1</artifactId> <version>0.0.1-SNAPSHOT</version> <name>mvc-demo-1</name> <description>mvc-demo-1</description> <packaging>war</packaging> <dependencies> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> </dependencies> <build> <!-- 配置了很多外掛 --> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>2.3.2</version> <configuration> <source>1.8</source> <target>1.8</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build> </project>
第三步:新增web.xml檔案到webapp/WEB-INF目錄
web.xml檔案的具體內容:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>Hello World</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<servlet>
<description></description>
<display-name>HelloServlet</display-name>
<servlet-name>HelloServlet</servlet-name>
<servlet-class>com.cmit.HelloServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloServlet</servlet-name>
<url-pattern>/Hello</url-pattern>
</servlet-mapping>
</web-app>
第五步:編寫servlet檔案
Servlet具體內容如下:
package com.cmit;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class HelloServlet
*/
public class HelloServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* Default constructor.
*/
public HelloServlet() {
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
request.getRequestDispatcher("/hello.jsp").forward(request, response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}
第六步:編寫jsp檢視檔案
jsp具體內容如下:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>The First Example</title>
</head>
<body>
hello world
</body>
</html>
實現的效果如下:
最後獻上此次設計的原始碼,在此處出現的所有原始碼均有實現,有需要的小夥伴可以下載來執行一下,加深理解(當然是不需要積分的)。