Quelle est la différence entre @RequestParam
et @PathVariable
lors de la gestion des caractères spéciaux?
+
a été accepté par @RequestParam
comme espace.
Dans le cas de @PathVariable
, a +
été accepté comme +
.
la source
Quelle est la différence entre @RequestParam
et @PathVariable
lors de la gestion des caractères spéciaux?
+
a été accepté par @RequestParam
comme espace.
Dans le cas de @PathVariable
, a +
été accepté comme +
.
@PathVariable
consiste à obtenir un espace réservé à partir de l'URI (Spring l'appelle un modèle d'URI) - voir Spring Reference Chapter 16.3.2.2 URI Template Patterns@RequestParam
consiste à obtenir également un paramètre à partir de l'URI - voir Spring Reference Chapter 16.3.3.3 Binding request parameters to method parameters with @RequestParamSi l'URL http://localhost:8080/MyApp/user/1234/invoices?date=12-05-2013
reçoit les factures de l'utilisateur 1234 le 5 décembre 2013, la méthode du contrôleur ressemblerait à:
@RequestMapping(value="/user/{userId}/invoices", method = RequestMethod.GET)
public List<Invoice> listUsersInvoices(
@PathVariable("userId") int user,
@RequestParam(value = "date", required = false) Date dateOrNull) {
...
}
En outre, les paramètres de demande peuvent être facultatifs et, à partir de Spring 4.3.3, les variables de chemin peuvent également être facultatives . Attention cependant, cela pourrait changer la hiérarchie du chemin URL et introduire des conflits de mappage de demande. Par exemple, /user/invoices
fournirait les factures de l'utilisateur null
ou des détails sur un utilisateur avec un ID "factures"?
@PathVariable
peut être utilisé dans n'importe quel RequestMethod@PathParam
ne fonctionne que s'il y a un espace réservé dans le modèle uri)@PathParam
est une annotation javax.ws.rs. docs.oracle.com/javaee/7/api/javax/ws/rs/PathParam.htmlAnnotation @RequestParam utilisée pour accéder aux valeurs des paramètres de requête à partir de la demande. Regardez l'URL de demande suivante:
Dans la demande d'URL ci-dessus, les valeurs de param1 et param2 sont accessibles comme suit:
Voici la liste des paramètres pris en charge par l'annotation @RequestParam:
@PathVariable
@ PathVariable identifie le modèle utilisé dans l'URI pour la demande entrante. Regardons l'URL de demande ci-dessous:
La demande d'URL ci-dessus peut être écrite dans votre MVC Spring comme ci-dessous:
L' annotation @ PathVariable n'a qu'une seule valeur d'attribut pour lier le modèle d'URI de demande. Il est autorisé d'utiliser l' annotation multiple @ PathVariable dans la méthode unique. Mais, assurez-vous que pas plus d'une méthode a le même modèle.
Il y a aussi une autre annotation intéressante: @MatrixVariable
Et la méthode du contrôleur pour cela
Mais vous devez activer:
la source
userName
aura un type param ou non? Je penche pour en faire une variable, mais cela pourrait aussi être un paramètre.@PathParam
et@RequestParam
être déclaré sans utiliser@RequestMapping
@RequestParam est utilisé pour les paramètres de requête (valeurs statiques) comme: http: // localhost: 8080 / calcul / pow? Base = 2 & ext = 4
@PathVariable est utilisé pour des valeurs dynamiques comme: http: // localhost: 8080 / calcul / sqrt / 8
la source
1)
@RequestParam
est utilisé pour extraire les paramètres de requêtewhile
@PathVariable
est utilisé pour extraire les données directement de l'URI:2)
@RequestParam
est plus utile sur une application Web traditionnelle où les données sont principalement transmises dans les paramètres de requête, tandis qu'elle@PathVariable
convient mieux aux services Web RESTful où l'URL contient des valeurs.3) l'
@RequestParam
annotation peut spécifier des valeurs par défaut si un paramètre de requête n'est pas présent ou vide en utilisant undefaultValue
attribut, à condition que l'attribut requis soitfalse
:la source
la source
Les deux annotations se comportent exactement de la même manière.
Seulement 2 caractères spéciaux '!' et '@' sont acceptés par les annotations @PathVariable et @RequestParam.
Pour vérifier et confirmer le comportement, j'ai créé une application de démarrage à ressort qui ne contient qu'un seul contrôleur.
Frapper les demandes suivantes, j'ai obtenu la même réponse:
! @ a été reçu comme réponse dans les deux demandes
la source
il se peut que le type midia application / x-www-form-urlencoded convertisse l'espace en + , et le récepteur décodera les données en convertissant le + en space.check l'url pour plus d'informations. http://www.w3.org/TR/html401/interact/forms.html#h-17.13.4.1
la source