🦔

【Django】Pythonで作るRest API【15Get Post By Id】

2023/02/02に公開

【15Get Post By Id】

YouTube: https://youtu.be/fm08afmt9JA

https://youtu.be/fm08afmt9JA

今回は「Post」の個別データを取得するビュー作成を行います。
「Post」の「id」がクエリーのパラムスとして「pk」に設定されます。

myapp/posts/views.py
from django.shortcuts import render
from django.http import HttpResponse
from rest_framework import viewsets
from .models import Post
from .serializers import PostSerializer
from rest_framework.decorators import api_view
from rest_framework.response import Response

# Create your views here.
def helloWorld(request):
  # return HttpResponse('Hello World')
  hello = 'hello'
  return render(request, 'posts/index.html', {})

@api_view(['GET'])
def getAllPosts(request):
  posts = Post.objects.all()
  serializer = PostSerializer(posts, many=True)

  return Response(serializer.data)

@api_view(['POST'])
def createPost(request):
  data = request.data
  user = request.user

  post = Post.objects.create(
    title = data['title'],
    content = data['content'],
    author = user
  )

  serializer = PostSerializer(post, many=False)
  return Response(serializer.data)

@api_view(['GET'])
def getPostById(request, pk):
  post = Post.objects.get(id=pk)

  serializer = PostSerializer(post, many=False)
  return Response(serializer.data)

class PostViewSet(viewsets.ModelViewSet):
  queryset = Post.objects.all()
  serializer_class = PostSerializer

ビューの作成ができましたら、
URLの設定を行います。

myapp/posts/url.py
from django.urls import path, include
from .views import helloWorld, PostViewSet, getAllPosts, createPost, getPostById
from rest_framework.routers import DefaultRouter

router = DefaultRouter()
router.register(r'posts', PostViewSet, basename='posts')

urlpatterns = [
    path('hello/', helloWorld, name='hello'),
    path('', getAllPosts, name='getAllPosts'),
    path('<str:pk>/', getPostById, name='getPost'),
    path('create/', createPost, name='createPost'),
    path('', include(router.urls))
]

ここまでできましたら、
ローカルサーバーを起動して

http://localhost:8000/posts/5/

にアクセスします。

動画では「id」が「5」となっていますが、
こちらは存在する「Post」の「id」に置き換えてください。

Discussion