JSP中的MVC開發模式

来源:https://www.cnblogs.com/yiidian/archive/2020/04/11/12677216.html
-Advertisement-
Play Games

原文鏈接:http://www.yiidian.com/jsp/jsp mvc model.html 1 什麼是MVC模式 MVC,代表模型(Model),視圖(View),控制器(Controller)。這是一種將業務邏輯,表現邏輯和數據分開的設計模式。 充當視圖和模型之間的介面。控制器攔截所有傳 ...


原文鏈接:http://www.yiidian.com/jsp/jsp-mvc-model.html

1 什麼是MVC模式

MVC,代表模型(Model),視圖(View),控制器(Controller)。這是一種將業務邏輯,表現邏輯和數據分開的設計模式。

控制器充當視圖和模型之間的介面。控制器攔截所有傳入的請求。

模型代表應用程式的狀態,即數據。它還可以具有業務邏輯。

視圖即UI(用戶界面)。

2 MVC(Model2)模式的優勢

多個視圖共用一個模型,大大提高代碼的可重用性。
易於維護的大型應用程式

file

3 MVC模式的示例

在下麵的示例中,我們使用Servlet作為控制器,使用JSP頁面作為視圖組件,使用Java Bean類作為模型。

3.1 編寫index.jsp

<%@ page language="java" contentType="text/html;charset=utf-8" %>
<html>
<html>
<head>
    <meta charset="utf-8">
    <title>一點教程網-JSP的MVC模式</title>
</head>
<body>

<form action="ControllerServlet" method="post">
    用戶名:<input type="text" name="name"><br>
    密碼:<input type="password" name="password"><br>
    <input type="submit" value="登錄">
</form>

</body>
</html>

3.2 編寫User實體類

package com.yiidian;

/**
 * 一點教程網 - http://www.yiidian.com
 */
public class User {
    private String name;
    private String password;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public boolean validate(){
        if(password.equals("admin")){
            return true;
        }
        else{
            return false;
        }
    }
}

3.3 編寫ControllerServlet

package com.yiidian;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * 一點教程網 - http://www.yiidian.com
 */
public class ControllerServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out=response.getWriter();

        String name=request.getParameter("name");
        String password=request.getParameter("password");

        User bean=new User();
        bean.setName(name);
        bean.setPassword(password);
        request.setAttribute("bean",bean);

        boolean status=bean.validate();

        if(status){
            RequestDispatcher rd=request.getRequestDispatcher("login-success.jsp");
            rd.forward(request, response);
        }
        else{
            RequestDispatcher rd=request.getRequestDispatcher("login-error.jsp");
            rd.forward(request, response);
        }

    }

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        doPost(req, resp);
    }
}

3.4 編寫login-success.jsp

<%@ page  import="com.yiidian.User" contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>一點教程網-JSP的MVC模式</title>
</head>
<body>
<p>你已經成功登錄</p>

<%
    User bean=(User) request.getAttribute("bean");
    out.print("歡迎你, "+bean.getName());
%>

</body>
</html>

3.5 編寫login-error.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>一點教程網-JSP的MVC模式</title>
</head>
<body>
<p>抱歉! 用戶名或密碼錯誤</p>
<form action="ControllerServlet" method="post">
    用戶名:<input type="text" name="name"><br>
    密碼:<input type="password" name="password"><br>
    <input type="submit" value="登錄">
</form>
</body>
</html>

3.6 配置web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">

    <servlet>
        <servlet-name>ControllerServlet</servlet-name>
        <servlet-class>com.yiidian.ControllerServlet</servlet-class>
    </servlet>

    <servlet-mapping>
        <servlet-name>ControllerServlet</servlet-name>
        <url-pattern>/ControllerServlet</url-pattern>
    </servlet-mapping>

</web-app>

3.7 運行測試

file

輸入錯誤的密碼,顯示如下:

file

輸入正確的密碼(admin),顯示如下:

file

file

歡迎關註我的公眾號::一點教程。獲得獨家整理的學習資源和日常乾貨推送。
如果您對我的系列教程感興趣,也可以關註我的網站:yiidian.com


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天有群友提出這樣一個問題: ajax請求成功後,然後彈窗提示用戶,接著刷新頁面。結果彈窗一閃而逝,頁面就刷新了,提示的信息用戶都來不及看到。 這樣的問題我之前也用到過,我的解決方法如下: 重點代碼如下: setTimeout(function () { location.href = "www.b ...
  • 通過定位實現二級菜單: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <tit ...
  • 安裝Vuefity的時候,碰到一些坑,經過一番折騰,終於成功,記錄正確的姿勢如下: 創建一個Vue項目: vue init webpack-simple vular-admin 進入項目目錄: cd vular-admin 選擇:Webpack 安裝方式 npm install npm instal ...
  • 一、什麼是Web前端開發? Web前端簡單理解為搭建網頁,也就是通過瀏覽器的方式打開某個網頁,像平時我們打開的一些網頁,比如京東,網易,蘇寧,愛奇藝等,只要是以網頁的形式給大家展示的,都離不開web前端移動開發。 1、更深層次的理解就是,web前端具備三種形式:結構(Html),表現(Css),行為 ...
  • 寫在前面 寫【高併發專題】有一段時間了,一些讀者朋友留言說,併發編程很難,學習了很多的知識,但是在實際工作中卻無從下手。對於一個線上產生的併發問題,又不知產生這個問題的原因究竟是什麼。對於併發編程,感覺上似乎是掌握了,但是真正用起來卻不是那麼回事! 其實,造成這種現象的本質原因就是沒有透徹的理解併發 ...
  • 面向對象(OOP)的理解 喜歡程式的朋友們,大家應該都聽過一句話“萬物皆對象”,感覺老牛X了。 面向對象的程式設計,它是圍繞真實世界來設計程式的。 面向對象三要素:封裝、繼承、多態。 我們可以定義一個類,用來表示小轎車,並且定義小轎車的一些屬性跟行為。然而現實中,有很多種類的車,有公交車、貨車、出租 ...
  • 本文介紹了高德地圖中POI深度信息接入在平臺化過程中的一些思考和實踐,從最開始的單體應用,隨著業務發展面臨挑戰,從業務角度提出解決問題的思路和方案,進而轉化成技術設計並落地實現的過程。 ...
  • 源代碼地址 通過對於鬥羅大陸小說的游戲化過程,熟悉Angular的結構以及使用TypeScript的面向對象開發方法。 "Github項目源代碼地址" 線上體驗網址(推薦使用移動設備訪問) http://datavisualization.club:8888/ 極簡游戲攻略 除了劇情對話之外,本游戲 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...