Django 首页显示用户名

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

源码

原文地址:https://www.cnblogs.com/junsircoding/p/15665129.html