MENU
  • VPS(レンタルサーバ)比較
  • ITエンジニアの転職
  • IT技術入門(Engineers.LOG)
カテゴリー
  • IT関連 (623)
    • Bootstrap (2)
    • クラウド (4)
    • サーバー技術 (185)
    • ストレージ (7)
      • NetApp (7)
    • ネットワーク技術 (91)
      • Cisco (36)
      • Juniper (18)
      • 負荷分散装置 (17)
    • パソコン関連 (92)
      • MAC (25)
      • Windows (54)
    • プログラミング (154)
      • Ansible (11)
      • C言語 (23)
      • Python (111)
        • Django (20)
    • 仮想化 (88)
      • Docker (63)
      • VMware (23)
  • VPS (200)
    • ABLENET VPS (16)
    • Amazon Lightsail(VPS) (2)
    • ConoHaVPS (37)
    • mixhostVPS (4)
    • WebARENAIndigo (16)
    • XServerVPS (34)
    • お名前.com VPS (12)
    • さくらのVPS (24)
    • カゴヤクラウドVPS (13)
    • シンVPS (7)
  • レンタルサーバー (56)
    • エックスサーバー (38)
  • 光回線 (8)
  • 技術スキルアップ開発・学習 (7)
    • Envader (2)
    • RareTECH (2)
    • Udemy (3)
もう現役20年超えましたー。経験値ならだれにも負けないエンジニア技術ブログ
インフラエンジニアの技術LOG
  • VPS(レンタルサーバ)比較
  • ITエンジニアの転職
  • IT技術入門(Engineers.LOG)
インフラエンジニアの技術LOG
  • VPS(レンタルサーバ)比較
  • ITエンジニアの転職
  • IT技術入門(Engineers.LOG)
  1. ホーム
  2. IT関連
  3. 仮想化
  4. Docker
  5. 【Docker】Djangoのadmin管理画面にブログ投稿画面を追加する方法

【Docker】Djangoのadmin管理画面にブログ投稿画面を追加する方法

2020 6/27
Docker
2020年6月26日2020年6月27日

Dockerで構築したDjangoのデフォルトのadomin画面は以下のようになります。

デフォルトのadmin画面だと、ユーザー・グループの追加・編集のみしか機能がありません。

今回は、admin画面にブログ投稿用のエディタ機能を追加したのでまとめました。

目次
安くて高速!高性能VPSで快適開発!
最速5分でサーバー構築
>>>こちらをチェック

エンジニア必見! 技術力を伸ばすVPS徹底比較
>>>VPS比較

Docker上のDjangoでadmin画面にブログ投稿機能を追加する手順

Dockerコンテナで構築したDjangoの設定手順は前回の記事を参考にしてください。

あわせて読みたい
【docker-compose】Django+PostgreSQL+Nginxを連携した構築手順(CentOS8+VPS環境) VPS+CentOS8環境下で、docker-composeを利用し、Djangoの環境構築をしましたのでまとめます。 今回の構築では「docker-compose」でDjango+PostgreSQL+Nginxを連携した設...

admin管理画面に機能を追加したい場合、作成したアプリ配下の以下のファイルを編集します。

  • models.py
  • admin.py

「models.py」は追加機能を作成し、「admin.py」はadmin画面に追加・表示します。
以下、順に設定をしていきます。

「models.py」でブログ投稿機能とカテゴリー機能を作成する

「models.py」でブログ投稿機能とカテゴリー機能を作成します。
models.pyを編集で開くと「Create your models here.」から下の行で追加のモデルを作成します。

$ vim myhp/models.py 
from django.db import models

# Create your models here.

class Category(models.Model):
    title = models.CharField('カテゴリー', max_length=10)
    def __str__(self):
        return self.title
class Blog(models.Model):
    title = models.CharField('タイトル', max_length=60)
    text = models.TextField('テキスト')
    category = models.ForeignKey(Category, on_delete=models.PROTECT)
    created_at = models.DateField('作成日', auto_now_add=True)
    updated_at = models.DateField('更新日', auto_now=True)
    def __str__(self):
        return self.title

「models.py」で追加したモデルを作成

「models.py」で追加したモデルを作成するために「makemigrations」コマンドを実行します。

通常は、「python3 manage.py makemigrations myhp」で作成しますが、今回はDockerコンテナ上で動いているDjangoに対して実行するので「docker-compose run」コマンドを実行します。

※「web」は「docker-compose」のサービス名となります。

$ docker-compose run web python3 manage.py makemigrations myhp
Starting postgres ... done
Migrations for 'myhp':
  myhp/migrations/0005_blog_category.py
    - Create model Category
    - Create model Blog
$ 

うまくいくと上記のようにモデルが作成されます。

「admin.py」でadmin管理画面に作成したモデルを追加

次に上記で作成したモデル「Category」と「blog」をadmin管理画面に追加します。
作成したアプリ配下の「admin.py」を編集で開き「# Register your models here.」の下の行を追加します。

$ cat myhp/admin.py  
from django.contrib import admin

# Register your models here.

from .models import Category, Blog

admin.site.register(Category)
admin.site.register(Blog)

データベースと同期するために「migrate」コマンドを実施

最後にadmin管理画面とデータベースを同期するために「migrate」コマンドを実行します。
こちらもDockerコンテナ上なので以下のコマンドを実行します。

$ docker-compose run web python3 manage.py migrate
Starting postgres ... done
Operations to perform:
  Apply all migrations: admin, auth, contenttypes, myhp, sessions
Running migrations:
  Applying myhp.0005_blog_category... OK
$ 

うまくいくと、最後に「OK」と表示されます。

admin画面を開くと追加したモデルが表示されます。

admin画面に追加機能を作成し、表示させる手順は以上となります。

エンジニアスキルをアップする勉強法

ITエンジニアの開発・検証・学習としてインターネット上で専用のサーバ(VPS)を利用しましょう!
実務経験はVPSで学べます。

あわせて読みたい
現役エンジニアがおすすめするVPSレンタルサーバ比較(高速SSD限定) 格安VPS比較(2025年最新版)

Docker
よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!

コメント

コメントする コメントをキャンセル

email confirm*

post date*

日本語が含まれない投稿は無視されますのでご注意ください。(スパム対策)



検索
カテゴリー
新着記事
  • XServerVPS アニメ風 男の子 プログラミングをしている VPSを利用している 楽しそうにしている
    XServerVPSで証明書(SSL)を取得する方法
    2025年3月24日
    XServerVPS
  • レンタルサーバ アニメ風 女の子 楽しんでパソコンをしている 目がキラキラ
    WordPressがレンタルサーバよりVPSで利用する方がおすすめの理由
    2025年3月19日
    VPS
  • VPS レンタルサーバー アニメ風 女の子 プログラミングをしている VPSを利用している 楽しそうにしている
    VPSとクラウドの違いとは?初心者向けにわかりやすく解説
    2025年3月5日
    VPS
  • シンVPS アニメ風 女の子 パソコン プログラミングをしている VPSを利用している 楽しそうにしている
    シンVPSはWindows serverを利用できない。その理由と利用できるOSは?
    2025年3月4日
    シンVPS
  • シンVPS アニメ風 女の子 パソコン プログラミングをしている VPSを利用している 楽しそうにしている
    シンVPSでゲームを利用する環境はあるのか
    2025年3月4日
    シンVPS
  • シンVPS アニメ風 女の子 パソコン プログラミングをしている VPSを利用している 楽しそうにしている
    シンVPSのサイトの表示速度は他社に比べて早いのか?
    2025年3月4日
    シンVPS
目次
目次