Routing
Le routage dans webforJ avec Spring fonctionne exactement de la même manière que dans les applications webforJ classiques. Vous utilisez toujours l'annotation @Route pour définir les routes, les mêmes schémas de navigation, et le même cycle de vie des routes. La seule différence est que lorsque Spring est présent, vos routes peuvent également recevoir des beans Spring par injection de constructeur.
Lorsque vous naviguez vers une route, webforJ crée l'instance de la route - mais avec Spring sur le classpath, il utilise le conteneur de Spring pour résoudre les dépendances. Cela signifie que vos routes peuvent utiliser toute la puissance de l'écosystème Spring (services, dépôts, beans personnalisés) tout en maintenant le comportement de routage familier de webforJ.
Pour une compréhension complète des schémas d'injection de dépendances et du conteneur IoC de Spring, consultez la documentation officielle sur l'injection de dépendances de Spring.
Comment webforJ crée des routes avec Spring
webforJ gère la création de routes différemment lorsque Spring est présent. Le mécanisme de création d'objets du framework détecte Spring Boot sur le classpath et délègue à AutowireCapableBeanFactory de Spring la création d'instances avec injection de dépendances.
Pour les classes découvertes par le scan @Routify, webforJ crée toujours des instances fraîches et ne réutilise jamais des beans Spring existants. Chaque navigation de l'utilisateur reçoit une nouvelle instance de route sans état partagé. Le processus de création :
- L'utilisateur navigue vers une route
- webforJ demande une nouvelle instance (ignorant toute définition de bean Spring existante)
- Le conteneur de Spring crée l'instance et injecte les dépendances du constructeur
- La route s'initialise avec toutes les dépendances satisfaites
Ce comportement est intentionnel et diffère des beans Spring typiques. Même si vous enregistrez une route en tant que bean Spring avec @Component, webforJ ignore cette définition de bean et crée une nouvelle instance pour chaque navigation.
Utilisation des beans Spring dans les routes
Vos classes de route n'exigent pas d'annotations Spring. L'annotation @Route seule permet à la fois la découverte de route et l'injection de dépendances :
@Route("/dashboard")
public class DashboardView extends Composite<Div> {
private final Div self = getBoundComponent();
private final MetricsService metricsService;
private final UserRepository userRepository;
public DashboardView(MetricsService metricsService, UserRepository userRepository) {
this.metricsService = metricsService;
this.userRepository = userRepository;
// Utilisez les services injectés pour construire l'UI
Div metricsPanel = new Div();
metricsPanel.setText(metricsService.getCurrentMetrics());
self.add(metricsPanel);
}
}
Le constructeur peut recevoir :
- Services annotés avec
@Service,@Repositoryou@Component - Dépôts Spring Data (
JpaRepository,CrudRepository) - Valeurs de configuration via des annotations
@Value - Beans d'infrastructure Spring (
ApplicationContext,Environment) - Tout bean enregistré dans le contexte Spring
Exemple de travail
Cet exemple démontre un scénario complet d'injection de dépendances où un service Spring est injecté dans une route webforJ. Le service gère la logique métier tandis que la route s'occupe de la présentation de l'UI.
Tout d'abord, définissez un service Spring standard en utilisant l'annotation @Service. Ce service sera géré par le conteneur de Spring et disponible pour injection :
@Service
public class RandomNumberService {
public Integer getRandomNumber() {
return (int) (Math.random() * 100);
}
}
@Route("/")
public class HelloWorldView extends Composite<FlexLayout> {
private final FlexLayout self = getBoundComponent();
private Button btn = new Button("Générer un Nombre Aléatoire");
public HelloWorldView(RandomNumberService service) {
self.setDirection(FlexDirection.COLUMN);
self.setMaxWidth(300);
self.setStyle("margin", "1em auto");
btn.setPrefixComponent(TablerIcon.create("dice"))
.setTheme(ButtonTheme.GRAY)
.addClickListener(e -> {
Toast.show("Le nouveau nombre aléatoire est " + service.getRandomNumber(), Theme.SUCCESS);
});
self.add(btn);
}
}
Dans cet exemple, le RandomNumberService est un bean de service Spring standard. La route HelloWorldView le déclare comme paramètre de constructeur, et Spring fournit automatiquement l'instance de service lorsque webforJ crée la route.
Remarquez que la classe de la route utilise uniquement l'annotation @Route - aucune stéréotype Spring comme @Component ou @Controller n'est nécessaire. Lorsque l'utilisateur navigue vers le chemin racine /, webforJ :
- Crée une nouvelle instance de
HelloWorldView - Demande à Spring de résoudre la dépendance
RandomNumberService - Passe le service au constructeur
- La route utilise le service injecté pour gérer les clics sur le bouton
Ce modèle fonctionne avec n'importe quel bean Spring - services, dépôts, classes de configuration ou composants personnalisés. L'injection de dépendances se produit de manière transparente, vous permettant de vous concentrer sur la construction de votre interface utilisateur pendant que Spring gère le câblage.