Parlez du cycle de vie de Servlet ?
Servlet a une bonne définition du cycle de vie, y compris le chargement et l'instanciation, l'initialisation et le traitement La demande et le service prennent fin. Cette durée de vie est exprimée par les méthodes init(), service() et destroy de l'interface javax.servlet.Servlet. (Étude recommandée : questions d'entretien Java)
Une fois le servlet instancié par le serveur, le conteneur exécute sa méthode init, et lorsque la requête arrive, il exécute sa méthode de service. La méthode dispatche automatiquement l'exécution correspondant à la requête. Les méthodes doXXX (doGet, doPost), etc., appellent sa méthode destroy lorsque le serveur décide de détruire l'instance.
Le conteneur Web charge le servlet et le cycle de vie commence. Initialisez le servlet en appelant la méthode init() du servlet. Ceci est réalisé en appelant la méthode service(), et différentes méthodes do***() sont appelées en fonction de différentes requêtes. Pour mettre fin au service, le conteneur Web appelle la méthode destroy() du servlet.
Quelle est la différence entre forward() et redirect() dans l'API Servlet ?
1. À partir de l'affichage de la barre d'adresse,
forward est lorsque le serveur demande des ressources. Le serveur accède directement à l'URL de l'adresse cible. et met cette URL. Le contenu de la réponse est lu puis envoyé au navigateur. Le navigateur ne sait pas d'où vient le contenu envoyé par le serveur, donc sa barre d'adresse est toujours l'adresse d'origine
la redirection est la. côté serveur Selon la logique, un code d'état est envoyé pour indiquer au navigateur de demander à nouveau cette adresse. Ainsi, la barre d'adresse affiche la nouvelle URL. La redirection signifie donc que le client envoie deux requêtes au serveur et accepte également deux réponses.
2. En termes de partage de données
transférer : la page transférée et la page transférée peuvent partager les données dans la demande
redirection : ne peut pas partager de données.
la redirection peut non seulement rediriger vers d'autres ressources de l'application actuelle, mais également rediriger vers des ressources d'autres applications sur le même site, et même rediriger vers d'autres sites en utilisant des ressources d'URL absolues.
La méthode forward ne peut transférer les requêtes qu'entre les ressources au sein de la même application Web. Le transfert est une opération à l'intérieur du serveur.
la redirection se produit lorsque le serveur demande au client de le laisser. Le client relance le processus. demande.
Ainsi, vous pouvez dire que la redirection est une demande indirecte, mais vous ne pouvez pas dire "si une demande appartient au transfert ou à la redirection"
Depuis l'application Localement parlant.
forward : généralement utilisé lorsque les utilisateurs se connectent, transférer vers le module correspondant selon le rôle
redirect : généralement utilisé pour revenir à la page principale et sauter lorsque l'utilisateur se connecte. aller sur d'autres sites Web, etc.
4. En termes d'efficacité
vers l'avant : élevé.
redirection : faible.
Quelle est la différence entre request.getAttribute() et request.getParameter() ?
1 request.getParameter() est obtenu grâce à l'implémentation. du conteneur Données transmises via des méthodes telles que post, get, etc.
request.setAttribute() et getAttribute() circulent uniquement dans le conteneur Web et ne sont qu'en phase de traitement de la demande.
2. getAttribute renvoie un objet et getParameter renvoie une chaîne
3. getAttribute() est toujours utilisé avec setAttribute() Seulement après l'avoir défini avec setAttribute() au préalable. La valeur peut être obtenue via getAttribute(), qui transmet les données de type Objet. Et il doit être utilisé dans le même objet de requête pour être valide.
Et getParameter() sert à recevoir les paramètres soumis par get ou post du formulaire
La différence entre l'inclusion statique jsp et l'inclusion dynamique
1. < ;%@include file="xxx.jsp"%> est une instruction de compilation en jsp L'inclusion de son fichier se produit lors de la conversion de jsp en servlet, et
2. L'utilisation de l'inclusion statique ne générera qu'un fichier de classe , lors de l'utilisation de l'inclusion dynamique, plusieurs fichiers de classe seront générés
3. Utilisez l'inclusion statique L'objet de requête de la page incluse et de la page incluse est le même objet, car l'inclusion statique copie simplement le contenu de la page incluse. à la page incluse ;
La page contenant l'inclusion dynamique et la page incluse ne sont pas la même page. L'objet de requête de la page incluse peut obtenir une plage de paramètres relativement plus large. La page contenante peut être obtenue, mais également les paramètres transmis à la page contenante peuvent être obtenus. Vous pouvez également obtenir les paramètres transmis dans la page incluse
Quelles technologies sont utilisées pour implémenter chaque partie de MVC ? Comment l'implémenter ?
MVC est l'abréviation Model-View-Controller. Le modèle représente la logique métier de l'application (implémentée via des composants JavaBeans et EJB), la vue est la surface de présentation de l'application (générée par les pages JSP) et le contrôleur assure le contrôle des processus de l'application (généralement un servlet via ce modèle de conception). Divisez la logique d'application, la logique de traitement et d'affichage en différentes implémentations de composants. Ces composants peuvent être interagis et réutilisés.
Quels sont les objets intégrés dans jsp ? Quelles sont leurs fonctions ?
JSP a les 9 objets intégrés suivants :
1, demande de demande du client, cette demande contiendra les paramètres de la demande GET/POST
2, la page Web de réponse renvoie la réponse du client
3, l'attribut pageContext de la page Web est ici gestion
4, session session liée à la requête
5, contenu en cours d'exécution par le servlet d'application
6, out sert à transmettre la sortie de la réponse
7, composants d'architecture de servlet de configuration
8, page Web JSP elle-même
9, exception pour les pages Web d'erreur, exceptions non interceptées
Http, La différence entre les méthodes get et post
1. Get est une demande de données au serveur, tandis que Post est une demande de soumission de données au serveur
2. informations au lieu de les modifier, similaire à la fonction de requête de base de données, les données ne seront pas modifiées
3. Les paramètres de la requête Get seront transmis après l'URL et les données demandées seront ajoutées à l'URL. à ? Diviser l'URL et transmettre les données. Les paramètres sont connectés avec &. Le XX dans %XX est ASCII exprimé en hexadécimal. Si les données sont des lettres/chiffres anglais, envoyez-les telles quelles. à +. S'il s'agit de caractères chinois/autres, chiffrez directement la chaîne avec BASE64.
4. Il existe une limite de taille pour les données transmises par Get. Étant donné que GET soumet les données via l'URL, la quantité de données pouvant être soumises par GET est directement liée à la longueur de l'URL des différents navigateurs. ont des exigences différentes sur la longueur de l'URL. Les restrictions sont différentes.
5. Les données demandées par GET seront mises en cache par le navigateur, et le nom d'utilisateur et le mot de passe apparaîtront en texte clair sur l'URL. D'autres peuvent vérifier les enregistrements de navigation historiques, et les données ne sont pas sécurisées.
Côté serveur, utilisez Request.QueryString pour obtenir les données soumises par la méthode Get
La requête de publication est envoyée au serveur Web en tant que contenu réel du message http, et les données sont placé dans l’en-tête HTML pour la soumission. La publication ne limite pas les données soumises. Post est plus sûr que Get Lorsque les données sont en chinois ou des données non sensibles, utilisez get car lors de l'utilisation de get, les paramètres seront affichés dans l'adresse. Pour les données sensibles et les données qui ne sont pas des caractères chinois, utilisez post.
6. POST représente une requête pouvant modifier les ressources sur le serveur, côté serveur, les données soumises dans la méthode Post ne peuvent être obtenues qu'à l'aide de Request.Form.
Que sont les cookies ? Quelle est la différence entre une session et un cookie ?
Le cookie est une technologie de session, un objet qui enregistre les informations de l'utilisateur sur le navigateur.
Différence :
(1) Données du cookie Stockées sur le navigateur du client, les données de session sont placées sur le serveur
(2) Les cookies ne sont pas très sûrs. D'autres peuvent analyser le COOKIE stocké localement et procéder à une tromperie des COOKIES Si la sécurité est la principale préoccupation, session
(3) La session sera enregistrée sur le serveur pendant une certaine durée. Lorsque l'accès augmente, cela consommera davantage de performances de votre serveur. Si vous envisagez principalement de réduire les performances du serveur, vous devez utiliser COOKIE (4) La limite d'un seul cookie sur le client est de 3K, ce qui signifie que un site internet est stocké sur le client Le cookie ne peut pas être 3K.Conclusion :
Stockez les informations importantes telles que les informations de connexion en tant que SESSION si d'autres informations doivent être conservées, elles peuvent être placées dans COOKIE ;Quelles sont les différences, les points communs et le champ d'application entre jsp et servlet ?
JSP est une extension de la technologie Servlet, qui est essentiellement une manière simple de Servlet. Une fois JSP compilé, il s'agit d'un "servlet-like". La principale différence entre Servlet et JSP est que la logique d'application de Servlet est dans le fichier Java et est complètement séparée du HTML dans la couche de présentation. Dans le cas de JSP, Java et HTML peuvent être combinés dans un fichier avec une extension .jsp. JSP se concentre sur les vues et les servlets sont principalement utilisés pour la logique de contrôle. Dans le framework Struts, JSP est situé dans la couche d'affichage du modèle de conception MVC et Servlet est situé dans la couche de contrôleComment le conteneur Tomcat crée-t-il une instance de classe de servlet ? Quels principes sont utilisés ?
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!