token&静态文件&媒体文件

1. token

1. 会话技术
2. 服务端会话技术
3. 它实际上就是手动实现的session
4. 实现token
    4.1 在models.py中User类中添加token字段
        class User(models.Model):
            name = models.CharField(max_length=30, unique=True)
            password = models.CharField(max_length=32)
            age = models.IntegerField(default=1)
            token = models.CharField(max_length=32, null=True, blank=True, default='')
    4.2 md5加密
         # md5加密
         def my_md5(password):
            md5 = hashlib.md5()
            md5.update(password.encode('utf-8'))
            return md5.hexdigest()
        
    4.3 注册用户时,随机生成唯一的token
        token/usertoken,  用户唯一标识
        可以使用 时间+随机数+公司域名+ip信息 或 时间+随机数等方式生成token
        # 生成加密的token
        def generate_token():
            token = str(time.time()) + str(random.random())
            return my_md5(token)
    
    4.4 登录时使用cookie存储token
         # token
         d = datetime.datetime.now() + datetime.timedelta(days=7)  # 保存7天
         response.set_cookie('token', res.first().token, expires=d)
    
    4.5 根据token获取用户信息
        token = request.COOKIES.get('token', '')
        users = User.objects.filter(token=token)
    
    4.6 退出登录
        response = HttpResponseRedirect(reverse('app:index'))
        # 删除cookie: token
        response.delete_cookie('token')
        return response
 

2. 用户登录注册

1. 用户注册
    将用户名,用户密码,用户信息,存储到数据库中
2. 用户登陆
    使用用户名,用户密码进行数据库校验
3. 用户信息
    根据用户的唯一标识,去获取用户
4. 数据安全
    服务器的数据对任何人来说都应该是不可见的(不透明)
    可以使用常见的摘要算法对数据进行摘要(md5,sha1)
    如果使用了数据安全,那么就需要在所有数据验证的地方都加上 数据安全
 

3. 静态文件和媒体文件

媒体文件:用户上传的文件,叫做media
静态文件:存放在服务器的css,js,image等 叫做static
 

3.1 在django中使用静态文件

    1)首先确保django.contrib.staticfiles在 INSTALLED_APPS中
    2)在settings中定义 STATIC_URL
        STATIC_URL = '/static/'
    3)在你app的static目录中存放静态文件,比如: 
        my_app/static/my_app/example.jpg.
    4)如果有别的静态资源文件,不在app下的static目录下,可以通过
STATICFILES_DIRS来指定额外的静态文件搜索目录。
        STATICFILES_DIRS = [
            os.path.join(BASE_DIR, "static"),
            ...
        ]
    5)在模板中使用load标签去加载静态文件
        {% load static %}
        <img src="{% static "my_app/example.jpg" %}" alt="My image"/>
 

3.2 在django中使用媒体文件

    1)在settings中配置 MEDIA_ROOT
        MEDIA_ROOT = os.path.join(BASE_DIR, "media")
 

4. 文件上传

文件上传要求form表单存在enctype="multipart/form-data"属性,并且提交方法是post。
    <form enctype="multipart/form-data" action="/uploadFile/" method="post"> 
       <input type="file" name="myfile" />  
       <br/>  
       <input type="submit" value="upload"/>  
    </form>
    
最简单的文件上传:
    def file_upload(request):
        if request.method == 'POST':
            # 获取上传的文件,如果没有文件,则默认为None
            myFile = request.FILES.get('myfile', None)
            if not myFile:
                return HttpResponse("no files for upload")
            file_path = os.path.join(settings.MEDIA_ROOT, '1.jpg')
            with open(file_path, 'ab') as fp:
                for part in myFile.chunks():
                    fp.write(part)
            return HttpResponse("上传成功!")
        else:
            return render(request, 'index.html')
 

5. 多文件上传

多文件上传和单文件上传类似
    1.需要在模板文件的form表单input中添加multiple
    2.后台获取时使用request.FILES.getlist('myfile', None)
def file_upload2(request):
    if request.method == 'POST':
        # 获取上传的文件,如果没有文件,则默认为None
        myFiles = request.FILES.getlist('myfile', None)
        for myFile in myFiles:
            if not myFile:
                return HttpResponse("no files for upload")
    
            file_path = os.path.join(settings.MEDIA_ROOT, myFile.name)
            with open(file_path, 'ab') as fp:
                for part in myFile.chunks():
                    fp.write(part)
                    
        return HttpResponse("上传成功!")
    else:
        return render(request, 'index.html')
 

6.分页

6.1 分页工具

django提供了分页的工具,存在于django.core中
    Paginator : 数据分页工具
    Page    : 具体的某一页面
导入Paginator: 
    from django.core.paginator import Paginator
Paginator:
对象创建: 
    Paginator(数据集,每一页数据数)
属性:
    count:对象总数
    num_pages:页面总数
    page_range: 页码列表,从1开始
方法:
    page(整数): 获得一个page对象
常见错误:
    InvalidPage:page()传递无效页码
    PageNotAnInteger:page()传递的不是整数
    Empty:page()传递的值有效,但是没有数据
    
Page:
    对象获得,通过Paginator的page()方法获得
属性:
    object_list:    当前页面上所有的数据对象
    number: 当前页的页码值
    paginator:  当前page关联的Paginator对象
