目录
将图片到FastDFS和浏览的流程图
使用自定义文件存储类
1、定义存储类
2、创建FastDFS的配置文件
3、修改settings.py配置
4、上传图片进行验证
4.1 定义一个包含ImageField字段的模型类
4.2 登录django的admin后台
4.3 上传图片
4.4 查看图片
源码等资料获取方法
先部署好FastDFS,这个以前我的文章有讲过,可以去找找看
将图片到FastDFS和浏览的流程图
使用自定义文件存储类
1、定义存储类
自定义django文件存储类需要继承django的Storage类,并重写_open、_save、url、exists方法
创建fdfs_storage.py文件
实现如下代码:
from django.core.files.storage import Storage
from fdfs_client.client import Fdfs_client
from dailyfresh import settings
class FastDFSStorage(Storage):
"""FastDFS文件存储类"""
def __init__(self, client_conf=None, nginx_url=None):
self.client_conf = client_conf or settings.FDFS_CLIENT_CONF
self.nginx_url = nginx_url or settings.NGINX_URL
def _open(self, name, mode='rb'):
"""
用于打开文件
:param name: 要打开的文件的名字
:param mode: 打开文件方式
:return: None
"""
# 打开文件时使用的,此时不需要,而文档告诉说明必须实现,所以pass
pass
def _save(self, name, content):
"""
用于保存文件
:param name: 要保存的文件名字
:param content: 要保存的文件的内容
:return: None
"""
# 创建一个Fdfs_client对象, 需要client配置文件
client = Fdfs_client(self.client_conf)
# 上传文件到fastdfs系统中
ret_dict = client.upload_by_buffer(content.read())
# ret_dict返回的是一个字典,类型如下
"""
{
'Group name': 'group1',
'Local file name': '02.png',
'Remote file_id': 'group1/M00/00/00/wKgNgF9uzVuAd7JlAAS-_JN9ZAI299.png',
'Status': 'Upload successed.',
'Storage IP': '192.168.13.128',
'Uploaded size': '303.00KB'
}
"""
if ret_dict.get("Status") != "Upload successed.":
# 上传失败
raise Exception("上传文件到fastdfs失败")
# 获取返回的文件id
file_id = ret_dict.get("Remote file_id")
# 返回什么内容,最终在image属性对应的表中的字段保存的就是什么内容
return file_id
def url(self, name):
"""
返回name所指文件的绝对URL
:param name: 文件的id
:return: 文件的url
"""
# return 'http://ip:port/' + name
return self.nginx_url + name
def exists(self, name):
""" Django判断文件名是否可用, 必须重写"""
return False
2、创建FastDFS的配置文件
创建fdfs_client.conf文件
内容如下:
connect_timeout=30
network_timeout=60
tracker_server=192.168.107.201:22122
http.tracker_server_port=8080
3、修改settings.py配置
在setting.py文件中添加如下配置
# 设置Django的文件存储类
DEFAULT_FILE_STORAGE = 'utils.fdfs_storage.FastDFSStorage'
# FastDFS配置文件路径
FDFS_CLIENT_CONF = os.path.join(BASE_DIR, "./dailyfresh/fdfs_client.conf")
# 设置fdfs存储服务器上nginx的IP和端口号
NGINX_URL = 'http://192.168.107.201:8080/'
4、上传图片进行验证
4.1 定义一个包含ImageField字段的模型类
class GoodsType(BaseModel):
'''商品类型模型类'''
name = models.CharField(max_length=20, verbose_name='种类名称')
logo = models.CharField(max_length=20, verbose_name='标识')
image = models.ImageField(upload_to='type', verbose_name='商品类型图片')
class Meta:
db_table = 'df_goods_type' # 数据库表格名称
verbose_name = '商品种类'
verbose_name_plural = verbose_name
def __str__(self):
return self.name
在该模型类所属应用的admin.py中注册该模型类
4.2 登录django的admin后台
创建django的admin后台管理账号
python manage.py createsuperuser
在浏览器中输入 127.0.0.1/admin,输入上面创建的账号和密码进入admin管理后台
4.3 上传图片
点击增加
完善信息后,点击保存
保存成功后,进入详情界面,可以看到上传图片在FastDFS中保存的id
4.4 查看图片
不能使用“nginx地址+图片id”直接查看图片,需要在html静态页面引用查看
访问结果
源码等资料获取方法
各位想获取源码的朋友请点赞 + 评论 + 收藏,三连!
三连之后我会在评论区挨个私信发给你们~