部署FastDFS:https://www.cnblogs.com/testlearn/p/16303541.html
将图片到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静态页面引用查看
访问结果