Maison Java javaDidacticiel Résumer certaines des annotations les plus couramment utilisées en Java

Résumer certaines des annotations les plus couramment utilisées en Java

May 16, 2017 am 09:42 AM
boot spring Annotations communes 注解

Cet article présente principalement un résumé des annotations courantes utilisées dans Spring Boot. Les amis qui en ont besoin peuvent se référer aux annotations

@RestController et @RequestMapping

. 4.0 Important Une nouvelle amélioration est l'annotation @RestController, qui hérite de l'annotation @Controller. Avant la version 4.0, les composants Spring MVC utilisaient tous @Controller pour identifier la classe actuelle en tant que Controllerservlet. Grâce à cette fonctionnalité, nous pouvons développer des services REST sans utiliser @Controller mais un @RestController dédié.

Lorsque vous implémentez un service Web RESTful, la réponse sera toujours envoyée via le corps de la réponse. Pour simplifier le développement, Spring 4.0 fournit une version spécialisée du contrôleur. Jetons un coup d'œil à la définition de l'implémentation de @RestController :

@Target(value=TYPE)  
 @Retention(value=RUNTIME)  
 @Documented  
 @Controller  
 @ResponseBody  
public @interface RestController  
@Target(value=TYPE) 
 @Retention(value=RUNTIME) 
 @Documented 
 @Controller 
 @ResponseBody 
public @interface RestController
Copier après la connexion

L'annotation @RequestMapping fournit des informations de routage . Il indique à Spring que toute requête HTTP provenant du chemin "/" doit être mappée à la méthode home. L'annotation @RestController indique à Spring de restituer le résultat sous la forme de string et de le renvoyer directement à l'appelant.

Remarque : les annotations @RestController et @RequestMapping sont des annotations Spring MVC (elles ne sont pas des parties spécifiques de Spring Boot)

Annotation @EnableAutoConfiguration

La deuxième annotation au niveau de la classe est @EnableAutoConfiguration. Cette annotation indique à Spring Boot de deviner comment vous souhaitez configurer Spring en fonction des dépendances jar ajoutées. Étant donné que spring-boot-starter-web ajoute Tomcat et Spring MVC, la configuration automatique supposera que vous développez une application Web et configurez Spring en conséquence. POM de démarrage et configuration automatique : le but de la conception de la configuration automatique est de mieux utiliser les "POM de démarrage", mais les deux concepts ne sont pas directement liés. Vous êtes libre de choisir les dépendances jar en dehors des POM de démarrage, et Spring Boot fera toujours de son mieux pour configurer automatiquement votre application.

Vous pouvez choisir la configuration automatique en ajoutant l'annotation @EnableAutoConfiguration ou @SpringBootApplication à une classe @Configuration.

Remarque : Il vous suffit d'ajouter une annotation @EnableAutoConfiguration. Nous vous recommandons de l’ajouter à la classe principale @Configuration.

Si vous constatez que des classes de configuration automatique spécifiques sont appliquées et que vous ne souhaitez pas, vous pouvez les désactiver à l'aide de l'attribut d'exclusion de l'annotation @EnableAutoConfiguration.

<pre name="code" class="java">import org.springframework.boot.autoconfigure.*; 
import org.springframework.boot.autoconfigure.jdbc.*; 
import org.springframework.context.annotation.*; 
@Configuration 
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class}) 
public class MyConfiguration { 
} 
<pre name="code" class="java">import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
import org.springframework.context.annotation.*;
@Configuration
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class MyConfiguration {
}
@Configuration
Copier après la connexion

Spring Boot préconise une configuration basée sur Java. Bien que vous puissiez utiliser une source XML pour appeler SpringApplication.run() , nous vous recommandons généralement d'utiliser une classe @Configuration comme source principale. Les classes qui définissent généralement une méthode main sont également de bons candidats pour la @Configuration principale. Vous n'avez pas besoin de mettre tous les @Configuration dans une seule classe. L'annotation @Import peut être utilisée pour importer d'autres classes de configuration. Vous pouvez également utiliser l'annotation @ComponentScan pour collecter automatiquement tous les composants Spring, y compris les classes @Configuration.

Si vous devez absolument utiliser une configuration basée sur XML, nous vous recommandons de toujours commencer par une classe @Configuration. Vous pouvez charger des fichiers de configuration XML à l'aide de l'annotation supplémentaire @ImportResource.

L'annotation @Configuration de cette classe équivaut à configurer des beans en XML ; l'utilisation de la méthode d'annotation @Bean équivaut à configurer des beans en XML

@ComponentScan(basePackages = "com.hyxt",includeFilters = {@ComponentScan.Filter(Aspect.class)}) 
@ComponentScan(basePackages = "com.hyxt",includeFilters = {@ComponentScan.Filter(Aspect.class)})
@SpringBootApplication
Copier après la connexion

