通过电子邮件请求批准并处理它Python + Django

时间:2017-07-18 16:32:51

标签: python django email

也许我没有在搜索区域提出正确的问题,但我无法找到答案。我很确定很多人都有这个用例,但作为Django + Python的初学者,我需要问一下。

我有用户填写表单,数据存储在数据库中。基本上,此表单要求访问数据库,并在提交表单后,我希望我的程序向用户的经理发送电子邮件,并向DBA发送APPROVE或DENY。很简单,对吧?

我的想法是,在这封电子邮件中,我发送了两个URL,一个用于批准,一个用于拒绝请求。单击URL时,我会在manager_approval字段中向服务器发送更新并发送更新。

有没有人实施过此解决方案,或者可以指出一些可以帮助我的方法?

我正在使用Django + Python做所有事情。

此致 马科斯弗雷西亚

1 个答案:

答案 0 :(得分:1)

基本上这种技术用于电子邮件验证。这是你应该研究的地方。

假设您有模型,名为request,其中包含用户名等字段,用于标识请求访问权限的人,数据库名称,以及所有内容。但它也会有两个“类似密码”的字段,用于确定请求是否被拒绝。

class Request(models.Model):
    user = models.ForeignKey ...
    databasename = 
    date = 
    ...
    access_granted = models.BooleanField(default=False)
    deny_token = models.CharField()
    allow_token = models.CharField()

重点是在查看中按照保存请求生成这些令牌:

if request.method == POST:
    form = RequestForm(request.POST)
    if form.is_valid():
        data['user'] = form.cleaned_data['user'])
        data['databasename'] = form.cleaned_data['databasename'])
        ...
        data['access_token'] = GENERATE_USING_HASH_FUNCTION()
        data['deny_token'] = GENERATE_USING_HASH_FUNCTION()

        form.save(data)

然后您可以使用模块EmailMultiAlternatives发送html电子邮件,如下所示:

subject, from_email, to = 'Request', 'admin@example.com', form.cleaned_data['manager_email']
html_content = render_to_string(HTML_TEMPLATE, CONTEXT) # Just as any regular templates
text_content = strip_tags(html_content)

msg = EmailMultiAlternatives(subject, text_content, from_email, [to], reply_to=["admin@example.com"])
msg.attach_alternative(html_content, "text/html")
msg.send()

在该模板中,您构建了反向网址:

{% url 'app:grant_access' allow_token=token %} # "token" you get from context
{% url 'app:deny_access' deny_token=token %} # will become example.com/deny_access/7ea3c95, where 7ea3c95 is token

然后在您的应用的urls.py中添加以下行:

url(r'^allow_access/(?P<allow_token>[0-9]+)$', CheckAcessView.as_view(), name="app:grant_access"),
url(r'^deny_access/(?P<deny_token>[0-9]+)$', CheckAcessView.as_view(), name="app:deny_access"),]

然后创建CheckAcessView视图。您访问存储在数据库中的请求的位置,并检查例如url“allow_token”的参数是否等于存储allow_token。如果是,请将请求状态更改为允许。