Pregunta

Estoy utilizando Flask micro-marco 0.6 y Python 2.6

Necesito conseguir los tipo MIME de un archivo subido, así que puede almacenarla.

Esta es la relevante código Python / Frasco:

@app.route('/upload_file', methods=['GET', 'POST'])
def upload_file():
    if request.method == 'POST':
        file = request.files['file']
        mimetype = #FIXME
        if file:
            file.save(os.path.join(UPLOAD_FOLDER, 'File-Name')
            return redirect(url_for('uploaded_file'))
        else:
            return redirect(url_for('upload'))


Y aquí está el código de la página web:

<form action="upload_file" method=post enctype=multipart/form-data> 
Select file to upload: <input type=file name=file> 
<input type=submit value=Upload> 
</form> 


El código funciona, pero tengo que ser capaz de obtener los mimetype cuando se sube. He echado un vistazo a la documentación Frasco aquí: http: // frasco. pocoo.org/docs/api/#incoming-request-data
Así que sé que se pone el tipo MIME, pero no puedo encontrar la manera de recuperarlo - como una cadena de texto, por ejemplo, 'Txt / plain'.

¿Alguna idea?

Gracias.

¿Fue útil?

Solución

Desde el docs , file.content_type contiene el tipo completo con la codificación, mimetype contiene sólo el tipo MIME.

@app.route('/upload_file', methods=['GET', 'POST'])
def upload_file():
    if request.method == 'POST':
        file = request.files.get('file')
        if file:
            mimetype = file.content_type
            filename = werkzeug.secure_filename(file.filename)
            file.save(os.path.join(UPLOAD_FOLDER, filename)
            return redirect(url_for('uploaded_file'))
        else:
            return redirect(url_for('upload'))

Otros consejos

Se podría, en teoría el uso request.files['YOUR_FILE_KEY'].content_type, pero la aplicación (incluido a continuación, que se encuentra en werkzeug.datastructures ) o bien la confianza lo que el cliente está proporcionando, o usos mimetypes.guess_type cuales sólo comprueba la extensión de archivo (ver doc Python aquí ).

class FileMultiDict(MultiDict):

    """A special :class:`MultiDict` that has convenience methods to add
    files to it.  This is used for :class:`EnvironBuilder` and generally
    useful for unittesting.
    .. versionadded:: 0.5
    """

    def add_file(self, name, file, filename=None, content_type=None):
        """Adds a new file to the dict.  `file` can be a file name or
        a :class:`file`-like or a :class:`FileStorage` object.
        :param name: the name of the field.
        :param file: a filename or :class:`file`-like object
        :param filename: an optional filename
        :param content_type: an optional content type
        """
        if isinstance(file, FileStorage):
            value = file
        else:
            if isinstance(file, string_types):
                if filename is None:
                    filename = file
                file = open(file, 'rb')
            if filename and content_type is None:
                content_type = mimetypes.guess_type(filename)[0] or \
                    'application/octet-stream'
            value = FileStorage(file, filename, name, content_type)

        self.add(name, value)

En función de su caso de uso, es posible que desee utilizar pitón-magia que utilizará el archivo real para obtener el tipo MIME. Sería algo así:

import magic


def get_mimetype(data: bytes) -> str:
    """Get the mimetype from file data."""
    f = magic.Magic(mime=True)
    return f.from_buffer(data)


get_mimetype(request.files['YOUR_FILE_KEY'].stream.read(MAX_LENGTH))
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top