Welcome everyone to pay attention to my public number [old week chat architecture], The principle of Java backend mainstream technology stack, source code analysis, architecture and a variety of Internet high concurrency, high performance, high availability solutions.
Annotations
1. @ SpringBootApplication
Contains @ComponentScan, @Configuration, and @EnableAutoConfiguration annotations. @ComponentScan tells Spring Boot to scan the Configuration class and add it to the application context.
2, @ ComponentScan
Component scanning, which automatically discovers and assembles beans.
3, @ Configuration
An XML configuration file equivalent to Spring; You can check type safety using Java code.
4, @ EnableAutoConfiguration
Automatic configuration
5, @ RestController
This annotation, a combination of @Controller and @responseBody, indicates that this is a Controller Bean and that it is a REST-style Controller that fills the return value of the function directly into the BODY of the HTTP response.
6, the @autowired
Automatic import.
7, @ PathVariable
Get parameters.
8, @ JsonBackReference
Solve the nested external chain problem.
9, @ RepositoryRestResourcepublic
It can be used together with spring-boot-starter-data-rest.
Annotations
1, @springBootApplication: declare that SpringBoot will automatically configure the program as necessary. This configuration is equivalent to: @Configuration, @EnableAutoConfiguration, and @ComponentScan are configured.
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication // same as @Configuration @EnableAutoConfiguration @ComponentScan
public class Application {
public static void main(String[] args) { SpringApplication.run(Application.class, args); }}Copy the code
2. @responseBody: indicates that the return result of this method is directly written into the HTTP ResponseBody, which is generally used in asynchronous data acquisition and used to build RESTful apis.
If @requestMapping is used, the return value is usually interpreted as a jump path. If @responseBody is added, the return value is not interpreted as a jump path and is written directly to the HTTP ResponseBody.
So if you get json data asynchronously, and you add @responseBody, it will return json data directly.
This annotation is typically used in conjunction with @requestMapping.
Sample code:
@ RequestMapping ("/test ")
@ResponseBody
public String test(a){
return"Ok"; }Copy the code
3. @Controller: Used to define the Controller class. In spring project, the Controller is responsible for forwarding the URL request sent by the user to the corresponding service interface (Service layer).
Usually this annotation is in a class, and usually methods need to be annotated with @requestMapping.
Sample code:
@Controller
@ RequestMapping ("/demoInfo ")
publicclass DemoController {
@Autowired
private DemoInfoService demoInfoService;
@RequestMapping("/hello")
public String hello(Map map){
System.out.println("DemoController.hello()");
map.put("hello"."from TemplateController.helloHtml");
// The hello. HTML or hello. FTL template will be used for rendering.
return"/hello"; }}Copy the code
4. @RestController: A collection of annotated control-layer components (such as Struts actions), @responseBody, and @Controller.
Sample code:
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@ RequestMapping ("/demoInfo2 ")
publicclass DemoController2 {
@RequestMapping("/test")
public String test(a){
return"ok"; }}Copy the code
@requestMapping: provides routing information for mapping urls to specific functions in Controller.
6. @enableAutoConfiguration: Spring Boot Auto-Configuration: Try to automatically configure your Spring application based on the JAR dependencies you added.
For example, if HSQLDB exists in your CLASspath and you don’t manually configure any database connection Beans, we will automatically configure an in-memory database.
You can add the @EnableAutoConfiguration or @SpringBootApplication annotation to an @Configuration class to select automatic Configuration.
If you find specific auto-configuration classes applied that you don’t want, you can disable them using the exclusion attribute of the @enableAutoConfiguration annotation.
7. @ComponentScan: indicates that this class automatically discovers scanned components.
If you scan a class with @Component, @Controller, @Service, etc., and register it as a Bean, you can automatically collect all Spring components, including the @Configuration class.
We often use the @ComponentScan annotation to search for Beans, combined with the @AutoWired annotation to import. All Spring components can be collected automatically, including the @Configuration class.
If not, Spring Boot scans for classes that use @service, @repository, and other annotations in the Boot package and its subpackages.
@Configuration: Equivalent to a traditional XML Configuration file. If some third-party libraries require XML files, it is recommended that the @Configuration class be used as the main Configuration class of the project — the XML Configuration file can be loaded using the @ImportResource annotation.
@import: used to Import other configuration classes.
@importResource: used to load the XML configuration file.
@autoWired: Automatically import dependent beans
12. @service: Generally used to modify components in the Service layer
13, @ the Repository: Using the @Repository annotation ensures that DAO or Repositories provides an exception translation. The DAO or Repositories class modified by this annotation will be found and configured by ComponetScan without providing an XML configuration entry for them.
14. @beans: Annotating @beans is equivalent to beans configured in XML.
15, @value: Inject the Value of the Spring Boot Application. properties property configured. Sample code:
@ the Value (Value = "# {message}")
private String message;
Copy the code
Inject @inject: Equivalent to the default @autowired, but without the required attribute;
17. @Component: a generic annotation for components that are difficult to categorize.
18, @bean: equivalent to XML, on top of a method, not a class, which means to generate a Bean and hand it over to Spring to manage.
19, @autoWired: Automatically import dependent beans. ByType way. The configured Bean is used to complete the assembly of attributes and methods. It can annotate class member variables, methods and constructors to complete the work of automatic assembly. When (required=false) is added, no error is reported even if the bean is not found.
20. @qualifier: When there are multiple beans of the same type, you can specify @qualifier (” name “). Used with @autowired. In addition to being injected by name, the @qualifier Qualifier provides more fine-grained control over how candidates are selected, as follows:
@Autowired
@ the Qualifier (value = "demoInfoService")
private DemoInfoService demoInfoService;
Copy the code
21, @resource (name= “name”,type= “type”) : default byName. Same thing with @autowired.
JPA notes
@entity: @table (name= “) : indicates that this is an Entity class. These two annotations are usually used together, but @table can be omitted if the Table name is the same as the entity class name.
2, @mappedsuperclass: for an entity that is identified as a parent class. Attribute subclasses of the parent class can be inherited.
@noRepositoryBean: normally used as a repository for the parent class. With this annotation, Spring will not instantiate the repository.
4. @column: If the Column name is the same as the Column name, you can omit it.
5. @id: indicates the primary key of the attribute.
6, @ GeneratedValue (strategy = GenerationType SEQUENCE, the generator = “repair_seq”) : Indicates that the primary key generation policy is SEQUENCE (Auto, IDENTITY, or native). Auto indicates that the service can be switched among multiple databases. The sequence name is REPAIR_SEq.
7. @SequenceGeneretor(Name = “REPAIR_SEq”, sequenceName = “SEQ_repair”, allocationSize = 1) : Name is the name of sequence, so that sequenceName is the name of the database sequence. The two names can be the same.
8. @TRANSIENT: indicates that this attribute is not a mapping to a field of a database table and will be ignored by the ORM framework.
If a property is not a field mapping of a database table, it must be marked as @TRANSIENT; otherwise, the ORM framework defaults to annotating it as @BASIC.
9, @basic (fetch= fetchtype.lazy) : the tag can specify how the attributes of the entity are loaded.
10. @jsonIgnore: Ignore some properties of Java bean during JSON serialization, serialization and deserialization are affected.
@joinColumn (name= “loginId”) : one-to-one: specifies the foreign key that points to another table in this table. One-to-many: another table points to the foreign key of this table.
@onetoone, @onetomany, @manyToOne: correspond to one-to-one, one-to-many, many-to-one in hibernate configuration files.
4. SpringMVC annotations
1. @requestMapping: @requestMapping (/path) indicates that the controller processes all UR L requests of /path.
RequestMapping is an annotation to handle request address mapping, which can be used on a class or method.
Used on a class, this address is used as the parent path for all methods in the class that respond to requests. This annotation has six attributes:
params
: specifyrequest
Must contain some parameter values of yes for this method to process.headers
: specifyrequest
Must contain some specifiedheader
Value to allow the method to process the request.value
: Specifies the actual address of the request. The specified address can beURI Template
modelmethod
: Specifies the method type of the request,GET, POST, PUT, DELETE
Etc.consumes
: Specifies the type of submission to process the request (Content-Type
), such asapplication/json,text/html
;produces
: Specifies the type of content to return, only ifrequest
In the request header (Accept
) type contains the specified type.
2, @requestParam: used in front of method arguments.
3, @pathvariable: PathVariable. Such as:
RequestMapping (" user/get / {macAddress} ")public String getByMacAddress(@PathVariable String macAddress){
//do something;
}
Copy the code
The arguments must be the same as the names in braces.
5. Global exception handling
@ControllerAdvice: contains @Component. It can be scanned. Uniformly handle exceptions.
ExceptionHandler (exception.class) : Used above a method to indicate that the following method is executed when this Exception is encountered.
Lombok notes
The most comprehensive explanation of Lombok Features ever