• 新浪sae部署django1.4


    1.sae上建立一个python应用,并将版本库checkout到本地:

    svn co https://svn.sinaapp.com/projectname

    用户名为安全邮箱,密码为安全密码。

    把工程复制到版本库下并重命名工程名为1,作为默认版本代码目录。

    2.在默认版本目录下创建应用配置文件config.yaml,在其中添下如下内容:

    libraries:

    - name: “django”

    version: “1.4”

    handlers:

    - url: “static”

    static_dir: “mysite/static”

    创建文件index.wsgi,内容如下:

    import sae

    from mysite import wsgi

    application = sae.create_wsgi_app(wsgi.application)

    最终目录结构如下:

    jaime@westeros:~/pythondemo$ ls 1
    config.yaml index.wsgi manage.py mysite/
    jaime@westeros:~/pythondemo/1$ ls 1/mysite
    __init__.py settings.py  urls.py  views.py
    这样一个django工程就上传的sae了。
    3.django工程添加数据库。
     1)做django同步数据库。通过本地phpmyadmin导出本地django数据库文件,并保存。
     2)通过svn版本控制修改djangosettings文件。如下:
    django链接数据库配置如下:
    if 'SERVER_SOFTWARE' in os.environ:
        from sae.const import (
            MYSQL_HOST, MYSQL_PORT, MYSQL_USER, MYSQL_PASS, MYSQL_DB
        )
    else:
        # Make `python manage.py syncdb` works happy!
        MYSQL_HOST = 'localhost'
        MYSQL_PORT = '3306'
        MYSQL_USER = 'root'
        MYSQL_PASS = 'root'
        MYSQL_DB   = 'app_pylabs'
     
    DATABASES = {
        'default': {
            'ENGINE':   'django.db.backends.mysql',
            'NAME':     MYSQL_DB,
            'USER':     MYSQL_USER,
            'PASSWORD': MYSQL_PASS,
            'HOST':     MYSQL_HOST,
            'PORT':     MYSQL_PORT,
        }
    }
    3)在sae官网点击相应的应用,在左方菜单栏点击mysql。为应用添加mysql数据库。点击内容中的初始化mysql。点击管理mysql。通过phpmyadmin导入第一步导出的数据库文件,这样实现了sae上数据库的同步。
    4.sae上传图片。
      由于sae上传版本库只有读的权限。所以采用storage存储上传的图片。
    	1)为应用添加storage服务,并创建一个domain
    	2)修改models 中的ImageField,需要重写ImageFieldsave方法。如下:



    1. from django.db import models

    2. from django.db.models.fields.files import ImageFieldFile,FieldFile,FileField,ImageFile

    3. import sae.storage

    4. class SAEFieldFile(FieldFile):

    5.     def getUploadTo(self):

    6.         return self.upload_to

    7.     def save(self, name, content, save=True):

    8.         name = self.field.generate_filename(self.instance, name)

    9.         #for SAE

    10.         s = sae.storage.Client()

    11.         ob = sae.storage.Object(content._get_file().read())

    12.         url =s.put('media', name, ob)

    13.         self.name = name

    14.         setattr(self.instance, self.field.name, self.name)

    15.         # Update the filesize cache

    16.         self._size = content.size

    17.         self._committed = True

    18.         # Save the object because it has changed, unless save is False

    19.         #if save:

    20.         #    self.instance.save()

    21. class SAEImageFieldFile(ImageFile, SAEFieldFile):

    22.     def delete(self, save=True):

    23.         # Clear the image dimensions cache

    24.         if hasattr(self, '_dimensions_cache'):

    25.             del self._dimensions_cache

    26.         super(ImageFieldFile, self).delete(save)

    27. class ZGImageFieldFile(SAEImageFieldFile):

    28.     def save(self, name, content, save=True):

    29.         super(SAEImageFieldFile, self).save(name, content, save=True)

    30. class ZGImageField(models.ImageField):

    31.     attr_class = ZGImageFieldFile

    32.     def __init__(self, verbose_name=None, name=None, width_field=None, height_field=None, **kwargs):

    33.         super(ZGImageField, self).__init__(verbose_name, name, **kwargs)

    将以上文件放到你的apps/file.py 
    说明: SAE系统,不支持本地文件的上传(也就是网站代码所在目录不支持写操作), 上传的东西, 必须放到 storage这个地方, 它是一个分布式的系统, 支持大数据量的访问。
    django中, 对于上传的写操作, 依赖于models自带的save()方法(有兴趣的可以看看save的源码), 我们在定义一个ImageField这样的属性的时候,
    save()就自动包含了保存到本地文件系统的能力, 问题是, 默认, save是保存到代码所在的文件系统的, 二sae是要求保存到别的地方的, 这就有个问题了
    需要我们重新save方法, 使得上传的东西可以保存在storage这里。 以上代码就是重写的部分


    其次, 在你的models.py中, 就可以调用重写后的上传模型了。
    1. from csvtweb.zg.files import ZGImageField

    2. class TT(models.Model):

    3.         #image = ImageField(upload='./media')

    4.         image = ZGImageField(upload='./media')

    这样就可以了, 在前端页面的显示,需要考虑到 URL全路径, 可以查看admin获取
    3)上传文件后可通过storage中的对应domain查看。访问上传文件路径为:http://projectname-domainname.sinaapp.com/media/objectname

    其中可在settings设置MEDIA_ROOT=”http://projectname-domainname.sinaapp.com/

    那么在iews可导入settings设置。并进行访问settings.MEDIA_ROOT+image.name即为对应的路径。但上传图片最大不要超过2M.

    5.sae上传文件:同上只是重写FileFieldsave方法即可。

    1 from django.db import models

    2 from django.db.models.fields.files import FileField,FieldFile

    3 import sae.storage

    4 import sae

    5 import tempfile

    6 #tempfile.tempdir = sae.core.get_tmp_dir()

    7 class SAEFieldFile(FieldFile):

    8   def getUploadTo(self):

    9     return self.upload_to

    10

    11   def save(self, name, content, save=True):

    12     name = self.field.generate_filename(self.instance, name)

    13     #for SAE

    14     s = sae.storage.Client()

    15      ob = sae.storage.Object(content._get_file().read())

    16      url =s.put('jialong', name, ob)

    17      self.name = name

    18                setattr(self.instance, self.field.name, self.name)

    19

    20            # Update the filesize cache

    21                  self._size = content.size

    22        self._committed = True

    23

    24         # Save the object because it has changed, unless save is False

    25         #if save:

    26       # self.instance.save()

    27 class ZGFileField(FileField):

    28   attr_class = SAEFieldFile

    29   def save(self, name, content, save=True):

    30   super(SAEImageFieldFile, self).save(name, content, save=True)

  • 相关阅读:
    jquery文件上传控件 Uploadify
    【jQuery】uploadify,实际开发案例【选择完文件点击上传才上传】
    StarUML2 建模工具全平台破解及license验证简要分析
    Error:Failed to resolve: com.afollestad:material-dialogs:
    Android studio Github 断开连接
    Crashlytics Android 异常报告统计管理
    Android Studio集成crashlytics后无法编译的问题
    Android studio启动后卡在refreshing gradle project
    Android项目源码分享
    Android开发案例
  • 原文地址:https://www.cnblogs.com/baoyiluo/p/2862515.html
Copyright © 2020-2023  润新知