一、media

'''
1. 将用户上传的所有静态文件统一管理
-- settings.py
-- MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
2. 服务器会对外公开一下服务器静态资源
3. 对外公开的方式(配置url接口),在接口中返回指定的静态资源(如何批量操作)
-- from django.views.static import serve
-- url(r'^media/(?P<path>.*)', serve, {'document_root': settings.MEDIA_ROOT}),
'''

二、操作内存的流 - StringIO | BytesIO

from io import StringIO, BytesIO
# 创建操作字符串的内存流
sf = StringIO()
# 往内存中写
sf.write('hello')
# 在内存中取
sf.getvalue() # 创建操作二进制的内存流
bf = BytesIO()
# 往内存中写
bf.write('hello'.encode('utf-8'))
# 在内存总取
bf.getvalue()

三、PIL:python图片操作库

# 1、生成图片(画板)
from PIL import Image
# 生成一个Image类对象(准图片):模式、尺寸、颜色
img = Image.new('RGB', (80, 80), color=(255, 0, 0)) # Type: Image
# 将Image类对象采用具体格式放入具体的文件流中
bf = BytesIO() # eg: 内存字节流
img.save(bf, 'png') # 2、产生文字颜色字体(选择指定ttf并设置字体)
from PIL import ImageFont
# 产生某种ttf格式的30px大小文字
img_font = ImageFont.truetype('*.ttf', 30) # 3、画图,画笔(画点,线,字,圆)
from PIL import ImageDraw
# 在具体的Image对象上画图
img_draw = ImageDraw.Draw(img)
# 画文字:xy轴、文本、颜色、ImageFont字体
img_draw.text((x, y), 'abc', 'red', img_font)
'''
# 创建画板,保存在服务器本地
def save_local():
img = Image.new('RGB', (230, 32), (40, 20, 10)) # type: Image
# 本地写流
wf = open('code.png', 'wb')
# 将数据以指定格式丢给文件操作流
img.save(wf, 'png') with open('code.png', 'rb') as f:
data = f.read()
return data #创建画板保存到内存的流
img = Image.new('RGB', (230, 32), (40, 20, 10)) # type: Image
bf = BytesIO()
img.save(bf, 'png')
# 在内存中取
sf.getvalue()
'''
'''
#创建六位随机验证码 from PIL import Image,ImageFont,ImageDraw
from io import BytesIO
import random #随机RGB元组
def random_RGB(min,max):
return tuple([random.randint(min,max) for i in range(3)]) #随机产证六位验证码
def random_six_code():
code = ''
#每一位均可以为字母大小写或数字
for i in range(6):
tag = random.randint(1,3) #1.大写 2:小写 3:数字
if tag == 1:
#转换为字符 ASCII表
code += chr(random.randint(65,90))
elif tag == 2:
code += chr(random.randint(97,122))
else:
#转换为字符串
code += str(random.randint(0,9))
return code #获取验证码
def login_code(request):
#创建画板
img = Image.new('RGB',(230,32),random_RGB(150,255)) #设置ImageFont字体
img_font = ImageFont.truetype('static/font/kumo.ttf',size=30) #在画板中画字
img_draw = ImageDraw.Draw(img) #获取六位验证码
img_code = random_six_code() #将img_code存储到session中,与会话绑定用来完成验证码的验证
request.session['img_code'] = img_code #画文字:xy轴、文本、颜色、ImageFont字体
for i,ch in enumerate(img_code):
img_draw.text((30+i*30,0),ch,random_RGB(0,150),img_font) bf = BytesIO()
img.save(bf,'png')
data = bf.getvalue()
return HttpResponse(data)
'''

前端解析二进制流图片(了解)

// 向指定url请求图片二进制流转换为blob:格式的src
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true); // url
xhr.responseType = "blob";
xhr.onreadystatechange = function () {
if (xhr.readyState == 4) {
if (xhr.status == 200) {
var blod = this.response;
var src = URL.createObjectURL(blod); // src
}
}
};
xhr.send();
//完成前端点击验证码进行切换
$('#code').click(function () {
url = '/login_code/'; //提供一个连接
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true); // url
xhr.responseType = "blob";
xhr.onreadystatechange = function () {
if (xhr.readyState == 4) {
if (xhr.status == 200) {
var blod = this.response;
var src = URL.createObjectURL(blod); // src
$('#code').attr('src',src) //拿到其结果
}
}
};
xhr.send();
})

四、Admin自动化数据管理界面

admin的概念

# Admin是Django自带的一个功能强大的自动化数据管理界面
# 被授权的用户(超级用户)可以直接在Admin中操作数据库
# Django提供了许多针对Admin的定制功能

配置并访问自动化数据管理界面

# 终端项目目录创建一个超级用户:python3 manage.py createsuperuser
# eg:Username:root | Email:root@root.com | Password:1234qwer
# 浏览器Admin入口:http://127.0.0.1:8000/admin
# 设置Admin界面为中文环境:项目下settings.py,LANGUAGE_CODE = 'zh-Hans'
# 简体:zh-hans | 繁体:zh-hant | 美式英语:en-us

将指定映射添加到自动化数据管理界面

# 应用下的admin.py中,注册映射对应关系的类
from . import models
admin.site.register(models.Article) # 应用下的admin.py中,注册映射对应关系的表
from django.contrib import admin
from blog.models import * admin.site.register(User)
admin.site.register(Blog)
admin.site.register(Article)
admin.site.register(Category)
admin.site.register(Tag)
admin.site.register(UpOrDown)
admin.site.register(Comment)

格式化界面字段显示名与表名