De nombreux développeurs Spring Boot utilisent toujours @ Configuration, @EnableAutoConfiguration et @ComponentScan annotent leurs classes principales. Étant donné que ces annotations sont très fréquemment utilisées ensemble (surtout si vous suivez les meilleures pratiques ci-dessus), Spring Boot fournit une alternative pratique à @SpringBootApplication.

L'annotation @SpringBootApplication équivaut à utiliser @Configuration , @EnableAutoConfiguration et @ComponentScan avec les propriétés par défaut.

package com.example.myproject; 
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); 
  } 
} 
package com.example.myproject;
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);
  }
}
Copier après la connexion

Spring Boot tentera de vérifier la configuration externe, en utilisant JSR-303 par défaut (si elle se trouve dans le chemin de classe). Vous pouvez facilement ajouter l'annotation JSR-303 javax.validationconstraints à votre classe @ConfigurationProperties :

@Component 
@ConfigurationProperties(prefix="connection") 
public class ConnectionSettings { 
@NotNull 
private InetAddress remoteAddress; 
// ... getters and setters  
} 
@Component
@ConfigurationProperties(prefix="connection")
public class ConnectionSettings {
@NotNull
private InetAddress remoteAddress;
// ... getters and setters
}
@Profiles
Spring Profiles提供了一种隔离应用程序配置的方式,并让这些配置只能在特定的环境下生效。任何@Component或@Configuration都能被@Profile标记,从而限制加载它的时机。
[java] view plain copy print?在CODE上查看代码片派生到我的代码片
@Configuration 
@Profile("production") 
public class ProductionConfiguration { 
// ...  
} 
@Configuration
@Profile("production")
public class ProductionConfiguration {
// ...
}@ResponseBody
Copier après la connexion

signifie que le résultat de retour de cette méthode est écrit directement dans le corps de la réponse HTTP

est généralement utilisé lors de l'obtention de données de manière asynchrone. Après avoir utilisé @RequestMapping, la valeur de retour est généralement analysée comme un chemin de saut. Après avoir ajouté

@responsebody, le résultat renvoyé ne sera pas analysé comme un saut. chemin. Il est écrit directement dans le corps de la réponse HTTP. Par exemple,
obtient les données json de manière asynchrone, et après avoir ajouté @responsebody, les données json seront renvoyées directement.

@Composant :

泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。一般公共的方法我会用上这个注解

@AutoWired

byType方式。把配置好的Bean拿来用,完成属性、方法的组装,它可以对类成员变量、方法及构
函数进行标注,完成自动装配的工作。

当加上(required=false)时,就算找不到bean也不报错。

@RequestParam:

用在方法的参数前面。

@RequestParam String a =request.getParameter("a")。 
@RequestParam String a =request.getParameter("a")。
Copier après la connexion

@PathVariable:

路径变量。

RequestMapping("user/get/mac/{macAddress}") 
public String getByMacAddress(@PathVariable String macAddress){ 
//do something;  
} 
RequestMapping("user/get/mac/{macAddress}")
public String getByMacAddress(@PathVariable String macAddress){
//do something;
}
Copier après la connexion

参数与大括号里的名字一样要相同。

以上注解的示范

/** 
 * 用户进行评论及对评论进行管理的 Controller 类; 
 */ 
@Controller 
@RequestMapping("/msgCenter") 
public class MyCommentController extends BaseController { 
  @Autowired 
  CommentService commentService; 
  @Autowired 
  OperatorService operatorService; 
  /** 
   * 添加活动评论; 
   * 
   * @param applyId 活动 ID; 
   * @param content 评论内容; 
   * @return 
   */ 
  @ResponseBody 
  @RequestMapping("/addComment") 
  public Map<String, Object> addComment(@RequestParam("applyId") Integer applyId, @RequestParam("content") String content) { 
    .... 
    return result; 
  } 
} 
/**
 * 用户进行评论及对评论进行管理的 Controller 类;
 */
@Controller
@RequestMapping("/msgCenter")
public class MyCommentController extends BaseController {
  @Autowired
  CommentService commentService;
  @Autowired
  OperatorService operatorService;
  /**
   * 添加活动评论;
   *
   * @param applyId 活动 ID;
   * @param content 评论内容;
   * @return
   */
  @ResponseBody
  @RequestMapping("/addComment")
  public Map<String, Object> addComment(@RequestParam("applyId") Integer applyId, @RequestParam("content") String content) {
    ....
    return result;
  }
}
@RequestMapping("/list/{applyId}") 
  public String list(@PathVariable Long applyId, HttpServletRequest request, ModelMap modelMap) { 
} 
 @RequestMapping("/list/{applyId}")
  public String list(@PathVariable Long applyId, HttpServletRequest request, ModelMap modelMap) {
}
Copier après la connexion

