Привет всем, я Сяо Цай, Сяо Цай, который хочет быть Цай Буцаем в интернет-индустрии. Она может быть мягкой или жесткой, как она мягкая, а белая проституция жесткая!
Черт~ Не забудьте поставить мне тройку после прочтения!
"Эта статья в основном знакомит
SprinMVC
При необходимости вы можете обратиться к
Если это поможет, не забудьтеподобно❥Творить нелегко, проституция бессмысленна!
1. Обзор SpringMVC
- Превосходная веб-инфраструктура, основанная на концепции дизайна MVC, предоставленная Spring для уровня представления, в настоящее время является наиболее распространенной.
MVC
один из кадров - Комплексный после Spring 3.0
超越 Struts2
, стать лучшим фреймворком MVC - Spring MVC использует набор аннотаций MVC для создания
POJO
Будьте контроллером, который обрабатывает запрос без реализации какого-либо интерфейса. - служба поддержки
REST
стилизованный URL-запрос - Усыновленный
松散耦合可插拔
Структура компонентов, более расширяемая и гибкая, чем другие среды MVC.
2. Простое использование SpringMVC
1) Настройте DispatcherServlet в web.xml:
<!-- 配置 DispatcherServlet -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 -->
<!--
实际上也可以不通过 contextConfigLocation 来配置 SpringMVC 的配置文件, 而使用默认的.
默认的配置文件为: /WEB-INF/<servlet-name>-servlet.xml
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
2) Добавьте файл конфигурации Spring MVC
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
<!-- 配置自定扫描的包 -->
<context:component-scan base-package="cbuc.life.springmvc"></context:component-scan>
<!-- 配置视图解析器: 如何把 handler 方法返回值解析为实际的物理视图 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
3) Напишите обработчик, который обрабатывает запрос, и используйте@ControllerАннотация идентифицируется как процессор
@Controller
public class HelloWorldController {
/**
1. 使用 @RequestMapping 注解来映射请求的 URL
2. 返回值会通过视图解析器解析为实际的物理视图, 对于 InternalResourceViewResolver 视图解析器, 会做如下的解析:
通过 prefix + returnVal + 后缀 这样的方式得到实际的物理视图, 然会做转发操作
==> /WEB-INF/views/success.jsp
*/
@RequestMapping("/helloworld")
public String hello(){
System.out.println("hello world");
return "success";
}
}
4) Напишите представление JSP
Создайте файл success.jsp в каталоге /WEB-INF/views/
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<!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=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>成功跳转页面</h1>
</body>
</html>
5) Запустите проект и посетите: localhost:8080/hellowoorld
3. Используйте @RequestMapping для сопоставления запросов
- Использование Spring MVC
@RequestMapping
Аннотации указывают, какие URL-запросы может обрабатывать контроллер. - в контроллере
类
Определение и方法
Определения могут быть отмечены- определение класса: Предоставляет предварительную информацию о сопоставлении запросов. Относительно корневого каталога веб-приложения
- метод: Предоставляет дополнительную информацию о сопоставлении сегментов. Относительно URL-адреса в определении класса. Если @RequestMapping не отмечен в определении класса, URL-адрес, отмеченный в методе, относится к «корневому каталогу веб-приложения».
-
DispatcherServlet
После того, как запрос перехвачен, он передается на контроллер@RequestMapping
Предоставленная информация об отображении определяет соответствующий метод обработки запроса.
1) Стандартные заголовки запроса
2) @RequestMapping
@RequestMappingvalue,method,paramsа такжеheadsСоответственноURL-адрес запроса,метод запроса,параметры запросаа такжеУсловия сопоставления для заголовков запроса, между нимиа такжеотношения, а использование нескольких условий в сочетании может сделать сопоставление запросов более точным.
/**
* 可以使用 params 和 headers 来更加精确的映射请求. params 和 headers 支持简单的表达式.
*
* @return
*/
@RequestMapping(value = "testParamsAndHeaders",
params = { "username","age!=10" },
headers = { "Accept-Language=en-US,zh;q=0.8" },
method = RequestMethod.POST)
public String test() {
System.out.println("test...");
return "success";
}
3) Поддержка стиля муравья
-
?
: соответствует символу в имени файла
/user/createUser?
соответствует /user/createUseraили пользователь/создать пользователяbи т. д. URL-адрес
-
*
: соответствует любому символу в имени файла
/user/*/createUser
соответствует /пользователю/aaa/создать пользователя или /пользователь/bbbURL-адреса, такие как /createUser
-
**
: соответствует многослойным путям
/user/**/createUser
соответствует /user/createUser или /user/aaa/bbbURL-адреса, такие как /createUser
4. @PathVariable
Заполнитель для сопоставления привязок URL
- URL-адреса с заполнителями — это новая функция в Spring 3.0, которая является важной вехой в эволюции SpringMVC к целям REST.
- пройти через
@PathVariable
Вы можете привязать параметры-заполнители в URL-адресе к входным параметрам метода обработки контроллера: в URL-адресе{xxx}
заполнители могут быть@PathVariable("xxx")
Привязать к входному параметру метода операции.
/**
* @PathVariable 可以来映射 URL 中的占位符到目标方法的参数中.
*/
@RequestMapping("/testPathVariable/{id}")
public String test(@PathVariable("id") Integer id) {
System.out.println("id: " + id);
return "success";
}
5. Стиль ОТДЫХА
"
REST
: Изобразительное State Transfer. (Ресурс) Переход состояния уровня представления. Это одна из самых популярных архитектур программного обеспечения в Интернете. Он имеет четкую структуру, соответствует стандартам, прост для понимания и легко расширяется, поэтому его используют все больше и больше веб-сайтов.
Пример:
- /order/1 HTTP
GET
:получатьзапись заказа с id = 1 - /order/1 HTTP
DELETE
:удалятьзапись заказа с id = 1 - /order/1 HTTP
PUT
:возобновитьзапись заказа с id = 1 - /order HTTP
POST
:новыйзапись заказа
6. @RequestParam связывает значение параметра запроса
- Используйте @RequestParam во входном параметре метода обработки, чтобы передать параметры запроса в метод запроса.
-
value
:имя параметра -
required
: требуется или нет; по умолчанию true, что означает, что соответствующие параметры должны быть включены в параметры запроса, если нет, будет выброшено исключение
/**
* @RequestParam 来映射请求参数. value 值即请求参数的参数名 required 该参数是否必须. 默认为 true
* defaultValue 请求参数的默认值
*/
@RequestMapping(value = "/testRequestParam")
public String testRequestParam(
@RequestParam(value = "username") String username,
@RequestParam(value = "age", required = false, defaultValue = "0") int age) {
System.out.println("testRequestParam, username: " + username + ", age: " + age);
return "success";
}
7. @RequestHeader связывает значение атрибута заголовка запроса
/**
* 映射请求头信息 用法同 @RequestParam
*/
@RequestMapping("/testRequestHeader")
public String testRequestHeader(
@RequestHeader(value = "Accept-Language") String al) {
System.out.println("testRequestHeader, Accept-Language: " + al);
return "success";
}
8. @CookieValue связывает значение cookie в запросе
/**
* @CookieValue: 映射一个 Cookie 值. 属性同 @RequestParam
*/
@RequestMapping("/testCookieValue")
public String testCookieValue(@CookieValue("JSESSIONID") String sessionId) {
System.out.println("testCookieValue: sessionId: " + sessionId);
return "success";
}
Девять, значение параметра запроса привязки объекта POJO
/**
* Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配, 自动为该对象填充属性值。支持级联属性。
* 如:dept.deptId、dept.address.tel 等
*/
@RequestMapping("/testPojo")
public String testPojo(User user) {
System.out.println("testPojo: " + user);
return "success";
}
10. Параметры типа ServletAPI, которые может получить метод Handler в MVC
- HttpServletRequest
- HttpServletResponse
- HttpSession
- Writer
- java.security.Principal
- Locale
- InputStream
- OutputStream
- Reader
11. Обработка данных модели
1)ModelAndView
Если тип возвращаемого значения метода обработки — ModelAndView, тело метода может добавлять данные модели через этот объект.Посмотреть информацию, также содержитИнформация о данных модели.
2)Map 及 Model
ввод какorg.springframework.ui.Model,org.springframework.ui.ModelMapилиjava.uti.MapКогда метод обработки вернется, данные на карте будут автоматически добавлены в модель.
3)@SessionAttributes:
Постановка атрибута в модели дляHttpSessionчтобы это свойство можно было совместно использовать между несколькими запросами (отsessionдомен)
Если вы хотите совместно использовать определенные данные атрибута модели между несколькими запросами, вы можетеДобрыйотметить один на
@SessionAttributes
, Spring MVC временно сохранит соответствующие свойства в модели, чтобыHttpSession
середина.-
@SessionAttributes
В дополнение к указанию атрибутов, которые необходимо поместить в сеанс, через имя атрибута, вы также можете указать, какие атрибуты модели необходимо поместить в сеанс, через тип объекта атрибута модели.1)@SessionAttributes(types=User.class): преобразует все типы в неявной модели вUser.classатрибут сеанса
2)@SessionAttributes(значение={"пользователь1", "пользователь2"}): назовет объекты в неявной модели какuser1,user2атрибут сеанса
3)@SessionAttributes(types={User.class, Dept.class}): преобразует все типы в неявной модели вUser.class,Dept.classатрибут сеанса
4)@SessionAttributes(value={"user1", "user2"}, types={Dept.class}): назовет объекты в неявной модели какuser1,user2свойства и все типыDept.classатрибут сеанса
4)@ModelAttribute
После того, как входной параметр метода будет помечен аннотацией, объект входного параметра будет помещен в модель данных
12. @ModelAttribute
- использовать в определении метода
@ModelAttribute
Аннотация: Перед вызовом целевого метода обработки Spring MVC будет вызывать один за другим и помечать его на уровне метода.@ModelAttribute
Методы. - Используется перед параметрами метода
@ModelAttribute
аннотация: - Вы можете получить объект из данных неявной модели из неявного объекта, затем привязать параметры запроса к объекту, а затем передать входные параметры.
- Добавьте объект параметра метода в модель
Пример:
Тринадцать, представления и преобразователи представлений
- После того, как метод обработки запроса выполнен, он, наконец, возвращает
ModelAndView
объект. для тех, кто возвращаетсяString,ViewилиModeMapи другие типы методов обработки, Spring MVC также внутренне соберет их в объект ModelAndView, который содержитлогическое имяа такжевид объектов модели. - Spring MVC использует преобразователи представлений (
ViewResolver
), чтобы получить окончательный объект вида (View
), окончательный вид может бытьJSP
, или возможноExcel
,JFreeChart
Виды различных представлений. - Процессор не заботится о том, какой объект представления в конечном итоге используется для визуализации данных модели, и процессор сосредотачивается на работе по созданию данных модели, чтобы реализовать полное разделение MVC.
1) Посмотреть
Нам нужно только реализовать интерфейс View для настройки представления
Пример:
@Component
public class HelloView implements View{
@Override
public String getContentType() {
return "text/html";
}
@Override
public void render(Map<String, ?> model, HttpServletRequest request,
HttpServletResponse response) throws Exception {
response.getWriter().print("hello view, time: " + new Date());
}
}
@RequestMapping("/testView")
public String testView(){
System.out.println("testView");
return "helloView"; //这里返回的就是我们自定义的视图
}
2) Посмотреть распознаватель
- SpringMVC предоставляет различные стратегии для разрешения имен логических представлений, которые можно настроить в контексте Spring WEB.своего родаилиразличныйРазобрать политики и указатьпоследовательность. Каждая стратегия сопоставления соответствует определенному классу реализации преобразователя представлений.
- Роль синтаксического анализатора представления относительно проста.Разобрать логическое представление в конкретный объект представления.
- Все распознаватели представлений должны реализовыватьViewResolverинтерфейс.
- Программисты могут выбрать один преобразователь представлений или использовать сочетание преобразователей представлений.
- Каждый преобразователь представлений реализуетУпорядоченный интерфейсИ откройте свойство заказа, доступ к которому можно получить с помощьюАтрибут order определяет порядок приоритета парсера., заказЧем меньше, тем выше приоритет.
- SpringMVC будет анализировать имя логического представления в порядке приоритета порядка синтаксического анализатора представления до тех пор, пока синтаксический анализ не будет успешным и объект представления не будет возвращен, в противном случае он выдаст
ServletException
аномальный
Конфигурация в SpringMVC.xml:
<!-- 配置视图解析器: 如何把 handler 方法返回值解析为实际的物理视图 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 配置视图 BeanNameViewResolver 解析器: 使用视图的名字来解析视图 -->
<!-- 通过 order 属性来定义视图解析器的优先级, order 值越小优先级越高 -->
<bean class="org.springframework.web.servlet.view.BeanNameViewResolver">
<property name="order" value="100"></property>
</bean>
"Если вы будете усердно работать сегодня, завтра вы сможете сказать на одну вещь меньше, чтобы попросить о помощи!
Я Сяо Цай, человек, который учится у вас.
💋