全面升级登录注册,添加个人主页功能

2024-03-09 11:58

本文主要是介绍全面升级登录注册,添加个人主页功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先说明:登录注册都是我下载的模板,加以调整。

本次更新的主要内容是新增了个人主页功能。

登录用户点击 ‘我的’ 选项可进入自己的个人主页。

游客身份不可查看用户信息,避免信息泄露(我主要是玩爬虫的),后续添加,已登录用户可互相查看。(重要信息需点击。依靠js加载。)

全面升级登录注册页面,可在登录页跳往注册页,反之亦然。重点是变好看了。

还有static文件夹的使用,网上的教程看得我头疼。

这里记一个static的使用

首先,在你的settings.py里:

# 静态文件夹路径
STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')
]

然后,看看层级目录:

看好同级结构。

在我的static下有一个Myapp是针对Myapp应用的,因为你可能做得够大的话还会有别的应用。

然后,在html里引用css或js,这里给出我的登录html

login.html

{% load static %}
<!DOCTYPE html>
<html >
<head>
<meta charset="UTF-8">
<title>登录</title><link rel="stylesheet" href="{% static 'Myapp/css/login.css' %}" />
<style type="text/css">
<!--
a:link {
font-size: 12px;
color: white;
text-decoration: none;
}
a:visited {
font-size: 12px;
color: white;
text-decoration: none;
}
a:hover {
font-size: 12px;
color: white;
text-decoration: underline;
}
-->
</style>
</head>
<body>
<main><form class="form" method="post">{% csrf_token  %}<div class="form__cover"></div><div class="form__loader"><div class="spinner active"><svg class="spinner__circular" viewBox="25 25 50 50"><circle class="spinner__path" cx="50" cy="50" r="20" fill="none" stroke-width="4" stroke-miterlimit="10"></circle></svg></div></div><div class="form__content"><h1>欢迎</h1><div class="styled-input"><input type="text" name="username" class="styled-input__input"><div class="styled-input__placeholder"><span class="styled-input__placeholder-text">昵称</span></div><div class="styled-input__circle"></div></div><div class="styled-input"><input type="password" name="password" class="styled-input__input"><div class="styled-input__placeholder"><span class="styled-input__placeholder-text">密码</span></div><div class="styled-input__circle"></div></div><button type="submit" value="登录" class="styled-button"><span class="styled-button__real-text-holder"><span class="styled-button__real-text">登录</span><span class="styled-button__moving-block face"><span class="styled-button__text-holder"><span class="styled-button__text">登录</span></span></span><span class="styled-button__moving-block back"><span class="styled-button__text-holder"><span class="styled-button__text">登录</span></span></span></span></button><button type="button" value="注册" class="styled-button"><span class="styled-button__real-text-holder"><span class="styled-button__real-text"><a href="http://127.0.0.1:8000/register/">注册</a></span><span class="styled-button__moving-block face"><span class="styled-button__text-holder"><span class="styled-button__text"><a href="http://127.0.0.1:8000/register/">注册</a></span></span></span><span class="styled-button__moving-block back"><span class="styled-button__text-holder"><span class="styled-button__text"><a href="http://127.0.0.1:8000/register/">注册</a></span></span></span></span></button></div></form>
</main><script type="text/javascript" src="{% static 'Myapp/js/login.js' %}"></script>{% if info %}<script>window.alert('{{ info }}');</script>
{% endif %}
</body>
</html>

划重点:

1,{% load static %}

2,<link rel="stylesheet" href="{% static 'Myapp/css/login.css' %}" />

3,<script type="text/javascript" src="{% static 'Myapp/js/login.js' %}"></script>

然后,个人页面的各个代码:

models.py

class UserInfo(models.Model):# 用户名username = models.CharField(max_length=20,verbose_name='用户名')# 联系方式userphone = models.CharField(max_length=11,verbose_name="联系方式")# 头像链接userimg = models.CharField(max_length=2000,verbose_name="头像链接")# 地址useraddress = models.CharField(max_length=200,verbose_name="地址")# 用户类型usercate = models.CharField(max_length=20,verbose_name="用户类型")# 用户简介userdetail = models.CharField(max_length=1000,verbose_name='简介')def __str__(self):return self.usernameclass Meta:db_table = 'userinfo'

views.py

def profile(request,username):name = request.useruser = UserInfo.objects.filter(username=name).first()if user:return render(request, 'Myapp/profile.html', {'user':user})return HttpResponseRedirect('/tologin/')

urls.py:

from django.urls import path
from . import viewsurlpatterns = [#主页,用来显示类别等其他数据path('',views.index),# 登录path('tologin/',views.tologin),# 注册path('register/',views.register),# 注销path('lagout/',views.lagout),# 个人主页path('profile/<str:username>',views.profile),
]

profile.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>个人主页</title>
</head>
<body>
<p><div style="width:100px; height:100px; border-radius:100%; overflow:hidden;"><img src="{{ user.userimg }}"></div>
</p>
<p>昵称:{{ user.username }}
</p>
<p>联系方式:{{ user.userphone }}
</p>
<p>地址:{{ user.useraddress }}
</p>
<p>用户类型:{{ user.usercate }}
</p>
<p>简介:{{ user.userdetail }}
</p>
</body>
</html>

 

效果:

主页:我很low:

登录:我是动态的:

注册:我好看

登录后:

个人主页:

其实,上图中红色图案是头像,原图是这样的:https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=3100494582,1138448188&fm=26&gp=0.jpg

我还不会改,还在学。编辑资料暂时不支持,后续会更新

然后,最近考虑把它放到git上去,这里太麻烦了。。。

这篇关于全面升级登录注册,添加个人主页功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/790603

相关文章

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

怎么关闭Ubuntu无人值守升级? Ubuntu禁止自动更新的技巧

《怎么关闭Ubuntu无人值守升级?Ubuntu禁止自动更新的技巧》UbuntuLinux系统禁止自动更新的时候,提示“无人值守升级在关机期间,请不要关闭计算机进程”,该怎么解决这个问题?详细请看... 本教程教你如何处理无人值守的升级,即 Ubuntu linux 的自动系统更新。来源:https://

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

如何评价Ubuntu 24.04 LTS? Ubuntu 24.04 LTS新功能亮点和重要变化

《如何评价Ubuntu24.04LTS?Ubuntu24.04LTS新功能亮点和重要变化》Ubuntu24.04LTS即将发布,带来一系列提升用户体验的显著功能,本文深入探讨了该版本的亮... Ubuntu 24.04 LTS,代号 Noble NumBAT,正式发布下载!如果你在使用 Ubuntu 23.

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

Django中使用SMTP实现邮件发送功能

《Django中使用SMTP实现邮件发送功能》在Django中使用SMTP发送邮件是一个常见的需求,通常用于发送用户注册确认邮件、密码重置邮件等,下面我们来看看如何在Django中配置S... 目录1. 配置 Django 项目以使用 SMTP2. 创建 Django 应用3. 添加应用到项目设置4. 创建