Aller au contenu principal

Déploiement de Servlets Supplémentaires 25.02

Ouvrir dans ChatGPT

webforJ achemine toutes les requêtes via WebforjServlet, qui est mappé sur /* dans web.xml par défaut. Ce servlet gère le cycle de vie des composants, le routage et les mises à jour de l'interface utilisateur qui alimentent votre application webforJ.

Dans certains scénarios, vous pourriez avoir besoin de déployer des servlets supplémentaires aux côtés de votre application webforJ :

  • Intégration de bibliothèques tierces qui fournissent leurs propres servlets
  • Mise en œuvre d'API REST ou de webhooks
  • Gestion des téléchargements de fichiers avec un traitement personnalisé
  • Support de code basé sur des servlets anciens

webforJ propose deux approches pour déployer des servlets personnalisés aux côtés de votre application :

Approche 1 : Remappage de WebforjServlet

Cette approche remappe le WebforjServlet de /* à un chemin spécifique comme /ui/*, libérant ainsi l'espace d'URL pour des servlets personnalisés. Bien que cela nécessite de modifier web.xml, cela donne aux servlets personnalisés un accès direct à leurs modèles d'URL sans surcharge de proxy.

<web-app>
<!-- WebforjServlet remappé pour ne gérer que /ui/* -->
<servlet>
<servlet-name>WebforjServlet</servlet-name>
<servlet-class>com.webforj.servlet.WebforjServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>WebforjServlet</servlet-name>
<url-pattern>/ui/*</url-pattern>
</servlet-mapping>

<!-- Servlet personnalisé avec son propre modèle d'URL -->
<servlet>
<servlet-name>HelloWorldServlet</servlet-name>
<servlet-class>com.example.HelloWorldServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloWorldServlet</servlet-name>
<url-pattern>/hello-world</url-pattern>
</servlet-mapping>
</web-app>

Avec cette configuration :

  • Les composants webforJ sont accessibles sous /ui/
  • Le servlet personnalisé gère les requêtes à /hello-world
  • Aucun mécanisme de proxy impliqué - routage direct du conteneur de servlets
Configuration Spring Boot

Lors de l'utilisation de webforJ avec Spring Boot, il n'y a pas de fichier web.xml. Au lieu de cela, configurez le mappage des servlets dans application.properties :

webforj.servlet-mapping=/ui/*

Cette propriété remappe WebforjServlet de l'/* par défaut à /ui/*, libérant ainsi l'espace d'URL pour vos servlets personnalisés. N'incluez pas de guillemets autour de la valeur - ils seront interprétés comme faisant partie du modèle d'URL.

Approche 2 : Configuration de proxy pour WebforjServlet

Cette approche garde WebforjServlet à /* et configure les servlets personnalisés dans webforJ.conf. Le WebforjServlet intercepte toutes les requêtes et les proxy vers les servlets personnalisés correspondants.

Configuration standard de web.xml

<servlet>
<servlet-name>WebforjServlet</servlet-name>
<servlet-class>com.webforj.servlet.WebforjServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>WebforjServlet</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>

<!-- Servlet personnalisé avec son propre modèle d'URL -->
<servlet>
<servlet-name>HelloWorldServlet</servlet-name>
<servlet-class>com.example.HelloWorldServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloWorldServlet</servlet-name>
<url-pattern>/hello-world</url-pattern>
</servlet-mapping>
</web-app>

Configuration de webforJ.conf

servlets = [
{
name = "hello-world"
class = "com.example.HelloWorldServlet"
}
]

Avec cette configuration :

  • WebforjServlet gère toutes les requêtes
  • Les requêtes à /hello-world sont proxy vers HelloWorldServlet