全局处理异常的:

@ControllerAdvice:

包含@Component。可以被扫描到。

统一处理异常。

@ExceptionHandler(Exception.class):

用在方法上面表示遇到这个异常就执行以下方法。

/** 
 * 全局异常处理 
 */ 
@ControllerAdvice 
class GlobalDefaultExceptionHandler { 
  public static final String DEFAULT_ERROR_VIEW = "error"; 
  @ExceptionHandler({TypeMismatchException.class,NumberFormatException.class}) 
  public ModelAndView formatErrorHandler(HttpServletRequest req, Exception e) throws Exception { 
    ModelAndView mav = new ModelAndView(); 
    mav.addObject("error","参数类型错误"); 
    mav.addObject("exception", e); 
    mav.addObject("url", RequestUtils.getCompleteRequestUrl(req)); 
    mav.addObject("timestamp", new Date()); 
    mav.setViewName(DEFAULT_ERROR_VIEW); 
    return mav; 
  }} 
/**
 * 全局异常处理
 */
@ControllerAdvice
class GlobalDefaultExceptionHandler {
  public static final String DEFAULT_ERROR_VIEW = "error";
  @ExceptionHandler({TypeMismatchException.class,NumberFormatException.class})
  public ModelAndView formatErrorHandler(HttpServletRequest req, Exception e) throws Exception {
    ModelAndView mav = new ModelAndView();
    mav.addObject("error","参数类型错误");
    mav.addObject("exception", e);
    mav.addObject("url", RequestUtils.getCompleteRequestUrl(req));
    mav.addObject("timestamp", new Date());
    mav.setViewName(DEFAULT_ERROR_VIEW);
    return mav;
  }}
Copier après la connexion

通过@value注解来读取application.properties里面的配置

# face++ key 
face_api_key = R9Z3Vxc7ZcxfewgVrjOyrvu1d-qR**** 
face_api_secret =D9WUQGCYLvOCIdsbX35uTH******** 
# face++ key
face_api_key = R9Z3Vxc7ZcxfewgVrjOyrvu1d-qR****
face_api_secret =D9WUQGCYLvOCIdsbX35uTH********
@Value("${face_api_key}") 
  private String API_KEY; 
  @Value("${face_api_secret}") 
  private String API_SECRET; 
 @Value("${face_api_key}")
  private String API_KEY;
  @Value("${face_api_secret}")
  private String API_SECRET;所以一般常用的配置都是配置在application.properties文件的
Copier après la connexion

【相关推荐】

1. 特别推荐“php程序员工具箱”V0.1版本下载

2. Java免费视频教程

3. JAVA教程手册

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Fichier ISO Windows trop volumineux Erreur BootCamp [Corrigé] Fichier ISO Windows trop volumineux Erreur BootCamp [Corrigé] Feb 19, 2024 pm 12:30 PM

Si vous recevez le message d'erreur « Le fichier ISO Windows est trop volumineux » lorsque vous utilisez BootCampAssistant sur un ordinateur Mac, cela peut être dû au fait que la taille du fichier ISO dépasse la limite prise en charge par BootCampAssistant. La solution à ce problème consiste à utiliser d'autres outils pour compresser la taille du fichier ISO afin de garantir qu'il puisse être traité dans BootCamp Assistant. BootCampAssistant est un outil pratique fourni par Apple pour installer et exécuter le système d'exploitation Windows sur les ordinateurs Mac. Il aide les utilisateurs à configurer un système à double démarrage, leur permettant de choisir facilement d'utiliser MacOS ou Wind au démarrage.

Un nouveau paradigme de programmation, quand Spring Boot rencontre OpenAI Un nouveau paradigme de programmation, quand Spring Boot rencontre OpenAI Feb 01, 2024 pm 09:18 PM

En 2023, la technologie de l’IA est devenue un sujet brûlant et a un impact énorme sur diverses industries, notamment dans le domaine de la programmation. Les gens sont de plus en plus conscients de l’importance de la technologie de l’IA, et la communauté Spring ne fait pas exception. Avec l’évolution continue de la technologie GenAI (Intelligence Artificielle Générale), il est devenu crucial et urgent de simplifier la création d’applications dotées de fonctions d’IA. Dans ce contexte, « SpringAI » a émergé, visant à simplifier le processus de développement d'applications fonctionnelles d'IA, en le rendant simple et intuitif et en évitant une complexité inutile. Grâce à « SpringAI », les développeurs peuvent plus facilement créer des applications dotées de fonctions d'IA, ce qui les rend plus faciles à utiliser et à exploiter.

Quelles sont les méthodes de mise en œuvre des transactions programmatiques Spring ? Quelles sont les méthodes de mise en œuvre des transactions programmatiques Spring ? Jan 08, 2024 am 10:23 AM

