Как исправить 500 внутренних ошибок сервера в Python с помощью WebPy? - PullRequest
0 голосов
/ 01 апреля 2019

Когда я добавил строку кода в мой файл scripty.js, а также в мой main.py, у меня возникли проблемы с функцией POST:

scripty.js:

 var form = $('#register-form').serialize();
    $.ajax({
        url: '/postreg',
        type: 'POST',
        data: form,
        success: function (res) {
            res.preventDefault()
            console.log("done");

        }
    });

и main.py:

class PostRegistration:
    def POST(self):
        data = web.input()
        return data.username

и вот мой результат:

127.0.0.1:55126 - - [01/Apr/2019 18:37:25] "HTTP/1.1 GET /static/js/ripples.min.js.map" - 200 

Traceback (most recent call last):
  File "/home/amir/.local/lib/python3.6/site-packages/web/utils.py", line 70, in __getattr__
    return self[key]
KeyError: 'username'


During handling of the above exception, another exception occurred:


Traceback (most recent call last):
  File "/home/amir/.local/lib/python3.6/site-packages/web/application.py", line 257, in process
    return self.handle()

  File "/home/amir/.local/lib/python3.6/site-packages/web/application.py", line 248, in handle

    return self._delegate(fn, self.fvars, args)
  File "/home/amir/.local/lib/python3.6/site-packages/web/application.py", line 488, in _delegate
    return handle_class(cls)

  File "/home/amir/.local/lib/python3.6/site-packages/web/application.py", line 466, in handle_class
    return tocall(*args)

  File "/home/amir/PycharmProjects/SocialWeb/Controller.py", line 27, in POST
    return data.username
  File "/home/amir/.local/lib/python3.6/site-packages/web/utils.py", line 72, in __getattr__
    raise AttributeError(k)
AttributeError: 'username'

127.0.0.1:55124 - - [01/Apr/2019 18:37:30] "HTTP/1.1 POST /postreg" - 500 Internal Server Error

Ответы [ 2 ]

0 голосов
/ 01 апреля 2019

это мой HTML-файл регистрационной формы

<div class="container">
    <h2>Register Account</h2>

    <br /><br />

    <form id="register-form">

        <div class="form-group  label-static is-empty">
            <label for="username" class="control-label">Username</label>
            <input  id="username" class="form-control" type="text" placeholder="Choose a Username">
        </div>

        <div class="form-group  label-static is-empty">
            <label for="display_name" class="control-label">Full Name</label>
            <input id="display_name" class="form-control" type="text" placeholder="Enter your full name">

        </div>
        <div class="form-group  label-static is-empty">
            <label for="email" class="control-label">Email Address</label>
            <input id="email" class="form-control" type="email" placeholder="Enter your email">

        </div>
        <div class="form-group  label-static is-empty">
            <label for="password" class="control-label">Password</label>
            <input id="password" class="form-control" type="password" placeholder="Choose a password">

        </div>

        <button type="submit" class="btn btn-raised btn-info ">Submit <div class="ripple-container"></div> </button>
    </form>
</div>

0 голосов
/ 01 апреля 2019

запрос сериализации использует входные name атрибуты, а не id атрибуты.Ваш HTML-фрагмент, по-видимому, не включает в себя что-то вроде name="username".

Из документов jquery:

Примечание. Только «успешные элементы управления» сериализуются в строку.Значение кнопки отправки не сериализуется, так как форма не была отправлена ​​с помощью кнопки.Чтобы значение элемента формы было включено в сериализованную строку, элемент должен иметь атрибут name .Значения из флажков и переключателей (входы типа «радио» или «флажок») включаются, только если они отмечены.Данные из элементов выбора файлов не сериализуются.

...