快速入门 SpringMVC
通过本文,你将了解如何使用 SpringMVC 框架实现一个简单的 Controller,并在浏览器中访问。SpringMVC 框架的背后做了大量的工作,使得开发变得非常简单。
注解(Annotation)
在代码中,我们使用了如 @Controller 等注解。为了更好地理解这些代码,我们需要先了解一下 Java 的注解语法。注解是一种对源代码的标注,不会直接影响代码的执行,但可以在编译或运行时通过注解来扩展代码的功能。
Java 语言本身提供了一些常用的注解,例如 @Override 用于标记方法是一个重载方法,@Deprecated 用于标记代码已废弃。为了创建自定义注解,Java 提供了一些元注解(Meta Annotations),这些注解用于定义新的注解。以下是一个示例:
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface MyAnnotation {
}
上述代码中,我们使用了以下几个元注解:
@Target:指定注解可以应用的语言元素,如方法、类型、函数参数等。
@Retention:指定注解的存储方式,SOURCE(仅存在于源代码中)、CLASS(存储在 class 文件中但不保留到运行时)、RUNTIME(存储在 class 文件中并保留到运行时)。
@Documented:表示注解会在生成的 Javadoc 中显示。
@Inherited:未在示例中使用,用于标记类的注解可以被子类继承。
POJO(Plain Old Java Object)
POJO 是普通 Java 对象的简称,大多数 Java 对象都可以称为 POJO。POJO 的概念旨在反对早期框架(如 EJB)中强制继承特定类或实现特定接口的设计,从而减少框架依赖。例如,在使用 JMS 时,需要实现特定接口:
public class ExampleListener implements MessageListener {
public void onMessage(Message message) {
// ...
}
}
而在使用 RMI 时,业务接口需要继承特定接口:
public interface IHello extends Remote {
public String helloWorld() throws RemoteException;
}
SpringMVC 鼓励使用 POJO,例如我们编写的 Controller 类:
public class MyFirstSpringController {
public String hello() {
return "Hello, SpringMVC.";
}
}
即使加上注解,这个类仍然是一个简单的 Java 类,没有依赖任何外部组件,从而保持了代码的轻量性和灵活性。
JavaBean
JavaBean 是一种编程惯例,主要用于编写数据模型类,具体要求包括:
- 无参构造器
- 所有成员变量为 private,并提供 getter 和 setter 方法
- 实现 Serializable 接口
随着时间的发展,JavaBean 的概念逐渐泛化,不再局限于数据模型类,也可以应用于业务类等。Spring 框架中,许多组件也被称为 Bean,这是对 JavaBean 概念的进一步扩展。
SpringMVC 的魔法
SpringMVC 需要知道 Controller 类的信息。在配置文件中,我们指定了 Controller 类。在 Controller 类中,@RequestMapping 注解用于处理请求的分发。SpringMVC 在初始化 Controller 时,会解析 @RequestMapping 注解中的信息,根据这些信息将请求分发到相应的 Controller 方法中。
@ResponseBody 注解表明方法的返回值应作为 HTTP 响应的 body。SpringMVC 会将返回的字符串生成 HTTP 响应并返回给客户端。
通过以上介绍,我们可以看到 SpringMVC 通过注解以低侵入性的方式,提供了一套简洁易用的 Web 开发 API。