方法:
    has_next()  :判断是否有下一页
    has_previous():判断是否有上一页
    has_other_pages():判断是否有上一页或下一页
    next_page_number():返回下一页的页码
    previous_page_number():返回上一页的页码
    len():返回当前页的数据的个数
 

Django (七) token&静态文件&媒体文件的更多相关文章

  1. Django配置与静态文件

    settings.py """ Django settings for myproject project. Generated by 'django-admin sta ...

  2. Django下配置静态文件以及渲染图片

    js,css,img等都叫做静态文件,那么关于django中静态文件的配置,我们就需要在setting配置文件里面写上下面这些内容: #STATIC_URL = '/xxx/' #别名,随便写的名字, ...

  3. Django中对静态文件的支持(转)

    英文原文:[http://agiliq.com/blog/2013/03/serving-static-files-in-django/] 译文:[http://segmentfault.com/a/ ...

  4. Django 学习之---静态文件处理详解

    前言: 1.静态文件是指 网站中的 js, css, 图片,视频等文件 2.静态文件放在对应的 app 下的 static 文件夹中 或者 STATICFILES_DIRS 中的文件夹中. 当 DEB ...

  5. Django中使用静态资源/文件

    Django中常需要引用js,css,小图像文件,一般我们把这一类文件称为静态文件,放置在static文件夹中,接下来,对Django中配置静态文件进行下傻瓜式的步骤介绍 在工程目录下新建static ...

  6. Django基础二静态文件和ORM

    Django基础二静态文件和ORM 目录 Django基础二静态文件和ORM 1. 静态文件 1.1 静态文件基本配置: 1.2 静态文件进阶配置 2. request参数 3. Django配置数据 ...

  7. django中的静态文件

    静态文件 1.什么是静态文件 在django中静态文件是指那些图片.css样式.js样式.视频.音频等静态资源. 2.为什么要配置静态文件 这些静态文件往往不需要频繁的进行变动,如果我们将这些静态文件 ...

  8. vue第七单元(vue的单文件组件形式-单文件组件的加载原理-vue-cli构建的开发环境以及生命周期)

    第七单元(vue的单文件组件形式-单文件组件的加载原理-vue-cli构建的开发环境以及生命周期) #课程目标 掌握安装 vue-cli 命令行工具的方法,掌握使用命令行在本地搭建开发环境,使用命令行 ...

  9. [译]:Orchard入门——媒体文件的添加与管理

    原文链接:Adding and Managing Media Content 注:此文内容相对较老,实际操作指导性不强,仅适合做研究 当你利用富文本编辑器上传图片时(或者使用XML-RPC客户端,例如 ...

随机推荐

  1. ARM编译器中预定义的宏

    arm系列目前支持三大主流的工具链,realview的armcc,iar ewarm的iccarm,gnu的gcc,编译器在编译的时候会预定义一些宏,这些宏在工程中起到不可或缺的作用. 例如 /* d ...

  2. GIN+GORILLA=A GOLANG WEBSOCKET SERVER

    鉴于聊天已然成为大部分app的基础功能,而大部分app用户基数有没有辣么大,常用的聊天server架构如xmpp或者消息队列实现之类的用起来还挺麻烦的,有比较难跟网页端做交互,加之H5标准落地,所以w ...

  3. Codeforces Round #374 (Div. 2) B. Passwords —— 基础题

    题目链接:http://codeforces.com/contest/721/problem/B B. Passwords time limit per test 2 seconds memory l ...

  4. 基于BASYS2的VHDL程序——数字钟

    在编电子表时发现FPGA求余,取模只能针对2的次方.毕竟是数字的嘛! 时钟用到了动态刷新数码管.以一个大于50Hz的速度刷新每一个数码管. 因为数码管只有四个,只写了分针和秒针. 代码如下: libr ...

  5. TestNG测试用例编写和执行

    编写TestNG用例测试基本上包括以下步骤: 编写业务逻辑 针对业务逻辑中涉及的方法编写测试类,在代码中插入TestNG的注解 直接执行测试类或者添加一个testng.xml文件 运行 TestNG. ...

  6. 继续servlet理论篇

    唉,毕业是件很麻烦的事情,实习也是一件很郁闷的事情,现在公司很注重基础,所以 所以还要看java,不过,我年轻,我有激情.来吧,来着不惧,说这话,有些心虚. HttpServlet类中所提供的doGe ...

  7. poj图论解题报告索引

    最短路径: poj1125 - Stockbroker Grapevine(多源最短路径,floyd) poj1502 - MPI Maelstrom(单源最短路径,dijkstra,bellman- ...

  8. reactjs的一些笔记

    1.使用虚拟DOM作为其不同的实现.同时可以由服务器node.js渲染,从而不需要过重的浏览器DOM支持.   2.虚拟DOM:在浏览器端用javascript实现了一套DOM API.用react开 ...

  9. Gulp简单应用

    1.创建一个工程,在webstorm控制台   cnpm install --save-dev gulp      cnpm install --save-dev gulp-concat        ...

  10. vim vi Ubuntu 设置

    1. 在vi编辑模式下按退格键不能删除内容,按方向键不能上下左右移动?如果是则:一 在vi里非编辑模式下按冒号进入到末行命令模式,然后输入set nocompatible,回车,然后在进入vi编辑模式 ...