1

我想阻止高级计划在 30 天后过期的用户(尽管我可能会在几天后更改)。并将他们重定向到付款页面。如果到期日期已到,我通过检查数据库来做到这一点,这样它就可以阻止他们查看独家内容。我编写了以下代码来执行操作,但出现此错误:

ValidationError at /owo/
[u"'expire' value has an invalid date format. It must be in YYYY-MM-DD format."]

我也想知道这种方法是否是执行操作的最佳方式,或者我应该将代码移动并放在middleware.py中。

楷模

class Paid(models.Model):
   user=models.ForeignKey(User)
   pub_date=models.DateTimeField()
   expire = models.DateField(_('expire'), default=None, blank=True, null=True, db_index=True)
   active=models.BooleanField(_('active'), default=False, db_index=False)
   sid=models.CharField(max_length=100,default='1303908')
   mode=models.CharField(max_length=10, default='2CO')
   li_0_type=models.CharField(max_length=100, default='Product')
   li_0_name=models.CharField(max_length=100, default='Monthly Subscription')
   li_0_price=models.CharField(max_length=100, default='500')


   def __unicode__(self):
       return self.user

   def is_active(self):
       return self.active

   def is_expired(self):
       if self.expire is None:
          return False
       else:
          return self.expire < date.today()

拯救付费用户的观点:

def two_check(request):
    if request.method=="POST":
      form=PaidForm(request.POST)
      if form.is_valid():
         data=form.cleaned_data
         newtwo=Paid(
            user=request.user,
            pub_date=datetime.datetime.now(),
            expire=datetime.datetime.now()+ datetime.timedelta(days=29),
            active=data['active'],
            sid=data['sid'],
            mode=data['mode'],
            li_0_type=data['li_0_type'],
            li_0_name=data['li_0_name'],
            li_0_price=data['li_0_price'])
         newtwo.save()
         return HttpResponseRedirect('/confirm_two/')
      else:
         return HttpResponse('Oops error')
   else:
     return render_to_response('two.html'{'PaidForm':PaidForm},context_instance=RequestContext(request))

用于检查过期用户的视图

def check_use(request):
   d=datetime.date.today()
   if request.user.is_authenticated():
       if Paid.objects.get(expire='expire') >= d.strptime("%Y-%m-%d"):
          return HttpResponseRedirect('/pay_plan/')
       else:
          return HttpResponseRedirect('/owo/')
   return render_to_response('eyowo.html',{'Paid':Paid},context_instance=RequestContext(request))
4

2 回答 2

1

好吧,在第一个实例中,我可以在您的代码中看到两个问题

1.不明白这个意思:

Paid.objects.get(expire='expire')

您正在尝试根据用户获取付费对象并查找付费对象是否已过期,因此这样的事情更合适

Paid.objects.get(user=request.user).expire >= d.strptime("%Y-%m-%d"):

另一个问题与karthikr提到的相同

expire 是一个日期字段而不是日期时间,因此你得到一个 ValidationError 提到的数据类型是一个日期,其中发送的数据类型是日期时间

由于错误提到它期望日期时间在 'YYYY-MM-DD'

尝试这样的事情

>>> datetime.datetime.now().date() + datetime.timedelta(days=29)
datetime.date(2013, 7, 6)
>>> str(datetime.datetime.now().date() + datetime.timedelta(days=29))
'2013-07-06'

尝试在 YYYY-MM_DD 中发送此字符串

于 2013-06-07T18:11:44.453 回答
1

线

 expire=datetime.datetime.now()+ datetime.timedelta(days=29)

正在提供日期和时间值,您只需要日期 - 所以使用.date()

IE;

 expire = datetime.datetime.now().date() + datetime.timedelta(days=29)
于 2013-06-07T14:57:08.747 回答