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

源码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值