it-swarm.com.de

Methode nicht zulässig Flaschenfehler 405

Ich entwickle ein Flaschenregistrierungsformular und erhalte eine Fehlermeldung:

error 405 method not found.

Code:

import os
# Flask
from flask import Flask, request, session, g, redirect, url_for, abort, \
     render_template, flash, Markup, send_from_directory, escape
from werkzeug import secure_filename

from cultura import app

# My app
from include import User

@app.route('/')
def index():
    return render_template('hello.html')

@app.route('/registrazione', methods=['POST']) 
def registration():
    if request.method == 'POST':
        username= request.form.username.data
        return render_template('registration.html', username=username)
    else :
        return render_template('registration.html')

registration.html:

<html>
<head> <title>Form di registrazione </title>
 </head> 

    <body>
    {{ username }}
    <form id='registration' action='/registrazione' method='post'>
    <fieldset >
    <legend>Registrazione utente</legend>
    <input type='hidden' name='submitted' id='submitted' value='1'/>
    <label for='name' >Nome: </label> 
    <input type='text' name='name' id='name' maxlength="50" /> <br>
    <label for='email' >Indirizzo mail:</label>
    <input type='text' name='email' id='email' maxlength="50" />
     <br>
    <label for='username' >UserName*:</label>
    <input type='text' name='username' id='username' maxlength="50" />
     <br>
    <label for='password' >Password*:</label>
    <input type='password' name='password' id='password' maxlength="50" />
    <br>
    <input type='submit' name='Submit' value='Submit' />

    </fieldset>
    </form>
    </body>
    </html>

wenn ich localhost:5000/registrazione besuche, erhalte ich die Fehlermeldung. Was mache ich falsch?

14
Matteo

Dies liegt daran, dass Sie bei der Definition Ihrer Route nur POST -Anfragen zulassen.

Wenn Sie /registrazione in Ihrem Browser besuchen, wird zuerst eine GET-Anforderung ausgeführt. Erst wenn Sie das Formular absenden, führt Ihr Browser einen POST durch. Für ein sich selbst übermittelndes Formular wie das Ihre müssen Sie also mit beiden umgehen.

Verwenden 

@app.route('/registrazione', methods=['GET', 'POST']) 

sollte arbeiten.

41
Lukas Graf

Beispiel einer Flaschen-App mit wsgi mit JQuery, Ajax und json:

activecalls.py

from flask import Flask, jsonify

application = Flask(__name__, static_url_path='')

@application.route('/')
def activecalls():
    return application.send_static_file('activecalls/active_calls_map.html')

@application.route('/_getData', methods=['GET', 'POST'])
def getData():
    #hit the data, package it, put it into json.
    #ajax would have to hit this every so often to get latest data.
    arr = {}
    arr["blah"] = []
    arr["blah"].append("stuff");

    return jsonify(response=arr)


if __== '__main__':
    application.run()

Javascript json, /static/activecalls/active_calls_map.html:

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js">
</script>

<script>
$.ajax({
    //url : "http://dev.consumerunited.com/wsgi/activecalls.py/_getData",
    url : "activecalls.py/_getData",
    type: "POST",
    data : formData,
    datatype : "jsonp",
    success: function(data, textStatus, jqXHR)
    {
        //data - response from server
         alert("'" + data.response.blah + "'");
    },
    error: function (jqXHR, textStatus, errorThrown)
    {
         alert("error: " + errorThrown);

    }
});
</script>

Wenn du das ausführst. Die Benachrichtigungsbox druckt: "stuff".

1
Eric Leschinski

Nur für Leute, die jetzt lesen ... Sie müssen die/registrazione zuerst rendern, bevor Sie auf die Formulardaten zugreifen können. Einfach schreiben.

@app.route("/registrazione")
    def render_registrazione() -> "html":
        return render_template("registrazione.html")

bevor Sie die Registrierung def definieren (). Reihenfolge ist der Schlüssel. Sie können nicht auf Daten zugreifen, bevor die Sog verfügbar sind. Dies ist mein Verständnis des Problems.

0
Michael Migsch