Résumer certaines des annotations les plus couramment utilisées en Java
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
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
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
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); } }
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
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")。
@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; }
参数与大括号里的名字一样要相同。
以上注解的示范
/** * 用户进行评论及对评论进行管理的 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) { }
全局处理异常的:
@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; }}
通过@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文件的
【相关推荐】
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)
![Fichier ISO Windows trop volumineux Erreur BootCamp [Corrigé]](https://img.php.cn/upload/article/000/887/227/170831702395455.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
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.

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.

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 ;

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

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é.

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

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

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.
