Browse Source

Updated tutorial to the flask script

pull/1039/head
Armin Ronacher 11 years ago
parent
commit
a3a5075a94
  1. 50
      docs/tutorial/dbinit.rst
  2. 18
      docs/tutorial/setup.rst
  3. 1
      examples/flaskr/.gitignore
  4. 20
      examples/flaskr/flaskr.py

50
docs/tutorial/dbinit.rst

@ -20,28 +20,25 @@ require that we provide the path to the database which can introduce
errors. It's a good idea to add a function that initializes the database errors. It's a good idea to add a function that initializes the database
for you to the application. for you to the application.
To do this we can create a function called `init_db` that initializes the To do this we can create a function and hook it into the ``flask`` command
database. Let me show you the code first. Just add this function below that initializes the database. Let me show you the code first. Just add
the `connect_db` function in `flaskr.py`:: this function below the `connect_db` function in `flaskr.py`::
def init_db(): @app.cli.command()
with app.app_context(): def initdb():
db = get_db() """Initializes the database."""
with app.open_resource('schema.sql', mode='r') as f: db = get_db()
db.cursor().executescript(f.read()) with app.open_resource('schema.sql', mode='r') as f:
db.commit() db.cursor().executescript(f.read())
db.commit()
So what's happening here? Remember how we learned last chapter that the print 'Initialized the database.'
application context is created every time a request comes in? Here we
don't have a request yet, so we need to create the application context by The ``app.cli.command()`` decorator registers a new command with the
hand. Without an application context the :data:`~flask.g` object does not ``flask`` script. When the command executes Flask will automatically
know yet to which application it becomes as there could be more than one! create a application context for us bound to the right application.
Within the function we can then access :attr:`flask.g` and other things as
The ``with app.app_context()`` statement establishes the application we would expect. When the script ends, the application context tears down
context for us. In the body of the with statement the :data:`~flask.g` and the database connection is released.
object will be associated with ``app``. At the end of the with statement
the association is released and all teardown functions are executed. This
means that our database connection is disconnected after the commit.
The :func:`~flask.Flask.open_resource` method of the application object The :func:`~flask.Flask.open_resource` method of the application object
is a convenient helper function that will open a resource that the is a convenient helper function that will open a resource that the
@ -54,16 +51,15 @@ On that cursor there is a method to execute a complete script. Finally we
only have to commit the changes. SQLite 3 and other transactional only have to commit the changes. SQLite 3 and other transactional
databases will not commit unless you explicitly tell it to. databases will not commit unless you explicitly tell it to.
Now it is possible to create a database by starting up a Python shell and Now it is possible to create a database with the ``flask`` script::
importing and calling that function::
>>> from flaskr import init_db flask --app=flaskr initdb
>>> init_db() Initialized the database.
.. admonition:: Troubleshooting .. admonition:: Troubleshooting
If you get an exception later that a table cannot be found check that If you get an exception later that a table cannot be found check that
you did call the `init_db` function and that your table names are you did execute the `initdb` command and that your table names are
correct (singular vs. plural for example). correct (singular vs. plural for example).
Continue with :ref:`tutorial-views` Continue with :ref:`tutorial-views`

18
docs/tutorial/setup.rst

@ -29,7 +29,6 @@ config from the same file, in `flaskr.py`::
# Load default config and override config from an environment variable # Load default config and override config from an environment variable
app.config.update(dict( app.config.update(dict(
DATABASE=os.path.join(app.root_path, 'flaskr.db'), DATABASE=os.path.join(app.root_path, 'flaskr.db'),
DEBUG=True,
SECRET_KEY='development key', SECRET_KEY='development key',
USERNAME='admin', USERNAME='admin',
PASSWORD='default' PASSWORD='default'
@ -71,10 +70,7 @@ module. Flask will the initialize the variable from that module. Note
that in all cases only variable names that are uppercase are considered. that in all cases only variable names that are uppercase are considered.
The ``SECRET_KEY`` is needed to keep the client-side sessions secure. The ``SECRET_KEY`` is needed to keep the client-side sessions secure.
Choose that key wisely and as hard to guess and complex as possible. The Choose that key wisely and as hard to guess and complex as possible.
debug flag enables or disables the interactive debugger. *Never leave
debug mode activated in a production system*, because it will allow users to
execute code on the server!
We will also add a method that allows for easily connecting to the We will also add a method that allows for easily connecting to the
specified database. This can be used to open a connection on request and specified database. This can be used to open a connection on request and
@ -92,16 +88,14 @@ tuples.
rv.row_factory = sqlite3.Row rv.row_factory = sqlite3.Row
return rv return rv
Finally we just add a line to the bottom of the file that fires up the
server if we want to run that file as a standalone application::
if __name__ == '__main__':
app.run()
With that out of the way you should be able to start up the application With that out of the way you should be able to start up the application
without problems. Do this with the following command:: without problems. Do this with the following command::
python flaskr.py flask --app=flaskr --debug run
The ``--debug`` flag enables or disables the interactive debugger. *Never
leave debug mode activated in a production system*, because it will allow
users to execute code on the server!
You will see a message telling you that server has started along with You will see a message telling you that server has started along with
the address at which you can access it. the address at which you can access it.

1
examples/flaskr/.gitignore vendored

@ -0,0 +1 @@
flaskr.db

20
examples/flaskr/flaskr.py

@ -37,13 +37,14 @@ def connect_db():
return rv return rv
def init_db(): @app.cli.command()
def initdb():
"""Creates the database tables.""" """Creates the database tables."""
with app.app_context(): db = get_db()
db = get_db() with app.open_resource('schema.sql', mode='r') as f:
with app.open_resource('schema.sql', mode='r') as f: db.cursor().executescript(f.read())
db.cursor().executescript(f.read()) db.commit()
db.commit() print('Initialized the database.')
def get_db(): def get_db():
@ -76,7 +77,7 @@ def add_entry():
abort(401) abort(401)
db = get_db() db = get_db()
db.execute('insert into entries (title, text) values (?, ?)', db.execute('insert into entries (title, text) values (?, ?)',
[request.form['title'], request.form['text']]) [request.form['title'], request.form['text']])
db.commit() db.commit()
flash('New entry was successfully posted') flash('New entry was successfully posted')
return redirect(url_for('show_entries')) return redirect(url_for('show_entries'))
@ -102,8 +103,3 @@ def logout():
session.pop('logged_in', None) session.pop('logged_in', None)
flash('You were logged out') flash('You were logged out')
return redirect(url_for('show_entries')) return redirect(url_for('show_entries'))
if __name__ == '__main__':
init_db()
app.run()

Loading…
Cancel
Save