BBS-登录注册
1注册上传头像
创建admin管理员代码:python3 manage.py createsuperuser
1.在setting文件中配置,用户注册成功之后自动生成用户上传的静态文件,这里需要特别注意的是,如果我们在数据库设置了默认图片存放地址,我们需要与下面的地址保持一致,否知前端找不到默认头像。
# media配置,能够将用户上传的所有文件都统一指定到这个media文件夹下
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
2.文件创建好了,我们需要将我们的文件开设访问接口,以便前端能够访问到;这里我们需要特别注意,这里的开始是不能随便开设的,以防数据后端数据泄露。
from django.views.static import serve
from BBS import settings
# 手动开设后端资源,将media文件夹下面所有的资源暴露给外界,
# media可以随便改,但是后面的是固定写法,不可改变,
url(r'^media/(?P<path>.*)', serve, {'document_root': settings.MEDIA_ROOT}),
3.前端:将头像图片加载到页面的时候,在img标签的src这样的写
<img class="media-object" src="/media/{{ article.blog.userinfo.avatar }}/" alt="..." height="60">
4.前端加载头像图片和发送后端的时候我们需要注意些,
<script>
//这里是对头像的事件做一些处理
$('#mdd').on('change', function () {
//在这里特别注意,需要用到一个内置对象,FileReader完成文件的读取操作
let MyFileReader = new FileReader();
//获取用户要上传的文件对象
let fileObj = $(this)[0].files[0];
//让文件阅读器读取文件
MyFileReader.readAsDataURL(fileObj);//这里的操作是IO操作,属于异步
//将读取之后的内容替换到img标间scr属性中
MyFileReader.onload = function () { //因为是异步操作所有这里我们要等待文件阅读完之后
//再将结果替换到img标间中取
$('#img').attr('src', MyFileReader.result)
}
});
//提交按钮绑定事件
$('#submit').click(function () {
//第一步当点击事件触发后,将数据提交给后端
//先定义一个函数,这里的FormData是form中的一个函数
let MyFormData = new FormData();
//接下来就是往里面添加键值对
//普通的键值对添加完毕后
// serializeArray序列化表单元素,返回 JSON 数据结构数据(就是利用form标签内部有一个自动序列化普通键值对的方法,,)
$.each($('#myform').serializeArray(), function (index, obj) {
//获取到的值是index是索引,obj是获取的对象
//将获取到的对象添加到函数中
MyFormData.append(obj.name, obj.value)
});//刚刚我这里把 ''})''弄到后面去了,结果还是可以运行但是出现了添加了值却显示为空的现象
//接下来手动添加文件数据
MyFormData.append('avatar', $('#mdd')[0].files[0]);//以avatar定义为name,后面的值作为value
//发送ajax请求
$.ajax({
url: '',
type: 'post',
data: MyFormData,
//发送文件一定要指定两个参数
processData: false,
contentType: false,
success: function (data) {
if (data.code == 1000) {
//注册成功,调转到登录页面,或你自己指定其他路径,
//从后端鞋垫到data中,前度直接从data中取
window.location.href = data.url
} else {
$.each(data.msg, function (index, obj) {
//这里的index就是报错的字段,obj就是错的信息,数组的形式
//获取报错字段,手动拼接该字段对应的input的框的id值
let targetId = '#id_' + index;//+利用字符串拼接方式
$(targetId).next().text(obj[0]).parent().addClass('has-error')//找到对应的input标签,
//然后通过next找到下面span给文本添加值
//并且给其添加属性
})
}
}
})
});
//input框获取焦点事件
$('input').focus(function () {
//获取焦点后设置文本为空,父标签删除 class="has-error"
$(this).next().text('').parent().removeClass('has-error')
})
</script>
2.登录图片验证码校验
在登录的时候我们需要特别注意的是,这里我们需要做一个图片的验证码做校验。
1.这里我们需要引入一个特别重要的模块
from PIL import Image, ImageDraw, ImageFont
import random
from io import BytesIO, StringIO
2.获取验证码背景颜色的三个色号:
def get_random():
return random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)
3.获取图片相关的验证码:
def get_code(request):
# 利用pillow模块自动生成图片
# 生成图片对象
img_obj = Image.new('RGB', (360, 35), get_random())
# 将生成好的图片对象交给ImageDrawa在图片生成一个画笔
img_draw = ImageDraw.Draw(img_obj)
# 设置一个字体样式
img_font = ImageFont.truetype('static/font/111.ttf', 30)
# 随机字符串,大小写单词加数字,5位每一位都可以是大小写字母,小写字母或数字
code = ''
for i in range(5):
upper_str = chr(random.randint(65, 90))
lower_str = chr(random.randint(97, 122))
random_int = str(random.randint(0, 9))
# 随机取一个
tmp = random.choice([upper_str, lower_str, random_int])
# 朝图片上写一个,五个值设置不同的颜色、字体。在前端展示给用户
img_draw.text((i * 60 + 60, 0), tmp, get_random(), img_font)
code += tmp # 把值添加到code中,然后保存到session中,用于校验前端提交的值
# 把code添加到session中,这个验证码后面其他视图函数可能要用到 找个地方存储一下 并且这个地方全局的视图函数都能访问
request.session['code'] = code
# 生成一个二进制对象
io_obj = BytesIO()
# 保存二进制的图片对象,并以png格式,
img_obj.save(io_obj, 'png')
# 返回二进制图片的值
return HttpResponse(io_obj.getvalue())
4.在前端的img的src写入函数的URL,这样就会自动在这个img标签中自动生成一张随机字符串的图片:
<img src="/get_code/" alt="" width="260" height="35" id="id_img">
前端js处理图片的时候,有两种或更多情况,下面展示两种情况,一种是当点击图片的时候刷新验证码图片,第二种是登录错误的时候也需要刷新下验证码图片:
//给验证码图片绑定一个点击一次就会更改一次事件
$('#id_img').click(function () {
//获取当前img的路径
var oldPath = $(this).attr('src');
$(this).attr('src', oldPath += '?') //将oldPath路径通过+进行字符串拼接
});
//登录错误的时候也需要刷新下验证码图片
var oldPath = $('#id_img').attr('src');
$('#id_img').attr('src', oldPath += '?')
BBS-登录注册的更多相关文章
- 1209 BBS 登录
目录 上周内容 今日内容 url.py views.py login home.html 逻辑流程 登录功能 上周内容 bbs项目 项目开发流程 需求分析 架构设计 分组开发 我们一般情况下都只是作用 ...
- web全栈开发之网站开发二(弹出式登录注册框前端实现-类腾讯)
这次给大家分享的是目前很多网站中流行的弹出式登录框,如下面的腾讯网登录界面,采用弹出式登录的好处是大大提升了网站的用户体验和交互性,用户不用重新跳转到指定的页面就能登录,非常方便 先来个演示地址 要实 ...
- android安卓Sqlite数据库实现用户登录注册
看了很多别人写的安卓SQlite数据的操作代码,一点也不通俗易懂,我觉得我写的不错,而且安卓项目也用上了,所以在博客园里保存分享一下!建立一个类 并继承SQLiteOpenHelper public ...
- JQuery+Ajax+Struts2+Hibernate 实现完整的登录注册
写在最前: 下午有招聘会,不想去,总觉得没有准备好,而且都是一些不对口的公司,可是又静不下心来,就来写个博客. 最近在仿造一个书城的网站:http://www.yousuu.com ,UI直接拿来用, ...
- HTML登录注册界面怎么制作?
在没有学习CSS样式的前提下,是如何做一个简单的注册界面的. 一.表单标签(form) 首先我们先写一个<form></form>的标签,form标签属于表单标签,通常我们的登 ...
- php+ajax 登录注册页面
主要是登录注册功能,前端后台验证没有什么,这个大家可以自己加上去,比如过滤啊,正则啊等 还是先放图吧 这是登录及注册界面 点击注册切换到注册界面,点击登录切换到登录界面 <!DOCTYPE h ...
- 7. Swift 基于Xmpp和openfire实现一个简单的登录注册
1. 基本步骤:首先导入Xmpp框架,配置环境 ->由于我们使用的是OC的Xmpp框架,再进行Swift开发时需要进行桥接. 具体方法就是创建一个基于c的.h的头文件,然后将我们需要编译OC的语 ...
- Nodejs学习总结 -Express 登录注册示例(二)
项目创建后,我们来做个登录注册实例,详细操作步骤如下. 1.新建项目demo ,具体操作步骤参考上一章内容 https://www.cnblogs.com/Anlycp/ 2.添加mysql和sess ...
- iOS开发一个用户登录注册模块需要解决的坑
最近和另外一位同事负责公司登录和用户中心模块的开发工作,开发周期计划两周,减去和产品和接口的协调时间,再减去由于原型图和接口的问题,导致强迫症纠结症状高发,情绪不稳定耗费的时间,能在两周基本完成也算是 ...
- 使用Struts2搭建登录注册示例
使用Struts2来搭建mvc网站框架还是比较容易的,Struts2提供了各项辅助功能,保证了web开发的快速方便.下面使用struts2来搭建一个登录注册示例. 0 项目结构截图 1 搭建Strut ...
随机推荐
- ROS topic,service和action的使用场景
参考:ROS中关于topic和service的运用场合 Topics 特点: 1.单向,分工明确,处理连续数据流,topic是一种多对多的形式,一个Node可以订阅多个Topic,可以publish到 ...
- 20191204-使用nginx解决ajax测试调用接口跨域问题
问题描述 之前要测试一个http的接口,在postman中测试成功,但使用ajax调用却跨域.于是通过使用ngin反向代理的方式来解决ajax调用跨域问题 测试页面的内容 <html> & ...
- 图论+思维(2019牛客国庆集训派对day2)
题意:https://ac.nowcoder.com/acm/contest/1107/J n个点的完全图编号0-n-1,第i个点的权值为2^i,原先是先手选取一些边,然后后手选取一些点,满足先手选取 ...
- spark的安装步骤
官网:http://spark.apache.org/downloads.html 安装:tar -zxvf spark-2.4.3-bin-hadoop2.7.tgz#配置环境变量(vim ~/.b ...
- 小白学习django第一站-环境配置
Django简单来说就是用Python开发的一个免费开源的Web框架 使用Django,使你能够以最小的代价构建和维护高质量的Web应用. 开搞!!! 工具准备: linux(ubuntu) + py ...
- Python编程之注释
一.注释 当你把变量理解透了,你就已经进入了编程的世界.随着学习的深入,用不了多久,你就可以写复杂的上千甚至上万行的代码啦,有些代码你花了很久写出来,过了些天再回去看,发现竟然看不懂了,这太正常了. ...
- 解决Spring Boot集成Shiro,配置类使用Autowired无法注入Bean问题
如题,最近使用spring boot集成shiro,在shiroFilter要使用数据库动态给URL赋权限的时候,发现 @Autowired 注入的bean都是null,无法注入mapper.搜了半天 ...
- linux 下安装 jre
本文链接:https://blog.csdn.net/qq_34368587/article/details/79559102 Linux下安装Java运行环境 现需要项目部署到Linux中,需要配置 ...
- C#求1-100的质数,100-1000的水仙花数,1-100所有的平方和平方平方根
//你们的鼓励是我最大的动力 大家可以多留言评论 在接下来很长一段时间我会从初级到高级每天更新 大家有想学习的内容也可以留言哦 //现在是我做C#老师的第28天,希望和大家一起努力 加油 using ...
- vue项目中的登录鉴权
用vue做一个简单的登录鉴权功能. 项目目录结构如下: Login 组件 登录成功后做本地存储和store存储,并进行跳转. Login.vue关键代码: async handleLogin(e) { ...