J'utilise tornado pour construire un serveur web et maintenant je crée un module de connexion. Voici le code:
demande tornade post: argument manquant
<body>
<form id="uploadForm">
<div class="form-group">
<label for="exampleInputEmail1">Email address</label>
<input name="name" type="email" class="form-control" id="exampleInputEmail1" placeholder="Email">
</div>
<div class="form-group">
<label for="exampleInputPassword1">Password</label>
<input name="password" type="password" class="form-control" id="exampleInputPassword1" placeholder="Password">
</div>
<button id="submit" type="button" class="btn btn-default">Submit</button>
</form>
</body>
<script src="../js/plugins/jquery-3.2.1.min.js?v=c9f5aeeca3"></script>
<script src="../js/common/bootstrap.min.js?v=5869c96cc8"></script>
<script>
$(function(){
$('#submit').on('click',function(){
$.ajax({
url: 'http://www.example.com/login',
method: 'POST',
data: $('#uploadForm').serialize(),
contentType: false,
processData: false,
cache: false,
success: function(data) {
console.log(data);
if(data === 'ERROR'){
alert('login failed')
}else{
location.href = data;
}
},
error: function (jqXHR) {
alert('ERROR');
}
});
});
});
</script>
Et la partie back-end:
class LoginHandler(tornado.web.RequestHandler):
def post(self, path):
try:
print(self.request.body)
name = self.get_body_argument("name")
except Exception as e:
print(e)
Quand je fais un test, je peux voir que print(self.request.body)
me donne le résultat: b'name=test&password=tttt'
mais après que je reçois une exception :
HTTP 400: Bad Request (Manquant nom de l'argument)
name=test
est juste dans le corps http, mais pourquoi il me dit le nom d'argument manquant? Tornado ne supporte que "application/x-www-form-urlencoded" et "multipart/form-data" comme type de contenu.