Comment implémenter les transactions programmatiques Spring : 1. Utilisez TransactionTemplate ; 2. Utilisez TransactionCallback et TransactionCallbackWithoutResult ; 3. Utilisez les annotations Transactional ; 4. Utilisez TransactionTemplate en combinaison avec @Transactional ;

Utilisez Spring Boot et Spring AI pour créer des applications d'intelligence artificielle générative Utilisez Spring Boot et Spring AI pour créer des applications d'intelligence artificielle générative Apr 28, 2024 am 11:46 AM

En tant que leader du secteur, Spring+AI fournit des solutions de pointe pour divers secteurs grâce à son API puissante et flexible et ses fonctions avancées. Dans cette rubrique, nous examinerons les exemples d'application de Spring+AI dans divers domaines. Chaque cas montrera comment Spring+AI répond à des besoins spécifiques, atteint ses objectifs et étend ces LEÇONS APPRISES à une gamme plus large d'applications. J'espère que ce sujet pourra vous inciter à comprendre et à utiliser plus profondément les possibilités infinies de Spring+AI. Le framework Spring a une histoire de plus de 20 ans dans le domaine du développement logiciel, et cela fait 10 ans que la version Spring Boot 1.0 est sortie. Maintenant, personne ne peut contester ce printemps

Comment les annotations sont-elles utilisées pour les méthodes de test dans le framework JUnit ? Comment les annotations sont-elles utilisées pour les méthodes de test dans le framework JUnit ? May 06, 2024 pm 05:33 PM

Les annotations dans le framework JUnit sont utilisées pour déclarer et configurer les méthodes de test. Les principales annotations incluent : @Test (déclaration des méthodes de test), @Before (méthode exécutée avant l'exécution de la méthode de test), @After (méthode exécutée après la méthode de test). est exécuté), @ BeforeClass (méthode qui s'exécute avant l'exécution de toutes les méthodes de test), @AfterClass (méthode qui s'exécute après l'exécution de toutes les méthodes de test), ces annotations aident à organiser et à simplifier le code de test et à améliorer la fiabilité du code de test. en fournissant des intentions et des configurations claires. Lisibilité et maintenabilité.

Le roi de la documentation du code PHP : un guide avancé de PHPDoc Le roi de la documentation du code PHP : un guide avancé de PHPDoc Mar 02, 2024 am 08:43 AM

Introduction : PHPDoc est une norme de commentaire pour le code PHP qui produit une documentation facile à comprendre et informative. En utilisant des balises de commentaires spécifiques, PHPDoc permet aux développeurs de fournir des détails importants sur les fonctions, classes, méthodes et autres éléments de code. Ce guide avancé examine en profondeur PHPDoc, démontrant ses capacités et fournissant des stratégies de documentation efficaces. Syntaxe et balises : les commentaires PHPDoc commencent par des doubles barres obliques (//) ou des commentaires sur plusieurs lignes (/**/). Voici quelques balises d'annotation courantes : @param : définit les paramètres d'une fonction ou d'une méthode. @return : Spécifie la valeur de retour de la fonction ou de la méthode. @throws : décrit les exceptions qui peuvent être levées par une fonction ou une méthode. @var : définit les attributs ou instances de la classe

Comment les annotations de la bibliothèque Jackson contrôlent-elles la sérialisation et la désérialisation JSON ? Comment les annotations de la bibliothèque Jackson contrôlent-elles la sérialisation et la désérialisation JSON ? May 06, 2024 pm 10:09 PM

Les annotations dans la bibliothèque Jackson contrôlent la sérialisation et la désérialisation JSON : Sérialisation : @JsonIgnore : Ignorer la propriété @JsonProperty : Spécifiez le nom @JsonGetter : Utilisez la méthode get @JsonSetter : Utilisez la méthode set Désérialisation : @JsonIgnoreProperties : Ignorez la propriété @ JsonProperty : Spécifiez le nom @JsonCreator : utilisez le constructeur @JsonDeserialize : logique personnalisée

Explication détaillée des étapes de fonctionnement des annotations MyBatis et du SQL dynamique Explication détaillée des étapes de fonctionnement des annotations MyBatis et du SQL dynamique Feb 18, 2024 pm 03:29 PM

Introduction détaillée à l'utilisation de SQL dynamique d'annotation MyBatis MyBatis est un cadre de couche de persistance qui nous fournit des opérations de persistance pratiques. Dans le développement réel, il est généralement nécessaire de générer dynamiquement des instructions SQL basées sur les besoins de l'entreprise pour réaliser des opérations de données flexibles. Le SQL dynamique d'annotation MyBatis est conçu pour répondre à cette demande.

See all articles