前言
我们在 django-rest-framework解析请求参数 文章中完成了接口文档到参数解析, 一个完整的流程中还缺少对数据库的操作. 本篇内容为django连接数据库, 并编写一个image表用来存储图片路径, 编写图片上传接口和查看数据库中所有图片路径的接口.
前期准备
django操作图片需要安装一个三方库叫做,Pillow
workon python35 pip install pillow pip install pymysql
Pillow这个库可以对图片进行操作, 例如生成缩略图等等, 非常强大.
pymysql是python3中用来连接数据库的一个库.
安装mysql数据库. 安装MySQLWorkBench(作用和navicat一样,使用其他软件也可以)
选好点击apply 提交创建新库.
django如何存储图片
一般图片不存数据库单独存储于某个路径, 开发过程中就存在项目的某个路径下.
iOS开发中有个http 304问题. 就是请求图片时, 如果有缓存直接取缓存的图片. 实际上苹果早已帮我们处理好了. 实际开发中不需要针对http 304编写任何代码.
关于http 304的问题
这一篇文章写的非常详细了.
现在我们进行服务端编程, 服务端是如何生成etag, last-modify这些参数的呢"color: #ff0000">编写存储图片路径和id的表.
修改models.py文件.
from django.db import models import datetime class Image(models.Model): # url = models.TextField(null=True) image = models.ImageField(upload_to=str('image/{time}'.format(time=str(datetime.date.today().strftime("%Y%m/%d"))))) create_time = models.DateTimeField(auto_now_add=True, null=True) update_time = models.DateTimeField(auto_now=True, null=True) class Meta: pass
ImageField中的upload_to表示图片上传的具体路径.
修改数据库配置连接mysql
修改settings.py文件中的DATABASES 到下面的样式. name是刚刚创建mysql新库的名称. user password 是mysql用户的用户名和密码. mysql端口号默认为3306
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test', 'USER': 'root', 'PASSWORD': '111111', 'HOST': '127.0.0.1', 'PORT': '3306', } }
记得删除 migrations目录下除了__init__.py 之外的所有文件.
这些文件记录了对数据库定义个整个修改流程. 切换数据库后这个流程和新库根本对不上号. 需要全部删除.
修改与settings.py 同一目录的__init__.py 文件
添加两行代码
import pymysql pymysql.install_as_MySQLdb()
cd到项目manage.py文件的路径下,运行
workon python35 python manage.py makemigrations python manage.py migrate
使用mysqlworkbench 连接3306打开之前创建的库可以看到表都已经被创建出来
编写图片上传接口
from rest_framework import serializers class ImageUploadSerializer(serializers.Serializer): token = serializers.CharField(max_length=100) image = serializers.ImageField() from .models import * from django.views.decorators.csrf import csrf_exempt import time import hashlib class ImageUpload(APIView): ''' 图片上传接口 \n "http://127.0.0.1:8000/pages/uploadImage" (我简单写了个页面做提交)\n ''' # coreapi_fields = (DocParam(name='token', description='token'), # DocParam(name='image', description='文件', type='file'),) @csrf_exempt def post(self, request, *args, **kwargs): image = request.FILES['image'] data = get_parameter_dic(request) # 需要判断文件类型是否是图片. serial = ImageUploadSerializer(data={"token": data["token"], "image": image}) if serial.is_valid(): print("校验成功") else: return JsonError("参数校验失败") image = serial.validated_data.get("image") new_image = Image(image=image) imageName = str(new_image.image.name) location = str(imageName).find('.') extension = imageName[location:] name = imageName[:location] namestring = name+str(time.time()) md5 = hashlib.md5(namestring.encode('utf-8')).hexdigest() new_image.image.name = md5[:10] + extension new_image.save() return JsonResponse(data=new_image)
运行项目
调用上传图片接口, 我用了postman测试接口
图片存储位置
图片的完整访问路径为
http://localhost:8000/image/201710/20/d527b242d1.jpg
此时请求会失败因为这个路径不允许访问, 需要进行简单配置
setting.py 文件中添加
MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media').replace('\\', '/')
urls.py文件中添加
from django.conf.urls import url, include from django.contrib import admin from rest_framework.schemas import get_schema_view from mytest.views import ReturnJson import mytest from mytest.views import SwaggerSchemaView from mytest.views import ImageUpload from django.views.static import serve from django.conf import settings urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^api-auth/', include('rest_framework.urls', namespace='rest_framework')), url(r'^docs/', SwaggerSchemaView.as_view(), name='apiDocs'), url(r'^api/getjson', ReturnJson.as_view()), url(r'^api/uploadimage', ImageUpload.as_view()), # url(r'^static/("htmlcode">http://localhost:8000/media/image/201710/20/d527b242d1.jpg写一个查询所有图片并返回json的接口
from .models import Image class GETAllImages(APIView): def get(self, request, *args, **kwargs): imagesset=Image.objects.all() return JsonResponse(data=imagesset)修改urls.py文件添加此接口
from django.conf.urls import url, include from django.contrib import admin from rest_framework.schemas import get_schema_view from mytest.views import ReturnJson import mytest from mytest.views import SwaggerSchemaView from mytest.views import ImageUpload, GETAllImages from django.views.static import serve from django.conf import settings urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^api-auth/', include('rest_framework.urls', namespace='rest_framework')), url(r'^docs/', SwaggerSchemaView.as_view(), name='apiDocs'), url(r'^api/getjson', ReturnJson.as_view()), url(r'^api/uploadimage', ImageUpload.as_view()), url(r'^api/getallimage', GETAllImages.as_view()), url(r'^static/("text-align: center">以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】
- 邓丽欣.2006-FANTASY【金牌大风】【WAV+CUE】
- 饭制《黑神话》蜘蛛四妹手办
- 《燕云十六声》回应跑路:年内公测版本完成95%
- 网友发现国内版《双城之战》第二季有删减:亲亲环节没了!
- 邓丽君2024-《漫步人生路》头版限量编号MQA-UHQCD[WAV+CUE]
- SergeProkofievplaysProkofiev[Dutton][FLAC+CUE]
- 永恒英文金曲精选4《TheBestOfEverlastingFavouritesVol.4》[WAV+CUE]
- 群星《国风超有戏 第9期》[320K/MP3][13.63MB]
- 群星《国风超有戏 第9期》[FLAC/分轨][72.56MB]