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 ...
随机推荐
- Linux 安装 openoffice
1 说明 本文档采用rpm包方式安装,操作系统为centos 2 下载openoffice rpm包 创建nginx源码包存放目录 mkdir /usr/local/src/openoffice cd ...
- ######【Python】【基础知识】Python的介绍 ######
Python 是一种面向对象.解释型计算机程序设计语言. Python是什么? Python(英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种面向对象的解释型计算机程序设计语言 ...
- 从入门到自闭之Python--Django Rest_Framework
核心思想: 缩减编写api接口的代码 Django REST framework是一个建立在Django基础之上的Web 应用开发框架,可以快速的开发REST API接口应用.在REST framew ...
- Python解释器换源
Python解释器换源 """ 1.采用国内源,加速下载模块的速度 2.常用pip源: -- 豆瓣:https://pypi.douban.com/simple -- 阿 ...
- ELK-全过程搭建
环境说明:软件包我都 给你们放/usr/local/src/elk目录下安装目录都放在/usr/local/下数据都放在/data0/elk/目录下日志都放在/data0/logs/elk目录下系统 ...
- jenkins+docker+git+etcd实现应用配置文件管理
两台机器: 一台机器安装gitlab: http://www.cnblogs.com/cjsblogs/p/8716932.html 另一台机器安装etcd+docker+jenkins jenkin ...
- Tomcat中的服务器组件和 服务组件
开始学习Tocmat时,都是学习如何通过实例化一个连接器 和 容器 来获得一个Servlet容器,并将连接器 和 servlet容器相互关联,但是之前学习的都只有一个连接器可以使用,该连接器服务80 ...
- node 环境安装
记录一下, 方便自己需要时用, 免得到处找 1. 官网下载安装node(选择LTS长期支持版本), 一路点击next即可(傻瓜式安装) 2. 验证是否正确安装, 打开命令窗口, 执行 node -v ...
- 修改git默认的编辑器nano为vim的方法
git默认的编辑器是nano,使用起来不易操作,下面介绍两种方法将git默认的编辑器修改为vim. git config --global core.editor vim .git/config文件 ...
- EntityFramework学习要点记一
一.Entity的注解属性(Annotations)不管是code first还是db first,都需要用到注解属性,至于用System.ComponentModel.DataAnnotations ...