日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

Windows中Python上傳文件到Liunx下的fastdfs

作者:尤諾. 更新時(shí)間: 2022-04-19 編程語(yǔ)言

1.安裝fdfs_client

fdfs_client安裝方法

2.將/etc/fdfs/client.conf復(fù)制到windows項(xiàng)目下

配置client.conf

# 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
base_path=windows中確實(shí)存在的目錄存放log文件

# tracker_server can ocur more than once, and tracker_server format is
#  "host:port", host can be hostname or ip address
tracker_server= 虛擬機(jī)的ip: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.使用python上傳文件

存儲(chǔ)文件方法

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


class FdfsStorage(Storage):
    """fast dfs文件存儲(chǔ)類"""
    def __init__(self, client_conf=None, base_url=None):
        """初始化"""
        if client_conf is None:
            client_conf = './utils/fdfs/client.conf'
        self.client_conf = client_conf

        if base_url is None:
            base_url = 'http://192.168.0.128:8888/'
        self.base_url = base_url

    def _open(self, name, mode='rb'):
        """打開文件時(shí)使用"""
        pass

    def _save(self, name, content):
        """
        保存文件時(shí)使用
        name:上傳文件的名字
        content:包含你上傳文件內(nèi)容的File對(duì)象
        """
        # 1.創(chuàng)建Fdfs_client對(duì)象
        client = Fdfs_client(self.client_conf)

        # 2.上傳文件到fast dfs
        res = client.upload_by_buffer(content.read())

        if res['Status'] != 'Upload successed.':
            # 上傳失敗
            raise Exception('上傳文件到fast dfs失敗')

        # 獲取返回的文件id
        filename = res['Remote file_id']
        return filename

    def exists(self, name):
        """django判斷文件名是否可用"""
        return False

    def url(self, name):
        """django返回訪問(wèn)文件的url路徑"""
        return self.base_url + name

配置項(xiàng)目的settings文件(將django默認(rèn)的存儲(chǔ)方法設(shè)置為自定義的)

# 設(shè)置Django的文件存儲(chǔ)類
DEFAULT_FILE_STORAGE = 'utils.fdfs.storage.FdfsStorage'


原文鏈接:https://blog.csdn.net/weixin_43670190/article/details/123048811

欄目分類
最近更新