SpringMVC--注解开发

1.新建web项目
2.导入相关jar包
3.编写web.xml,注册DispatcherServlet
4.编写springmvc配置文件
5.创建对应控制类,controler
6.最后完善前端视图和controller直接的对应
7.测试运行调试
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_4_0.xsd"
         version="4.0">
    <!--1.注册Servlet-->
    <servlet>
        <servlet-name>SpringMVC</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--通过初始化参数指定SpringMVC配置文件的位置,进行关联-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc-04-anno.xml</param-value>
        </init-param>
        <!--启动顺序,数值越小,启动越早-->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <!--所有的请求都会被springmvc拦截-->
    <servlet-mapping>
        <servlet-name>SpringMVC</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
</web-app>
springmvc配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!--4.编写SpringMVC的配置文件!名称:springmvc-servlet.xml:[servletname]-servlet.xml!
说明,这里的名称要求是按照官方来的-->
<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.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--自动扫描包,让指定包下的注解生效,由IOC容器统一管理-->
    <context:component-scan base-package="com.kpp.controller"></context:component-scan>
    <!--让springMVC不处理静态资源-->
    <mvc:default-servlet-handler></mvc:default-servlet-handler>
    <!--
    支持mvc注解驱动
    在spring中一般采用@RequestMapping注解来完成映射关系
    要想使@RequestMapping注解生效
    必须向上下文中注册DefaultAnnotationHandlerMapping
    和一个AnnotationMethodHandlerAdapter实例
    这两个实例分别在类级别和方法级别处理
    而annotation-driven配置帮助我们自动完成上述两个实例的注入
    -->
    <mvc:annotation-driven></mvc:annotation-driven>
    <!--视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="InternalResourceViewResolver">
        <!--前缀-->
        <property name="prefix" value="/WEB-INF/jsp/"></property>
        <!--后缀-->
        <property name="suffix" value=".jsp"></property>
    </bean>
</beans>
controller类
package com.kpp.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
//@RequestMapping("HelloController")
public class HelloController {
    @RequestMapping("/hello")
    public String hello(Model model){
        //封装数据
        model.addAttribute("msg","hello,spring mvc by annocation");
        return "hello";//会被视图解析器处理
    }
}

使用springMVC必须配置的三大件

处理器映射器,处理器适配器,视图解析器
通常,我们只需要手动配置视图解析器,而处理器映射器和处理器适配器只需要开启注解驱动即可,
而省去了大段的xml配置

controller配置总结

SpringMVC数据处理
SpringMVC结果跳转方式
SpringMVC:Controller及Restful风格

SpringMVC:Controller及Restful风格
控制器Controller

*控制器负责提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现。
*控制器负责解析用户的请求并将其转换为一个模型。
*在SpringMVC中一个控制器类可以包含多个方法
*在SpringMVC中,对于controller的配置方式有很多种
方式如下:

实现Controller接口

//Controller是一个接口,在org.springframework.web.servlet.mvc包下,接口中只有一个方法;
//只有实现了Controller的类,这就是个控制器
public class ControllerDemo1 implements Controller {
    @Override
    public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
        ModelAndView mav = new ModelAndView();
        mav.addObject("msg","controller test1");
        mav.setViewName("hello");
        return mav;
    }
}
然而,实现接口Controller定义控制器是较老的办法
缺点是:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;定义的方法比较麻烦;

使用注解@Controller

*@Controller注解类型用于声明Spring类的实例是一个控制器(在讲IOC时还提到了另外3个注解);
*Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。
@Component
@Service
@Controller
@Repository
<context:component-scan base-package="com.kpp.controller"></context:component-scan>
增加一个controllerDemo2类,使用注解实现:
package com.kpp.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller//代表这个类会被spring接管
public class ControllerDemo2 {
    @RequestMapping("t2")
    public String test1(Model model){
        model.addAttribute("msg","2021/5/21");
        return "hello";//return+controller注解返回视图解析器
    }
    @RequestMapping("t3")
    public String test2(Model model){
        model.addAttribute("msg","2021/5/24");
        return "hello";//return+controller注解返回视图解析器
    }
    //使用同一个jsp页面
}

RequestMapping说明

@RequestMapping
*@RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法。可用于类或方法上。
用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
*为了测试结论更加准确,我们可以加上一个项目名测试myweb
*只注解在方法上面
@Controller
public class ControllerDemo3 {
    @RequestMapping("/t1")
    public String test1(Model model){
        model.addAttribute("msg","ControllerDemo3");
        return "hello";
    }
}
访问路径:http://localhost:8080/项目名/h1
同时注解类与方法
@Controller
@RequestMapping("/c3")
public class ControllerDemo3 {
    @RequestMapping("/t1")
    public String test1(Model model){
        model.addAttribute("msg","ControllerDemo3");
        return "hello";
    }
}

在这里插入图片描述
在这里插入图片描述

@Controller
public class RestfulController {
    @RequestMapping("/add/{a}/{b}")
    public String test1(@PathVariable int a,@PathVariable int b, Model model){
        int res = a+b;
        model.addAttribute("msg","结果为:"+res);
        return "hello";
    }
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值