網站首頁 編程語言 正文
1.安裝fdfs_client
2.將/etc/fdfs/client.conf復制到windows項目下
配置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中確實存在的目錄存放log文件
# tracker_server can ocur more than once, and tracker_server format is
# "host:port", host can be hostname or ip address
tracker_server= 虛擬機的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上傳文件
存儲文件方法
from django.core.files.storage import Storage
from fdfs_client.client import Fdfs_client
class FdfsStorage(Storage):
"""fast dfs文件存儲類"""
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'):
"""打開文件時使用"""
pass
def _save(self, name, content):
"""
保存文件時使用
name:上傳文件的名字
content:包含你上傳文件內容的File對象
"""
# 1.創建Fdfs_client對象
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返回訪問文件的url路徑"""
return self.base_url + name
配置項目的settings文件(將django默認的存儲方法設置為自定義的)
# 設置Django的文件存儲類
DEFAULT_FILE_STORAGE = 'utils.fdfs.storage.FdfsStorage'
原文鏈接:https://blog.csdn.net/weixin_43670190/article/details/123048811
相關推薦
- 2021-11-29 .Net性能測試框架Crank的使用方法_基礎應用
- 2022-06-13 Python標準庫之time庫的使用教程詳解_python
- 2022-12-15 QT中對話框的使用示例詳解_C 語言
- 2022-04-05 本地文件提交到gitee上報錯的問題:error: src refspec master does
- 2022-06-01 Python實現xml格式轉txt格式的示例代碼_python
- 2022-07-04 PyCharm如何配置SSH和SFTP連接遠程服務器_python
- 2022-10-28 Python入門之列表用法詳解_python
- 2022-06-21 Android?Studio實現下拉列表效果_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支