Как я могу использовать Django ORM в своем приложении Tornado?
У меня есть существующее приложение Django с базой данных и соответствующий файл models.py.
У меня есть новое приложение Tornado, которое предоставляет веб-сервис другим приложениям. Он должен читать/писать из той же базы данных, и есть код в файле моделей, который я хотел бы использовать.
Как лучше всего использовать базу данных Django и модели в обработчиках запросов Tornado? Это так же просто, как сделать символическую ссылку на папку проекта models.py Django, импортировать модули Django и использовать ее? Думаю, мне нужно было бы сделать settings.configure(), правильно?
Спасибо!
Ответы
Ответ 1
Добавьте путь к проекту Django в приложение Tornado PYTHONPATH env-var и соответствующим образом установите DJANGO_SETTINGS_MODULE. Затем вы сможете импортировать свои модели и использовать их, как обычно, при запуске Django при первоначальной настройке при первом импорте.
Вам не нужны никакие символические ссылки.
Ответ 2
есть пример здесь о том, как использовать django ORM и форму django внутри Tornado.
и вы можете прочитать Использование Django внутри веб-сервера Tornado для получения некоторой информации. оттуда был извлечен следующий код:
import sys
import os
import tornado.httpserver
import tornado.ioloop
import tornado.web
# django settings must be called before importing models
from django.conf import settings
settings.configure(DATABASE_ENGINE='sqlite3', DATABASE_NAME='dev.db')
from django import forms
from django.db import models
# Define your Model
class Message(models.Model):
"""
A Django model class.
In order to use it you will need to create the database manually.
sqlite> CREATE TABLE message (id integer primary key, subject varchar(30), content varchar(250));
sqlite> insert into message values(1, 'subject', 'cool stuff');
sqlite> SELECT * from message;
"""
subject = models.CharField(max_length=30)
content = models.TextField(max_length=250)
class Meta:
app_label = 'dj'
db_table = 'message'
def __unicode__(self):
return self.subject + "--" + self.content
# Define your Form
class DjForm(forms.Form):
subject = forms.CharField(max_length=100, required=True)
content = forms.CharField()
# Define the class that will respond to the URL
class ListMessagesHandler(tornado.web.RequestHandler):
def get(self):
messages = Message.objects.all()
self.render("templates/index.html", title="My title",
messages=messages)
class FormHandler(tornado.web.RequestHandler):
def get(self):
form = DjForm()
self.render("templates/form.html", title="My title", form=form)
def post(self):
data = {
'subject':self.request.arguments['subject'][0],
'content':self.request.arguments['content'][0],
}
form = DjForm(data=data)
if form.is_valid():
message = Message(**form.cleaned_data)
message.save()
self.redirect('/')
else:
self.render("templates/form.html", title="My title", form=form)
# map the Urls to the class
application = tornado.web.Application([
(r"/", ListMessagesHandler),
(r"/form/", FormHandler),
])
# Start the server
if __name__ == "__main__":
http_server = tornado.httpserver.HTTPServer(application)
http_server.listen(8888)
tornado.ioloop.IOLoop.instance().start()
и это еще один demo с джанго и торнадо...
Ответ 3
Я не мог заставить его работать с информацией, предоставленной @aragon в Django 1.8. Поскольку этот вопрос является одним из лучших результатов в Google при поиске интеграции Django + Tornado, вот как я получил его для работы в Django 1.8:
from django import forms
from django.db import models
from models import Operation #Own model
import django
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'database.db',
}
}
settings.configure(DATABASES=DATABASES)
if django.VERSION[:2] > (1,5):
django.setup()