Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/310.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 烧瓶教程-找不到404_Python_Python 2.7_Flask_Http Status Code 404 - Fatal编程技术网

Python 烧瓶教程-找不到404

Python 烧瓶教程-找不到404,python,python-2.7,flask,http-status-code-404,Python,Python 2.7,Flask,Http Status Code 404,我刚刚完成了烧瓶基础教程(),尽管我已经完成了每一步,但当我尝试时 python flaskr.py 我得到的是一个404未找到错误 在服务器上找不到请求的URL。如果您手动输入URL,请检查拼写并重试。 这是文件中的代码 import os import sqlite3 from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash #create app app =

我刚刚完成了烧瓶基础教程(),尽管我已经完成了每一步,但当我尝试时

python flaskr.py

我得到的是一个
404未找到
错误

在服务器上找不到请求的URL。如果您手动输入URL,请检查拼写并重试。

这是文件中的代码

import os
import sqlite3
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash

#create app
app = Flask(__name__)
app.config.from_object(__name__)

#load default conf and override config from an env var
app.config.update(dict(
    DATABASE=os.path.join(app.root_path, 'flaskr.db'),
    DEBUG=True,
    SECRET_KEY = 'dev key',
    USERNAME = 'admin',
    PASSWORD = 'admin'
))
app.config.from_envvar('FLASKR_SETTINGS', silent=True)

def connect_db():
    """connect to the specific db"""
    rv = sqlite3.connect(app.config['DATABASE'])
    rv.row_factory = sqlite3.Row
    return rv

if __name__== '__main__':
    app.run()


def get_db():
    """opens a new db connection if there is none yet for the cyrrent app"""
    if not hasattr(g, 'sqlite_db'):
        g.sqlite_db = connect_db()
        return g.sqlite_db

@app.teardown_appcontext
def close_db(error):
    """closes the db again at the end of the request."""
if hasattr(g, 'sqlite_db'):
    g.sqlite_db.close()

def init_db():
    with app.app_context():
        db = get_db()
        with app.open_resource('schema.sql', mode='r') as f:
            db.cursor().executescript(f.read())
        db.commit()


@app.route('/')
def show_entries():
    db_get_db()
    cur = db.execute('select title, text from entries order by id desc')
    entries = cur.fetchall()
    return render_template('show_entries.html', entries=entries)

@app.route('/add', methods=['POST'])
def add_entry():
    if not session.get('logged_in'):
        abort(401)
    db = get_db()
    db.execute('insert into entries (title, text) values (?,?)',
        [request.form['title'], request.form['text']])
    db.commit()
    flash('New entry was successfully posted')
    return redirect(url_for('show_entries'))

@app.route('/login', methods=['GET', 'POST'])
def login():
    error = None
    if request.method == 'POST':
        if request.form['username'] != app.config['USERNAME']:
            error = 'Invalid username'
        elif request.form['password'] != app.config['PASSWORD']:
            error = 'Invalid password'
        else:
            session['logged_in'] = True
            flash('You were logged in')
            return redirect(url_for('show_entries'))
    return render_template('login.html', error=error)

@app.route('/logout')
def logout():
    session.pop('logged_in', None)
    flash('You were logged out')
    return redirect(url_for('show_entries'))
这是我收到的控制台消息(加上3次刷新页面的尝试):

对可能出现的问题有什么建议吗?

您过早地将
应用程序.run()
调用

if __name__== '__main__':
    app.run()
这是在注册任何路由之前执行的。将这两行移到文件的末尾

接下来,
show\u entries()
中的第一行不正确:

def show_entries():
    db_get_db()

没有
db\u get\u db()
函数;这应该是
db=get_db()。在路由的末尾附加一个尾随斜杠后,错误消失了

@app.route('/hello')
    def hello():
        return 'Hello, World!'
改为

@app.route('/hello/')
    def hello():
        return 'Hello, World!'

问题解决了。希望这对正在寻找类似问题的任何人都有帮助。

这与问题中所述的问题完全不同,因为问题中根本没有到达路线注册。
@app.route('/hello/')
    def hello():
        return 'Hello, World!'