0

編集: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))
4

0 に答える 0