djangoアプリ – その2.ブログアプリ作成

technologies

お疲れ様です。ベンジャミン天早です。
前回はdajngoの環境構築までを紹介しました。
今回から3回に分け、dajngoで出来る簡単なブログアプリを作っていきたいと思います。
初回の今回は、djangoフレームワークの機能説明とhtmlに文字を表示させる所までを実装していきます。

最後までお付き合い下さい。

※ 環境構築がまだの方は、下記URLから環境構築を実施して下さい。
http://benjamin.co.jp/blog/technologies/django-app_env/

作業環境
mac os 14.4.1
Python 3.12.2
django 5.0.4

目次

1.概要

まず初めに今回のdjangoの一連の流れについて解説していきます。

・ユーザーからのリクエストをurls.pyに渡し、views.pyへルーティング。

・urls.pyから受け取ったデータ(リクエスト)をhtmlファイルへ渡す。

・htmlがviews.py、サーバーを経由しユーザーへデータを返す。

ここまでが今回の django の一通りの流れになります。
では、以降から url.py , views.py , htmlファイルを実際に作成して行きます。

2.アプリ雛形を作成

前回の記事でdjango環境の立ち上げに成功したら次にアプリ環境を作成します。
今回は、まず初めにブログアプリを作成するので django_blog としています。好きなプロジェクト名にして下さい。

django-admin startapp django_blog

コマンドを実行すると、configと同列配下にdjango_blogというアプリフォルダーが作成されます。

3.setting.py

続いてconfig配下にあるsetting.py を修正します。



・INSTALLED_APPS に 今回作成したアプリフォルダー名(django_blog) を記載します。

# Application definition

INSTALLED_APPS = [
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django_blog'
]

・今回日本語を使用したいので LANGUAGE_CODE = ‘ja
・時刻を日本標準時刻に設定するためTIME_ZONE = ‘Asia/Tokyo‘ とします。

# Internationalization
# https://docs.djangoproject.com/en/4.2/topics/i18n/

LANGUAGE_CODE = 'ja'

TIME_ZONE = 'Asia/Tokyo'

4. urls.py

djangoの仕組みを理解できたら次にブラウザ上で Hello django を表示するところまでをやってみます。
まずは、config(プロジェクトフォルダー)配下にあるurls.pyを開きます。

url.py から views.py の関数へルーティングを設定していきます。

from django.contrib import admin
from django.urls import path
from django_blog.views import frontpage

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', frontpage),
]

5. views.py

次にviews.py で関数を設定します。
django_blog(アプリフォルダー)配下にあるviews.py を開きます。

views.py で urls.py で設定した関数を定義していきます。
ここでは、htmlファイルから受け取ったデータをユーザーへ返す処理をしています。

from django.shortcuts import render

def frontpage(request):
    return render(request, 'frontpage.html')

6.htmlファイル(frontpage.html)

続いてdjango_blog(アプリフォルダー)配下でtemplateフォルダーを作成し
そこにfrontpage.htmlを作成します。

frontpage.html で h1タグの中に Hello django を記載します。これで準備OKです。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <h1>Hello django</h1>
</body>
</html>

再度 サーバーを起動させ下記画像のように Hello django となっていれば成功です。

python manage.py runserver

7. 完成形

↑ ホーム画面

↑詳細ページ画面

8. おわりに

いかがでしたでしょうか。
今回は、djangoフレームワークを使って Hello django を画面に表示させる。
また、dajngoの仕組みについてまとめてみました。
次回は、ブログアプリ完成させるところまでをまとめてみたいと思います。
どうぞご期待下さい。

Related posts