TurboGears - RESTful Uygulamalar
REST, şu anlama gelir: REsunum STate Transfer. REST, web standartları tabanlı bir mimaridir ve veri iletişimi için HTTP Protokolünü kullanır. Her bileşenin bir kaynak olduğu ve bir kaynağa HTTP standart yöntemleri kullanılarak ortak bir arayüzle erişildiği bir kaynak etrafında döner. REST ilk olarakRoy Fielding in 2000.
RestController nedir
TurboGears'taki RestController, yalnızca URL'ye değil, isteğin yöntemine erişmek için bir mekanizma sağlar. Standart HTTP ifadeleri şunları içerir: GET, POST, PUT ve DELETE. RestController bunları destekler ve ayrıca URL dağıtımı için verilerin formlar ve listeler olarak görüntülenmesini kullanıcı için biraz daha kolay hale getiren birkaç kısayol ekler.
RESTful'un TurboGears ile nasıl çalıştığını açıklamak için, bir öğrenci listesini ortaya çıkaran basit bir web hizmeti tanımlayacağız.
Öğrenci modeli kodu aşağıda verilmiştir -
model \ öğrenci.py
# -* - coding: utf-8 -*-
from sqlalchemy import *
from sqlalchemy.orm import mapper, relation, relation, backref
from sqlalchemy import Table, ForeignKey, Column
from sqlalchemy.types import Integer, Unicode, DateTime
from hello.model import DeclarativeBase, metadata, DBSession
from datetime import datetime
class student(DeclarativeBase):
__tablename__ = 'student'
uid = Column(Integer, primary_key = True)
name = Column(Unicode(20), nullable = False, default = '')
city = Column(Unicode(20), nullable = False, default = '')
address = Column(Unicode(100), nullable = False, default = '')
pincode = Column(Unicode(10), nullable = False, default = '')
Şimdi RestController'a dayalı bir denetleyici oluşturun ve öğrencilerin listesini json biçiminde listelemek için bir görünüm işlevi sağlayın.
Denetleyiciler \ student.py
from tg import RestController
from tg import expose
from hello import model
from hello.model import DBSession
from hello.model.student import student
from tg.decorators import with_trailing_slash
class StudentController(RestController):
@expose('json')
def get_all(self):
students = DBSession.query(student).all()
return dict(students=students)
Aşağıdaki satırları dahil ederek bu StudentController'ı uygulamanın RootController'ına bağlayın. root.py -
from hello.controllers.student import StudentController
class RootController(BaseController):
students = StudentController()
Gitmek http://localhost:8080/students json formatında kodlanmış öğrencilerimizin listesini sağlayacaktır.
Öğrencimizi veritabanına nasıl kaydedeceğimizi tanımlamak için post yöntemini kullanıyoruz. Bu yöntem ne zaman çağrılır http://localhost:8080/student url'ye bir POST isteği kullanılarak erişiliyor -
@expose('json')
def post(self, name, city, address, pincode):
newstudent = student(name = name, city = city, address = address, pincode = pincode)
DBSession.add(newstudent)
DBSession.flush()
return dict(student = newstudent)
Kullanmak get_one() yöntem, veritabanından kullanıcıya bir öğe görüntüleyebiliriz -
@expose('json')
def get_one(self, movie_id):
newstudent = DBSession.query(student).get(uid)
return dict(movie = movie)
PUT, mevcut bir kaydı REST kullanarak güncellemek için kullanılan yöntemdir -
@expose('json')
def put(self, name = name, city = city, address = address, pincode = pincode, **kw):
newstudent = DBSession.query(student).get(name)
newstudent.name = name
newstudent.city = city
newstudent.address = address
newstudent.pincode = pincode
return dict(student = newstudent)
Silme iş atı, post_delete yöntemine eklenir. Burada aslında kaydı veritabanından kaldırıyoruz ve ardından listeleme sayfasına geri yönlendiriyoruz -
@expose('json')
def post_delete(self, uid, **kw):
newstudent = DBSession.query(student).get(uid)
DBSession.delete(newstudent)
return dict(movie = newstudent.uid)