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

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

相关文章

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循