繁体   English   中英

通过 Websocket 连接将文件上传到 Django 频道(来自本机应用程序)

[英]Upload files to Django Channels through a Websocket connection ( from react native app )

我想允许用户从应用程序上传文件,它必须通过 WebSocket 连接,我很难找到解决方案,到目前为止我找到的所有解决方案都需要设置 Content-Type 标头,而对于 WS 连接,我不能无论如何找到这样做

上传文件的 JavaScript 代码:

const fd = new FormData();
fd.append('uri', uri)

// I get the URI from user gallery expo-image-picker
// The URI looks like this:  file:/data/user/0/host.exp.exponent/cache/ExperienceData/%2540zeyadshaban%252Forgachat/ImagePicker/394f4262-184d-4adc-9a51-db32afcb86a2.png

JSON.stringify({
        fd,
        type: 'image',
    })

在后端(consumers.py)中,我尝试直接保存文件,但它不断抛出错误

elif json_data.get('type') == 'image':
     my_model_instance.image = json_data.get('fd')

await sync_to_async(my_model_instance.save)()

当我在终端中检查 json_data.get('fd') 时,我得到了这个

>> json_data.get('fd')
{'_parts': [[...]]}

我强烈建议您不要通过 websocket 连接上传大量数据,最好创建另一个辅助 http 端点并将其用于文件上传。 所用数据的 URL 编码使其可以内联到 JSON 中,这将使传输的数据量成倍增加。

如果您坚持使用 WS 上传数据,那么您应该使用二进制框架而不是 JS 框架。 要包含内容类型,我建议您通过创建一个专门用于上传数据的 WS 端点来实现,当您连接到它时,您首先发送带有信息的 JSON 帧(如内容类型),然后发送大量二进制帧与数据。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM