編集:Djangoを使用しています。
私は次の機能を使用しています。この関数はデータの投稿に使用されているため、csrf 保護を追加する必要があります。そこで、関数の前に @csrf_protect を追加します。また、前述のように RequestContext を設定する必要がありますが、json_response を使用/返すときにその方法を理解できませんでした。
def message_updates(self, request):
cursor = request.session.get('cursor')
if not self.cache or cursor == self.cache[-1]['id']:
self.new_message_event.wait()
assert cursor != self.cache[-1]['id'], cursor
try:
for index, m in enumerate(self.cache):
if m['id'] == cursor:
return json_response({'messages': self.cache[index + 1:]})
return json_response({'messages': self.cache})
finally:
if self.cache:
request.session['cursor'] = self.cache[-1]['id']
else:
request.session.pop('cursor', None)
通常の場合、次のようなものを書いています。
@csrf_protect
def main(self, request):
if self.cache:
request.session['cursor'] = self.cache[-1]['id']
return render_to_response('index.html', {'MEDIA_URL': settings.MEDIA_URL, 'messages': self.cache},context_instance=RequestContext(request))