Controller
声明此类事一个MVC类,通常与@RequestMapping一起使用
Service
Component
通用注解类,业务无法明确划分或不能归类清晰时,对该功能进行组件封装,并希望交给 IOC 管理, 这时候用@component 注解。
ResController
开发rest api
responseBody
@responseBody作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML.
http://localhost:8080/responsebody
@ResponseBody
@RequestMapping("/responseBody")
public String responseBody(){
return "hello springmvc";
}
RequestParam
把请求中的指定名称的参数传递给控制器中形参赋值
属性:
value:请求参数中的名称
required:请求参数中是否必须提供此参数,默认值是true,表示必填参数
defaultValue:默认值,如果设置了该值,required 将自动设为 false,无论你是否配置了 required,配置了什么值,都是 false(可选配置)
@ResponseBody
@RequestMapping("/param")
public String requestParam(@RequestParam(value = "id",required = false) String userId){
return "hello"+userId;
}
RequestBody
获取请求参数提的内容,由于get方法没有body 所有get不可以使用,
属性 required:是否必须有请求体,默认值是true
@ResponseBody
@RequestMapping(value = "/requestBody",method = RequestMethod.POST)
public String requestBody(@RequestBody String body){
return body;
}
curl 测试请求Post
curl -X POST http://localhost:8080/requestBody \
-H 'Content-Type: application/json' \
-d '{"uid":12}'
PathVariable
拥有绑定url中的占位符的。/delete/{id},{id}就是占位符
属性 value:指定url中的占位符名称
http://localhost:8080/user/1100
@ResponseBody
@RequestMapping(value = "/user/{id}")
public String request(@PathVariable("id") String id){
return "uid:"+id;
}
RequestHeader
获取指定请求头的值
属性 value:请求头的名称
@ResponseBody
@RequestMapping(value = "/lang")
public String requestHead(@RequestHeader("accept-language") String lang){
return lang;
}
curl -X GET http://localhost:8080/lang \
-H 'Accept-Language: zh-CN' \
CookieValue
获取指定cookie的名称的值
属性 value:cookie的名称
http://localhost:8080/cookie
@ResponseBody
@RequestMapping(value = "/cookie")
public String requestCookie(@CookieValue("JSESSIONID") String cookie){
return cookie;
}
ModelAttribute
- 出现在方法上:表示当前方法会在控制器方法执行前线执行。
- 出现在参数上:获取指定的数据给参数赋值。
应用场景:
1当提交表单数据不是完整的实体数据时,保证没有提交的字段使用数据库原来的数据。
2修饰的方法没有返回值 - SessionAttributes
多次执行控制器方法间的参数共享
属性1. value:指定存入属性的名称
@Configuration
用于指定当前类是一个 spring 配置类,当创建容器时会从该类上加载注解。获取容器时需要使用AnnotationApplicationContext(有@Configuration 注解的类.class)。当注解的配置类作为AnnotationConfigApplicationContext对象创建的参数时,该注解可以省略
ApplicationContext ac = new AnnotationConfigApplicationContext(SpringConfiguration.class);
@ComponentScan
用于指定 spring 在初始化容器时要扫描的包。作用和在 spring 的 xml 配置文件中的:
属性:basePackages:用于指定要扫描的包。和该注解中的 value 属性作用一样。
@Bean
该注解只能写在方法上,用于把当前方法的返回值放入spring的IOC容器中。如果注解的方法有参数的时,spring框架回去容器中查找有没有可以匹配的bean对象,与Autowired注解的作用是一样的
属性:name 指定当前bean的id,默认值是当前方法的名称。
xml配置文件
<context:component-scan base-package="com.bx"></context:component-scan>
<bean id="runner" class="org.apache.commons.dbutils.QueryRunner" scope="prototype">
<constructor-arg name="ds" ref="dataSource">
</constructor-arg>
</bean>
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/demo?characterEncoding=utf-8"></property>
<property name="user" value="root"></property>
<property name="password" value="baxiang"></property>
</bean>
转换成注解
@Configuration
@ComponentScan(basePackages = "com.bx")
public class SpringConfiguration {
@Bean(name = "runner")
public QueryRunner createQueryRunner(DataSource dataSource){
return new QueryRunner(dataSource);
}
@Bean("datasource")
public DataSource createDataSource(){
try {
ComboPooledDataSource ds = new ComboPooledDataSource();
ds.setDriverClass("com.mysql.jdbc.Driver");
ds.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/demo?characterEncoding=utf-8");
ds.setUser("root");
ds.setPassword("baxiang");
return ds;
}catch (Exception e){
e.printStackTrace();
}
return null;
}
}
Value
@Value 是获取 application.properties 中的配置信息,例如 application.properties 中有相关
@PropertySource
用于加载 .properties 文件中的配置 。配置数据源时,可以把连接数据库的信息写到properties 配置文件中,就可以使用此注解指定 properties 配置文件的位置。
属性:value[]:用于指定 properties 文件位置。如果是在类路径下,需要写上 classpath
jdbcConfig.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/demo?characterEncoding=utf-8
jdbc.user=root
jdbc.password=baxiang
设置@PropertySource注解 需要设置classpath
@Configuration
@PropertySource("classpath:jdbcConfig.properties")
public class JdbcConfig {
@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.user}")
private String username;
@Value("${jdbc.password}")
private String password;
@Bean("datasource")
public DataSource createDataSource(){
try {
ComboPooledDataSource ds = new ComboPooledDataSource();
ds.setDriverClass(driver);
ds.setJdbcUrl(url);
ds.setUser(username);
ds.setPassword(password);
return ds;
}catch (Exception e){
e.printStackTrace();
throw new RuntimeException(e);
}
}
}
@Import
用于导入其他配置类,在引入其他配置类时,可以省略@Configuration 注解。
属性:value[]:用于指定其他配置类的字节码。当我们使用Import的注解之后,有Import注解的类就是父配置类,而导入的都是子配置类
@Import(xxxx.class)
参考
https://docs.spring.io/spring-javaconfig/docs/1.0.0.M4/reference/html/ch02s02.html