Maison > Article > développement back-end > Utilisation des fonctions Golang pour la validation des paramètres dans la passerelle API
Dans la passerelle API, l'utilisation des fonctions Golang pour vérifier les paramètres de requête API peut : Empêcher les entrées invalides ou malveillantes d'entrer dans le système back-end. Vérifiez que le corps de la demande est vide. Vérifiez que les champs obligatoires existent. Vérifiez qu'un champ numérique est un nombre. Vérifiez qu'un champ de chaîne est conforme à une expression régulière.
Utilisation des fonctions Golang pour la validation des paramètres dans API Gateway
Introduction
Lors de la création d'applications basées sur le cloud, la validation des paramètres est cruciale pour empêcher les entrées non valides ou malveillantes d'entrer dans le système backend. Une passerelle API est une couche intermédiaire qui gère le trafic API et fournit des fonctionnalités de sécurité telles que la validation des paramètres. Ce didacticiel vous expliquera comment utiliser les fonctions Golang pour valider les paramètres de requête API dans API Gateway.
Prérequis
Configurer le projet
Créer un nouveau projet Golang
r : rreeeImportez les packages nécessaires :
go mod init my-validation-function
Écrivez une fonction Golang
Définissez une fonction Golang pour valider les paramètres de la requête :
import ( "context" "errors" "fmt" "net/http" "regexp" "strconv" "github.com/cloudevents/sdk-go/v2/event" )
Fonction de déploiement
Utilisez votre propre mécanisme de déploiement de passerelle API pour déployer la fonction et la configurer pour authentifier des requêtes API spécifiques. Consultez la documentation API Gateway pour connaître les étapes de déploiement spécifiques.
Cas pratique
Supposons que vous ayez un point de terminaison d'API /validate
qui reçoit deux paramètres de requête : name
et age
. En utilisant la fonction Golang que nous avons écrite, vous pouvez vérifier que l'entrée est conforme aux règles suivantes : /validate
,接收name
和age
两个查询参数。使用我们编写的Golang函数,可以验证输入是否符合以下规则:
name
是必填项,只能包含字母。age
name
est obligatoire et ne peut contenir que des lettres. age
est obligatoire et doit être un nombre.
Fonctionnalité de validation des tests à l'aide d'un client ou d'un navigateur REST :
Envoyer une requête avec des paramètres valides :
func validate(ctx context.Context, event event.Event) (*http.Response, error) { // 获取HTTP请求正文 request := event.HTTP body := request.Body // 验证请求正文的必需字段 if body == nil || len(body) == 0 { return nil, errors.New("request body is empty") } // 获取字段值 name := request.URL.Query().Get("name") age := request.URL.Query().Get("age") // 验证字段值 if name == "" { return nil, errors.New("name is required") } if age == "" { return nil, errors.New("age is required") } // 验证age是否为数字 if _, err := strconv.Atoi(age); err != nil { return nil, errors.New("age must be a number") } // 验证name是否符合正则表达式 nameRegex := regexp.MustCompile("[a-zA-Z]+") if !nameRegex.MatchString(name) { return nil, errors.New("name must contain only letters") } // 返回验证成功的响应 return &http.Response{ StatusCode: http.StatusOK, Body: http.NoBody, }, nil }
Envoyer une requête avec des paramètres invalides : GET /validate?name=John&age=30
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!