questo:
url(r'^download/template/(?P<object_id>\d+)/$', views.myview().myfunction,model=models.userModel, name="sample")
dovrebbe essere:
url(r'^download/template/(?P<object_id>\d+)/$', views.myview.as_view(model=models.userModel), name="sample")
Vedi docs
Il tuo attuale implementazione non è thread-safe. Per esempio:
from django import http
from django.contrib.auth.models import User
from django.views import generic
class YourView(generic.TemplateView):
def __init__(self):
self.foo = None
def your_func(self, request, object_id, **kwargs):
print 'Foo', self.foo
self.foo = 'bar'
return http.HttpResponse('foo')
urlpatterns = patterns('test_app.views',
url(r'^download/template/(?P<object_id>\d+)/$', YourView().your_func,
kwargs=dict(model=User), name="sample"),
)
vi aspettate per stampare 'Foo Nessuno'? Bene fare attenzione perché l'istanza viene condiviso tra le richieste:
Django version 1.4.2, using settings 'django_test.settings'
Development server is running at http://127.0.0.1:8000/
Quit the server with CONTROL-C.
Foo None
[03/Dec/2012 08:14:31] "GET /test_app/download/template/3/ HTTP/1.1" 200 3
Foo bar
[03/Dec/2012 08:14:32] "GET /test_app/download/template/3/ HTTP/1.1" 200 3
Così, quando non è thread-safe, non si può presumere che sarà in uno stato pulito quando la richiesta si avvia - a differenza di quando si utilizza as_view() .
grazie amico, esattamente quello che voglio – user825904
@jpic Potresti elaborare? – Medorator
@buffer: presumibilmente jpic ritiene [la loro risposta] (http://stackoverflow.com/a/13678956) è l'approccio migliore, poiché esiste un problema di sicurezza del thread. –