- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一些特殊的要求,我正在尝试找出编码它的最佳方法。 最好是效率第一,可维护性第二。要求是这样的(请耐心等待):
我的 Django 网站上有一个功能,旨在为注册和未注册用户提供服务。此功能将通过每个用户的PIN 码进行控制。我要求这些引脚是随机生成的(而不是串行生成的)。
PIN码需要容易记住 - 这意味着PIN码len
成为一个因素。因此我要使用 4 位 PIN 码。仅限数字,因为字母数字不如纯数字更容易记住(根据我进行的可用性测试 - 我坚持这些结果)。
我不能在 pin 码之间发生冲突,因为它们也将用作标识符 - 所以它们都必须是唯一的。我的范围将介于 0000 到 9999 之间。只能有 10K 种独特的组合。这是限制性的,但是个人识别码的可内存性比可能的个人识别码池的大小具有更高的优先级。所以我会牺牲。
最后,注册用户的密码将被永久分配。另一方面,未注册的用户将被分配保留预订时间不超过 24 小时的 PIN 码,之后它们就会过期 - 因此再次进入未使用的 PIN 码池。
想象一下我的上述数据模型(在 models.py
中)如下所示:
class Inbox(models.Model):
pin_code = models.CharField(default='0')
owner = models.ForeignKey(User)
creation_time = models.DateTimeField(auto_now_add=True)
在 views.py
中,我需要一种方法为我创建的每个 Inbox
对象分配可用的 pin_code
。最有效的逻辑是什么?我认为可以采用以下方法:
def expire_pin(time_difference=None):
#admin user (with id 1) is assumed as the 'unregistered user'
Inbox.objects.filter(creation_time__lte=time_difference,owner_id=1).update(pin_code='0')
def get_pin():
parent_list = ['{:04d}'.format(i) for i in range(10000)]
day_ago = timezone.now() - timedelta(hours=24)
expire_pin(day_ago)
to_exclude = Inbox.objects.filter(~Q(pin_code='0')).values_list('pin_code',flat=True)
new_list = [item for item in parent_list if item not in to_exclude]
return random.choice(new_list)
<小时/>
可选:您不必阅读它,但这就是我使用 pin_code
的目的。每个用户(注册和未注册)都会分配一个收件箱,可以通过 example.com/pin/XXXX
访问(XXXX
是 pin_code
)。用户可以通过社交媒体与 friend 分享这个收件箱地址。然后, friend 可以通过他们的手机号码登录,查看前用户专门为该 friend 留下的内容。捕获漂移?
我需要为注册和未注册用户提供此功能 - 因此甚至需要为未知用户分配 pin_code
。但我希望能够回收未注册的用户代码,这样我就不会太快用完 10K 种可能性。我在这个网站上有相当大的用户群。
最终,我将用完 10K 种组合。我想我会编写代码,此后可以无缝切换到 5 位引脚。但即使在这种情况下,如果任何 4 位密码过期并可用,它们将在分配期间获得第一优先权。如果您也能帮助我完成这部分,那就太好了!
最佳答案
您所需要的只是django-extensions
包的RandomCharField
。请参阅django-extensions docs .
RandomCharField(length=4, include_alpha=False)
# 7097
在您的代码中:
from django_extensions.db.fields import RandomCharField
class Inbox(models.Model):
pin_code = RandomCharField(length=4, unique=True, include_alpha=False)
owner = models.ForeignKey(User)
creation_time = models.DateTimeField(auto_now_add=True)
关于python - Django Web 应用程序的棘手编码逻辑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35880654/
我有以下两个表: T1(身份证,名字)T2 (id,hybrid_col) 我想做的是从 T2 中选择所有内容,如果 hybrid_col 是数字,则使用 T1 加入。基本上,hybrid_col 持
这是代码:https://play.golang.org/p/Sizbc3uJt_c 我尝试替换这个简单的循环 for c := n.FirstChild; c != nil; c = c.NextS
我在大学参加了微软编码挑战,提出的问题是: Write a program that takes two strings as input, one is a query, and the other
我需要比较以下函数的增长率: f(n)=2^n 和 g(n)=n^log(n)(当 n 接近正无穷大时)。 这可能吗? 最佳答案 令 n = 2^k。我们有: 2^n = 2^(2^k) n^log(
我的服务器快满了,我需要自动删除文件。文件通常每天都会添加到我的服务器,但有时会有暂停,使它们每两周或每月一次。他们停止进来几个月然后又开始了,这是不可预测的。 我的脚本需要删除超过 30 天的文件但
我无法获得适用于 SonarQube 4.0 的代理配置,以便我可以安装插件。 当我打开 http://localhost:9000/updatecenter/available它显示错误:“未连接到
标题不是很清楚,但很难描述我遇到的问题。 让我们考虑一个实现了 == 和 != 方法的 Signal 类。 (这是我的简化版)。 import numpy as np class Signal:
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我想将焦点设置到我网站上的文本字段。有两个问题: 文本字段位于外部页面(我无法控制)。它使用 iframe 嵌入到我的页面中。 每次加载页面时,文本字段都会生成一个自己的随机 ID。 这是我想要聚焦的
我有一个非常棘手的问题,我现在正试图弄清楚它, 我有这个查询结果集 SELECT * FROM Orders OrderID | OrderAmount | OrderDate | E
当我启动 webkit 浏览器实例并输入 http://localhost 时,$this.innerWidth()的结果是对的(我用的是jQuery)。 但是如果我尝试刷新页面, $this.inn
首先我知道有很多人问过这个问题!但我还有一个问题。 我正在做的是,通过 phpmyadmin 将我的数据库 (MySql) 导出到 .sql 文件。没问题。当我尝试将其导入“SQLite Databa
我这里有一个棘手的问题..请帮助.. 我有一个名为“DemoViewController”的 ViewController,两个不同的 Xib(Demo1Controller.xib 和 Demo2C
哦,嗨。我是一名初级 Java 开发人员,在空闲时间从事一些基于 2D 图 block 的游戏。现在我正在尝试实现游戏模型中非常基本的东西 - 各种类型的对象如何彼此交互。我希望有一天添加网络支持,所
假设我有以下两个表: PRICE price_id price room_id nr_of_people 1 80 1
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我正在开发一个 jQuery 插件,人们可以将其包含在自己的页面中。该插件在我正在操作的位于不同域的服务中生成作业。 为了突破域边界,我使用 jQuery 的 JSONP 功能,它可以很好地生成作业。
我看到很多开发人员只是盲目地按照分步说明将 JAX-WS RI jar 复制到 Tomcat 认可文件夹。也没有看到有人问为什么。 1) 如果 JDK 6 update 4+ 已经包含 JAX-WS
我找不到解决这个问题的方法。 这是我想要的渲染图: http://jsfiddle.net/kQSxb/ HTML: Lorem ipsum dolor s
我是一名优秀的程序员,十分优秀!