Как исправить «Эта страница не была найдена» в Flask Python? - PullRequest
0 голосов
/ 20 июня 2019

Я устанавливаю новый сервер во Flask для API. И сервер для рендеринга внешнего интерфейса во Flask. Итак, когда я делаю запрос к определенному маршруту API, я получаю странный ответ «Эта страница не найдена». Я, кажется, все в порядке, как я могу отладить эту ошибку? Другая странная вещь в том, что она всегда дает мне статус 200 ОК. Ошибка в маршруте: @app.route ('/ v1.0 / aluno / update /', method = ['POST'])

API SIDE


@app.route('/v1.0/aluno/<int:aluno_id>', methods=['GET'])
def aluno(aluno_id):
    if request.method == 'GET':
        cur = mysql.connection.cursor()
        query = "SELECT NOME, NUMERO, PASSWORD FROM aluno WHERE NUMERO=%s"
        cur.execute(query, (aluno_id,))
        data = cur.fetchall()
        if len(data) <= 0:
            return Response(status=404)
        else:
            aluno = {
                'nome': data[0][0],
                'numero': data[0][1],
                'password': data[0][2]
            }
            js = json.dumps(aluno)
            resp = Response(js, status=200, mimetype='application/json')
            resp.headers['Links'] = 'http://127.0.0.1/aluno'
            return resp

@app.route('/v1.0/aluno/delete/<int:aluno_id>', methods=['POST'])
def aluno_delete(aluno_id):
    if request.method == 'POST' and request.form['_method'] == 'delete':
        query = "DELETE FROM aluno WHERE NUMERO = %s"
        cur = mysql.connection.cursor()
        cur.execute(query, (aluno_id,))
        mysql.connection.commit()
        cur.fetchall()
        cur.close()
        return Response(status=200)

@app.route('/v1.0/aluno/update/<int:aluno_id>', methods=['POST'])
def aluno_update(aluno_id):
    form = AlunoForm(request.form)
    if request.method == 'POST' and form.validate():
        nome = request.form["nome"]
        numero = request.form["numero"]
        password = request.form["password"]
        cur = mysql.connection.cursor()
        query = "UPDATE aluno SET NOME=%s, NUMERO=%s, PASSWORD=%s WHERE NUMERO = %s"
        cur.execute(query, (nome, numero, password, aluno_id))
        mysql.connection.commit()
        cur.execute(
            "SELECT NOME, NUMERO FROM aluno WHERE NUMERO = %s", (aluno_id,))
        data = cur.fetchall()
        cur.close()

        print(" * DATA ")
        print(data)

        aluno = {
            'nome': data[0][0],
            'numero': data[0][1]
        }

        js = json.dumps(aluno)
        resp = Response(js, status=200, mimetype='application/json')
        resp.headers['Links'] = 'http://127.0.0.1/aluno'
        return resp
    elif request.method == 'POST' and not form.validate():
        resp = Response(status=400)
        resp.headers['Links'] = 'http://127.0.0.1/aluno'
        return resp

ПЕРЕДНЯЯ СТОРОНА


{% endblock %}


<script type="text/javascript" src="{{url_for('static', filename='js/jquery-3.2.1.min.js') }}"></script>

<script type="text/javascript" src="{{url_for('static', filename = 'js/bootstrap.min.js')}}"></script>

<script>
    function aluno_update(){
        try{
            let formElement = document.getElementById("aluno_update")
            //let formData = formElement.
            //console.log(formData)
            $.ajax({
                type: "POST",
                url: "http://127.0.0.1:80/v1.0/aluno/update/{{aluno['numero']}}",
                data: {'nome': 'João Luis','numero':'16172','password':'Password'},
                //dataType: 'json',
                success: function(data){
                    //location.href = "http://127.0.0.1:3000/v1.0/alunos/"
                    alert(data)
                    console.log(data)
                },
                error(jqXHR,JQueryXHR,errorThrown){
                    //console.log(formData)
                    alert(jqXHR)
                    alert(JQueryXHR)
                    alert(errorThrown)
                    console.log(jqXHR)
                    console.log(JQueryXHR)
                    console.log(errorThrown)
                }
            })
        }catch(err){
            alert(err)
        }
    }
</script>

Я пытался использовать POSTMAN вместо обычного веб-браузера. Сделать запрос к API. Но я получаю тот же ответ: «Эта страница не была найдена»

По крайней мере, я ожидал что-то вроде 400 плохих запросов или чего-то в этом роде.

https://github.com/joaogracio/SqlParser

1 Ответ

1 голос
/ 20 июня 2019

Проверка формы не пройдена, и вы получите 400 в соответствии с кодом ниже

   elif request.method == 'POST' and not form.validate():
        resp = Response(status=400)
        resp.headers['Links'] = 'http://127.0.0.1/aluno'
        return resp
...