Skip to main content

Django Aliyun OSS (Object Storage Service) storage 适用于Django4.0

Project description

Django AliCloud OSS Storage


django-oss-storage provides a Django AliCloud OSS file storage.

Features


  • Django file storage for AliCloud OSS

  • Django static file storage for AliCloud OSS

  • Works in Python 2 & 3

Installation


  • Install

$ pip install django-oss-storage
  • Add 'django_oss_storage' to your INSTALLED_APPS setting

  • Set your DEFAULT_FILE_STORAGE setting to "django_oss_storage.backends.OssMediaStorage"

  • Set your STATICFILES_STORAGE setting to "django_oss_storage.backends.OssStaticStorage"

  • Configure your AliCloud OSS settings (Refer below).

Use the following settings for file storage.

STATICFILES_STORAGE = 'django_oss_storage.backends.OssStaticStorage'



DEFAULT_FILE_STORAGE = 'django_oss_storage.backends.OssMediaStorage'

Authentication settings


Use the following settings to authenticate with AliCloud OSS.

# AliCloud access key ID

OSS_ACCESS_KEY_ID = <Your Access Key ID>



# AliCloud access key secret

OSS_ACCESS_KEY_SECRET = <Your Access Key Secret>

Storage settings


For public or public-read buckets, storage urls will be bucket_name.endpoint/key format

For private buckets, storage urls will be signed url. The expires time can be set by OSS_EXPIRE_TIME as environment variable or as Django settings. The default value for OSS_EXPIRE_TIME is 30 days.

OSS_EXPIRE_TIME = <Expire Time in Seconds>

File storage settings


Use the following settings to configure AliCloud OSS file storage.

# The name of the bucket to store files in

OSS_BUCKET_NAME = <Your bucket name>



# The URL of AliCloud OSS endpoint

# Refer https://www.alibabacloud.com/help/zh/doc-detail/31837.htm for OSS Region & Endpoint

OSS_ENDPOINT = <Your access endpoint>



# The default location for your files

MEDIA_URL = '/media/'

Staticfiles storage settings


All of the file storage settings are available for the staticfiles storage.

# The default location for your static files

STATIC_URL = '/static/'

staticfiles provides command ‘collectstatic’. Run following command to collect all sub-folder ‘static’ of each app

and upload to STATIC_URL.

$ python manage.py collectstatic

Testing


First set the required AccessKeyId, AccessKeySecret, endpoint and bucket information for the test through environment variables (Do not use the bucket for the production environment).

Take the Linux system for example:

$ export OSS_ACCESS_KEY_ID=<AccessKeyId>

$ export OSS_ACCESS_KEY_SECRET=<AccessKeySecret>

$ export OSS_BUCKET_NAME=<bucket>

$ export OSS_ENDPOINT=<endpoint>

Support and announcements


Downloads and bug tracking can be found at the main project website.

License


Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django4.0-oss-storage-1.2.0.tar.gz (10.0 kB view details)

Uploaded Source

File details

Details for the file django4.0-oss-storage-1.2.0.tar.gz.

File metadata

  • Download URL: django4.0-oss-storage-1.2.0.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.5

File hashes

Hashes for django4.0-oss-storage-1.2.0.tar.gz
Algorithm Hash digest
SHA256 0f189651fcfbc79fe5d185d7d8fa4357d4ff20c8cd395933aef60d3b311b4934
MD5 7ad28098d9e8f32a5d58cd07d8c79e11
BLAKE2b-256 d03a048848b9cf8fef2478bf7d95c8f93aed19acff7985a8507898fb1bad1c96

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page