例如,我希望用户可以直接登录主页,而不是在页面“../account/login/”上登录。我应该做什么才能使它成为可能?如何将主页上的输入字段与 allauth 连接?我不知道这是否太复杂而无法以这种方式工作?
有一个适合我的解决方案。这不是最佳解决方案,因为它不干燥,所以如果有人改进它,我将不胜感激!
基本上我所做的就是渲染官方 allauth 登录模板并复制表单的 HTML 代码。然后我更改了 csrf 令牌和 url,并将其粘贴到主页模板中。
这是登录/注销的示例代码。您可以通过注册执行相同的操作。 (请注意,我仅使用电子邮件而不是用户名进行登录,您的代码可能会根据您的 allauth 设置而有所不同。查看您的登录和注册模板,了解您需要哪些输入字段及其名称。)
{% load account %}
<h1>Login / Logout</h1>
{% if user.is_authenticated %}
<p>Loged in with e-mail: {{ request.user.email }}</p>
<a href="{% url "account_logout" %}">Logout</a>
{% else %}
<form action="{% url "account_login" %}" method="post">
{% csrf_token %}
<input type="email" placeholder="E-mail" name="login">
<input type="password" placeholder="Password" name="password">
<label for="id_remember_menu" class="text-primary">Remember Me:</label>
<input id="id_remember_menu" name="remember" type="checkbox">
{% if redirect_field_value %}
<input type="hidden" name="{{ redirect_field_name }}" value="{{ redirect_field_value }}" />
{% endif %}
<button type="submit">Login</button>
<a href="{% url 'account_reset_password' %}">Forgot Password?</a>
</form>
{% endif %}
我想改进代码并能够直接在主页模板中呈现表单{{ form }}
而不是复制 HTML。如果我能做到,我会稍后更新回复。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)