mirror of
https://github.com/MichaelCade/90DaysOfDevOps.git
synced 2025-02-23 21:25:33 +07:00
added screenshots and more instructions
This commit is contained in:
parent
4d7338ef1c
commit
92e58eef5a
@ -7,11 +7,29 @@ Let's create a simple blog app with the help of [Flask](https://flask.palletspro
|
|||||||
Let's create a directory for our blog project. After you have created your project directory, create virtual environment using the following commands:
|
Let's create a directory for our blog project. After you have created your project directory, create virtual environment using the following commands:
|
||||||
- Windows
|
- Windows
|
||||||
``` bash
|
``` bash
|
||||||
|
c:\>python -m venv c:\path\to\myenv
|
||||||
```
|
```
|
||||||
- Linux//MacOs
|
- Linux//MacOs
|
||||||
``` bash
|
``` bash
|
||||||
|
python3 -m venv /path/to/new/virtual/environment
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Activate the virtual environment:
|
||||||
|
- Windows cmd
|
||||||
|
``` bash
|
||||||
|
C:\> <venv>\Scripts\activate.bat
|
||||||
|
```
|
||||||
|
|
||||||
|
- Windows powershell
|
||||||
|
``` powershell
|
||||||
|
<venv>\Scripts\Activate.ps1
|
||||||
|
```
|
||||||
|
|
||||||
|
- Linux//MacOs
|
||||||
|
``` bash
|
||||||
|
source <venv>/bin/activate
|
||||||
|
```
|
||||||
|
|
||||||
Now let's use `pip` to install required modules and packages that we will be using in this project.
|
Now let's use `pip` to install required modules and packages that we will be using in this project.
|
||||||
``` bash
|
``` bash
|
||||||
pip install flask markdown
|
pip install flask markdown
|
||||||
@ -19,7 +37,7 @@ pip install flask markdown
|
|||||||
|
|
||||||
## Creating the flask app
|
## Creating the flask app
|
||||||
|
|
||||||
First, create a new Flask app:
|
First, create a new Flask app, by creating a file in root of the project directory called `main.py`:
|
||||||
|
|
||||||
``` python
|
``` python
|
||||||
from flask import Flask, render_template
|
from flask import Flask, render_template
|
||||||
@ -35,8 +53,6 @@ def home():
|
|||||||
return render_template('index.html')
|
return render_template('index.html')
|
||||||
```
|
```
|
||||||
|
|
||||||
Create a directory called posts and add some Markdown files with blog post content.
|
|
||||||
|
|
||||||
Define a route to handle requests for individual blog posts:
|
Define a route to handle requests for individual blog posts:
|
||||||
|
|
||||||
``` python
|
``` python
|
||||||
@ -94,4 +110,35 @@ def home():
|
|||||||
return render_template('index.html', posts=posts)
|
return render_template('index.html', posts=posts)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Adding markdown posts
|
||||||
|
|
||||||
|
Now before running the app, let's add few posts.
|
||||||
|
Create a directory called `posts` and add some Markdown files with blog post content.
|
||||||
|
Let's add a `hello.md`:
|
||||||
|
|
||||||
|
``` markdown
|
||||||
|
# Hello
|
||||||
|
|
||||||
|
This is my first blog post
|
||||||
|
### Heading level 3
|
||||||
|
#### Heading level 4
|
||||||
|
##### Heading level 5
|
||||||
|
###### Heading level 6
|
||||||
|
|
||||||
|
I just love **bold text**.
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
Now, let's run the app, type the following command:
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
python main.py
|
||||||
|
```
|
||||||
|
|
||||||
|
Here is how it would look, I have 2 blog posts and have some gifs in my blog posts. Navigate to `127.0.0.0:5000` in a browser window:
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/1745f/1745f84365232e33ad647c69d746242a1c3b2f5b" alt="Home Page of our blog"
|
||||||
|
|
||||||
|
If we click on the `hello` blog post:
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/ef40d/ef40dbca75bec2fe8cf23b6eb4e15a6241ed9df5" alt="Hello blog post"
|
||||||
|
BIN
2023/images/day48-1.png
Normal file
BIN
2023/images/day48-1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 25 KiB |
BIN
2023/images/day48-2.png
Normal file
BIN
2023/images/day48-2.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 573 KiB |
Loading…
Reference in New Issue
Block a user