Sping MVC入門(通俗易懂)

前言:總結一下之前Spring MVC的基礎知識,寫出博客分享出來。總的來說也就是這幾個知識點:HelloWorld例子,視圖定位,接收表單,中文。多的就不說了,知識點一點點學習理解。
首先了解SpringMVC是什麼:springmvc是spring框架的一個模塊,基於MVC的web框架,至於MVC示什麼這裏就不說了,簡單品一品就行,理解成做web的一個spring模塊就像。
現在我們寫個HelloWorld例子感受下SpringMVC,後面我們一步步解釋。
1、新建一個web項目,導入SpringMVC的核心依賴包。
傳送門:ssm的jar包

2、在WEB-INF目錄下創建 web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
	<servlet>
		<servlet-name>springmvc</servlet-name>
		<servlet-class>
			org.springframework.web.servlet.DispatcherServlet
		</servlet-class>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>springmvc</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>
</web-app>

3、創建Spring MVC的配置文件,springmvc-servlet.xml

<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="
   http://www.springframework.org/schema/beans     
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
   http://www.springframework.org/schema/context 
   http://www.springframework.org/schema/context/spring-context-3.0.xsd">

   <context:component-scan base-package="com.java.controller" />

   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
      <property name="prefix" value="/WEB-INF/jsp/" />
      <property name="suffix" value=".jsp" />
   </bean>

</beans>

4、在com.java.controller包下創建HelloController.java

package com.java.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.ui.ModelMap;
@Controller
@RequestMapping("")
public class HelloController{ 
   @RequestMapping("/hello")
   public String Hello(ModelMap model) {
      model.addAttribute("message", "Hello Spring MVC !");
      return "hello";
   }
}

5、在WEB-INF/jsp文件夾下創建hello.jsp頁面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8" isELIgnored="false"%>
<html>
<head>
<title>Hello World</title>
</head>
<body>
   <h1>${message}</h1>
</body>
</html>

這樣一個簡單的MVC例子就完成了。web做的事就是配置Spring MVC的入口 DispatcherServlet,把所有的請求都提交到該Servlet。然後Spring mvc的配置文件中做的事就是,掃描包下面的java文件:

  <context:component-scan base-package="com.java.controller" />

視圖定位,就是定位到WEB-INF/jsp下面以.jsp文件

 <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
      <property name="prefix" value="/WEB-INF/jsp/" />
      <property name="suffix" value=".jsp" />
   </bean>

當用戶訪問@RequestMapping後面的這個地址的時候(和return的值不是同一個,這個是訪問地址,那個是訪問的文件名稱),就會訪問以return返回的名稱爲jsp文件名稱的jsp文件。比如你的jsp文件是hello.jsp,那就return “hello”。
接下來就是如何接收表單數據了:
1、在上面的基礎,修改hello.jsp,當然我們也可以重新寫一個提交頁面,我只是爲了連貫之前的東西。這裏的form表單裏面的action提交的路徑就是我們後面controller裏面方法的映射地址,就是@RequestMapping後面的值

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8" isELIgnored="false"%>
<html>
<head>
<title>Hello World</title>
</head>
<body>
   <form action="add" method="post">
 
    賬號 :<input type="text" name="name" value=""><br />
    密碼 : <input type="password" name="password" value=""><br />
 
    <input type="submit" value="登錄">
</form>
</body>
</html>

2、在com.java.model下添加一個用戶類User.java

package com.java.model;

public class User {
    private int id; // 用戶 id
    private String name; // 用戶名
    private String password; // 用戶密碼

    public User() {
        super();
    }
    public User(String name, String password) {
        super();
        this.name = name;
        this.password = password;
    }

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    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;
    }

    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + ", password=" + password + "]";
    }
}

3、修改HelloController,寫一個提交數據後返回到新頁面,在新頁面中我們會顯示提交的數據。

package com.java.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.ui.ModelMap;
@Controller
@RequestMapping("")
public class HelloController{ 
   @RequestMapping("/hello")
   public String Hello(ModelMap model) {
      return "hello";
   }

	@RequestMapping(value=/add”,method = RequestMethod.POST)
   public String addUser(User user, 
   ModelMap model) {
      model.addAttribute("name", User.getName());
      model.addAttribute("password", User.getPassword());   
      return "result";
   }
}

4、創建result.jsp界面,返回頁面,也就是在controller裏面寫的addUser方法所放回的頁面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8" isELIgnored="false"%>
<html>
<head>
<title>Hello World</title>
</head>
<body>
賬號: ${name}</br>
密碼: ${password}
</body>
</html>

但是提交表單數據這裏就有一個問題,那就是提交的是中文的問題,這就需要添加中文的依賴了

<filter> 
	<filter-name>CharacterEncodingFilter</filter-name> 
	   <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> 
	   <init-param> 
	       <param-name>encoding</param-name> 
	       <param-value>utf-8</param-value> 
	   </init-param> 
</filter> 
<filter-mapping> 
	   <filter-name>CharacterEncodingFilter</filter-name> 
	   <url-pattern>/*</url-pattern> 
</filter-mapping>   

以上就是SpringMVC的一些簡單的操作,不怎麼齊全,但是知識,慢慢了解就行了,如果有什麼地方錯了也請各位大佬指點指點,這只是單純我自己學習的總結而已!!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章