2017-07-31 2 views
0

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.

Répondre

0

Ainsi, lorsque nous envoyons une demande de publication au serveur, nous devons envoyer la requête avec le bon contentType. Par exemple,

$.ajax({ 
      url: 'http://www.example.com/login', 
      method: 'POST', 
      data: $('#uploadForm').serialize(), 
      contentType: 'application/x-www-form-urlencoded', 
      processData: false, 
      ... 

De plus, nous pouvons négliger le contentType en ajax comme 'application/x-www-form-urlencoded' est réglé par défaut.