# 为应用下models.py映射关系类重写__str__方法
class Article(models.Model):
title = models.CharField(max_length=32, default='Title', verbose_name="标题")
#blank是admin界面该字段可以为空,null是数据库该字段可以为空
content = models.TextField(null=True, verbose_name="内容", blank=True)
# 重写__str__方法,格式化该类实例对象的表示方式
def __str__(self):
return self.title
class Meta:
verbose_name = "文章" #单数形式如何显示
verbose_name_plural = verbose_name #复数形式如何显示

media静态文件统一管理 操作内存的流 - StringIO | BytesIO PIL:python图片操作库 前端解析二进制流图片(了解) Admin自动化数据管理界面的更多相关文章

  1. django官方文档--对静态文件的管理

    一.入门级理解: 在django中对静态文件的管理和模板(template)的思路是一样的.在模板的管理中django是把app用到 到的模板都保存到app目录下的templates子目录中. 静态文 ...

  2. Django配置静态文件(CSS\js)及Django调用JS、CSS、图片等静态文件

    1 新建一项目: root@python:django-admin.py startproject csstest root@python:cd csstest root@python:ls csst ...

  3. nginx实现动态/静态文件缓存(week4_day1_part2)-技术流ken

    nginx实现静态文件缓存实战 1.nginx静态文件缓存 如果要熟练使用nginx来实现文件的缓存,那下面的几个指令你必须要牢记于心 指令1:proxy_cache_path 作用:设置缓存数据的相 ...

  4. django 项目运行时media静态文件不能加载问题处理

    一.检查网页中的加载路径 如果路径不正确,首选调整html路径(当然也可以调整文件路径或修改models中upload_to路径,但是不要轻易改): 二.重点: 如果加载路径和实践路径一致,请按以下步 ...

  5. vue 中如何对公共css、 js 方法进行单文件统一管理,全局调用

    1.前言 最近,为公司开发交付的一个后台管理系统项目,我使用了 Vue 框架进行开发实践. 模块化.组件化.工程化的开发体验非常好.良好的 api,优雅的设计,对于工程师非常友好. 但是由于模块比较多 ...

  6. Linux 内核的文件 Cache 管理机制介绍

    Linux 内核的文件 Cache 管理机制介绍 http://www.ibm.com/developerworks/cn/linux/l-cache/ 1 前言 自从诞生以来,Linux 就被不断完 ...

  7. Linux 内核的文件 Cache 管理机制介绍-ibm

    https://www.ibm.com/developerworks/cn/linux/l-cache/ 1 前言 自从诞生以来,Linux 就被不断完善和普及,目前它已经成为主流通用操作系统之一,使 ...

  8. Django学习之十: staticfile 静态文件

    目录 Django学习之十: staticfile 静态文件 理解阐述 静态文件 Django对静态文件的处理 其它方面 总结 Django学习之十: staticfile 静态文件 理解阐述     ...

  9. Django静态文件的加载以及STATIC_URL、 STATIC_ROOT 、STATICFILES_DIRS的区别

    Djangon生产环境静态资源的处理 Django 关闭DEBUG模式后,就相当于是生产环境了. Django框架一旦作为生产环境,它的静态文件访问接口就不应该从Django框架中走,必须在Djang ...

随机推荐

  1. 2.5多重else嵌套的二次方程求根

    #include<stdio.h> #include<math.h> int main() { double a, b, c, disc, x1, x2, realpart, ...

  2. error C4430: missing type specifier - int assumed. Note: C++ does not support default-int

    以前一直用的VC6.0,最近换成VS2010了.哎这几天光折腾VS2010了. 曾经我以为程序没啥头绪忒头疼,现在觉得乱七八糟的编译问题才叫一个头裂=口= 原因:VC6.0中,如果没有直接显示指定的返 ...

  3. “康园圈--互联网+校园平台“项目之Sprint3

    sprint3任务列表 1.部署项目内测版上线,并绑定相应域名. 2.添加测试用的模拟数据. 3.写已实现功能及效果汇报文档. 4.写项目总结博客. 5.记录并分析用户反馈. 看板动态 第一次 第二次 ...

  4. 【读书笔记】iOS-开发技巧-UILabel内容模糊的原因

    在非Retina的iPad mini的屏幕上,一个UILabel的frame的origin值如果有小数位数(例如,0.5),就会造成显示模糊.所以最好用整数值的origin坐标. 参考资料: < ...

  5. OC基础(9)

    OC中的私有方法 @property基本概念 @synthesize基本概念 @property增强 @property修饰符 *:first-child { margin-top: 0 !impor ...

  6. wp8.1开发系列之安装包URI方案

    应用文件使用"ms-appdata:///"开头的URI地址,安装包使用的是"ms-appx:///"开头的URI地址. 比如:读取安装包Image文件夹下的t ...

  7. 设计模式之Adapter模式

    说起Adapter,STL里的stack和queue都是adapter,底层是deque,隐藏了deque的一些接口,使得其可以达到FIFO是queue,LIFO是stack. The STL sta ...

  8. Html元素添加事件禁用

    最近几天,测试在检测我页面功能时,疯狂点击带接口请求的按钮,然后就会发起无数次请求,然后app就卡住了.当看到这个问题的时候,心里疯狂鄙视测试(开个玩笑),一开始想的到解决方案是用函数防抖,使用函数防 ...

  9. Java 关键字详解(持续更新中)

    abstract:     表明类或者成员方法具有抽象熟悉.       修饰类,抽象类:         抽象类不能被实例化:         抽象类中可以有属性.方法.构造,都是用来给子类继承的: ...

  10. jmetter 安装 建测试计划详细步骤

    更多Jmetter教程 1,去官网下载最新的jmetter版本: http://jmeter.apache.org/download_jmeter.cgi 2,解压下载的jmtter安装包到D:\so ...