Django 首页显示用户名
实现效果图:
编写前端页面:
<tr v-if="username">
<td>当前登录用户:[[username]]</td>
<td><a href="/logout/">注销</a></td>
</tr>
<tr v-else="username">
<td><a href="/login/">登录</a></td>
<td><a href="/register/">注册</a></td>
</tr>
vue中需要绑定的变量:[[ username ]]
实现原理:
用户登录之后,保持登录状态,随后在cookie中添加登录信息。
页面重定向到首页时,vue读取cookie。若cookie有用户名信息,则显示已登录状态,若没有,则显示未登录状态。
配置路由:
from django.conf.urls import url
from . import views
urlpatterns = [
url('^$', views.IndexView.as_view()),
]
编写视图函数:
from django.shortcuts import render
from django.views import View
class IndexView(View):
def get(self, request):
return render(request, 'index.html')
获取cookie的js函数:
// 获取cokie
function getCookie(name){
var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
return r ? r[1] : undefined;
}
Vue:
var vm = new Vue({
el:'#app',
delimiters:['[[', ']]'],
data:{
host,
username:''
},
mounted(){
this.username = getCookie('username');
console.log(this.username);
},
methods:{}
});
在登录及注册视图函数中设置cookie:
# 登录状态保持
login(request, user)
# 响应
response = redirect('/')
response.set_cookie('username', user.username, max_age=60 * 60 * 24 * 14)
return response