1

Django アプリに、ユーザー ID を使用してオブジェクトを検索するメソッドがあります。このメソッドは、AJAX 呼び出しを介して呼び出されます。有効なユーザー アカウントにログインすると、何を試してもオブジェクトrequest.userとして評価され、必要なdjango.utils.functional.SimpleLazyObjectデータを取得できません (SkillEntry 一致クエリは、絶対に存在する場合でも存在しません)。私は Django で解決策を試しました: ユーザーごとに下書きをフィルタリングするとエラーが発生し、役に立ちません。

ユーザーにユーザー オブジェクトの実際のインスタンスを参照させるにはどうすればよいですか?

コードを表示:

@login_required
def skill_set(request, name):
    skill = Skill.objects.get(slug=name) # Found.
    level = 0
    user = request.user
    if request.method == 'POST':
        if user.is_authenticated():
            entry = SkillEntry.objects.get(user=user.pk, skill=skill) # Not found.
            entry.level = request.POST['level']
            entry.save()
            return HttpResponse(status=200)
    else:
        return HttpResponseForbidden()

JavaScript クライアント側コード:

function setSkill(skill, value) {
  var req = new XMLHttpRequest();
  req.open("POST", "/skill/" + skill + "/set/", true);
  csrftoken = getCookie('csrftoken');
  req.setRequestHeader("X-CSRFToken", csrftoken);
  req.send('level=' + value);
  var elem = document.getElementById('level');
  elem.innerHTML = "My skill level is " + value + ".";
}

セッション情報を維持するためにリクエストに設定する必要があるものはありますか? 私は、以前のバージョンの Django でこのようなことを成功させたことがあると断言できます。私は1.4.3を使用しています。

編集:

私のmodels.pyのモデル定義は次のとおりです。

class Skill(models.Model):
    name = models.CharField(max_length=100)
    slug = models.CharField(max_length=100, blank=True)
    keywords = models.CharField(max_length=120, blank=True, help_text='List of additional keywords this skill should show up for in search')
    description = models.TextField(null=True, blank=True)
    parent = models.ForeignKey('Skill', null=True, blank=True, help_text='Parent skill.  Leave blank if this is a root category.')

    def save(self, *args, **kwargs):
        if not self.id:
            self.slug = slugify(self.name)
        super(Skill, self).save(*args, **kwargs)

    def __unicode__(self):
        return self.name

    class Meta:
        ordering = ('name',)

class SkillEntry(models.Model):
    skill = models.ForeignKey('Skill')
    level = models.IntegerField()
    user = models.ForeignKey(User)
    last_updated = models.DateField(auto_now=True)

    class Meta:
        verbose_name_plural = 'Skill Entries'
        ordering = ('skill__name',)

    def __unicode__(self):
        return self.user.username + ' knows ' + self.skill.name + ' at level ' + str(self.level)
4

1 に答える 1

0

As rohan said you need not to use user.pk

Change this query

entry = SkillEntry.objects.get(user=user.pk, skill=skill) 

TO

    entry = SkillEntry.objects.get(user=user, skill=skill) 

Still if it is not working kindly share your models.py

于 2013-03-16T06:11:12.350 に答える