django自定义存储类,改变默认上传图片到fastdfs服务器

下载fastdfsPython客户端,https://github.com/jefforeilly/fdfs_client-py
安装:

pip install fdfs_client-py-master.zip
pip install mutagen
pip isntall requests

1.自定义存储类

from django.core.files.storage import Storage
from fdfs_client.client import Fdfs_client

class FdfsStorage(Storage):
    def __init__(self, client_conf=None, tracker_server=None):
        self.client_conf = './utils/fdfs/fdfs_client.conf'
        self.tracker_server = 'http://192.168.28.129:8889/'

    def _open(self, name, mode='rb'):
        """
        Retrieves the specified file from storage.
        """
        pass

    def _save(self, name, content):

        f_client = Fdfs_client(self.client_conf)
        res = f_client.upload_by_buffer(content.read())
        # res 返回值
        # dict
        # {
        #     'Group name': group_name,
        #     'Remote file_id': remote_file_id,
        #     'Status': 'Upload successed.',
        #     'Local file name': '',
        #     'Uploaded size': upload_size,
        #     'Storage IP': storage_ip
        # }
        if res.get('Status') != 'Upload successed.':
            raise Exception('上传失败')
        filename = res.get('Remote file_id')
        print(filename)
        return self.tracker_server + filename.replace('\\', '/')

    def exists(self, name):
        return False

    def url(self, name):
        return name

2.fastdfs配置文件

# connect timeout in seconds
# default value is 30s
connect_timeout=30

# network timeout in seconds
# default value is 30s
network_timeout=60

# the base path to store log files

# log store
base_path=r'D:\log'

# tracker_server can ocur more than once, and tracker_server format is
# "host:port", host can be hostname or ip address
# server
tracker_server=192.168.28.129:22122     

#standard log level as syslog, case insensitive, value list:
### emerg for emergency
### alert
### crit for critical
### error
### warn for warning
### notice
### info
### debug
log_level=info

# if use connection pool
# default value is false
# since V4.05
use_connection_pool = false

# connections whose the idle time exceeds this time will be closed
# unit: second
# default value is 3600
# since V4.05
connection_pool_max_idle_time = 3600

# if load FastDFS parameters from tracker server
# since V4.05
# default value is false
load_fdfs_parameters_from_tracker=false

# if use storage ID instead of IP address
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker is false
# default value is false
# since V4.05
use_storage_id = false

# specify storage ids filename, can use relative or absolute path
# same as tracker.conf
# valid only when load_fdfs_parameters_from_tracker is false
# since V4.05
storage_ids_filename = storage_ids.conf


#HTTP settings
http.tracker_server_port=80

#use "#include" directive to include HTTP other settiongs
##include http.conf

3.settings中配置

# 自定义存储类
DEFAULT_FILE_STORAGE = 'utils.fdfs.storage.FdfsStorage'

# fdfs客户端配置文件
FDFS_CLIENT = './utils.fdfs.fdfs_client.conf'

# trackerServer地址
TRACKER_SERVER = 'http://192.168.28.129:8889/'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值