社区首页 >问答首页 >将本机图像上传到Elixir菲尼克斯框架

将本机图像上传到Elixir菲尼克斯框架
EN

Stack Overflow用户
提问于 2021-04-14 04:15:13
回答 1查看 225关注 0票数 0

我使用Elixir Phoenix作为我的后端,并创建一个api来上传图像。我正在使用Waffle十六进制包来处理上传。

所以我有一个api

代码语言:javascript
代码运行次数:0
复制
localhost:4000/uplaod_avatar/

并在控制器中运行此函数:

代码语言:javascript
代码运行次数:0
复制
  def upload_avatar(conn, params) do
    scope = Repo.get(User, 1)
    case AvatarUploader.store({ params["image"], scope }) do
      {:ok, filename} ->
        IO.puts(filename)
        render(conn, "upload.json", params: %{"status" => :success, "filename" => filename})
      _ ->
        render(conn, "upload.json", params: %{"status" => :error})
    end
  end

当我用Postman测试它时,一切都正常。我用formData测试它,如下图所示:

这是来自Postman的数据

"/var/folders/y7/9j1md31s75n9kwfbs6q073fw0000gn/T//plug-1618/multipart-1618382732-484457522147916-1"}} %{“=> %Plug.Upload”{content_type:"image/png",文件名:“屏幕截图2021-03-10 at 4.31.53 PM.png",路径:PM.png

Phoenix Framework似乎理解了传入的内容数据,并使用Plug.Upload进行处理。

但是,当我使用React Native测试(ios版本)时,我会这样做:

代码语言:javascript
代码运行次数:0
复制
const data = new FormData();
      data.append('image',{
        name: this.state.fileName,
        type:this.state.fileType,
        uri:this.state.fileUri
      })

使用相同的api,我得到如下数据:

%{ => <<255,216,255,224,0,16,74,70,73,70,0,1,1,0,0,0,72,0,72,0,0,0,255,225,0,88,69,120,105,102,0,0,77,77,0,42,0,0,0,8,0,2,1,18,0,3,0,0,0,1,0,0,...>>}

当然,api并不适用于react native

如何将来自react native的数据转换为类似于Postman的数据

Update01经过一番周旋之后,我发现Postman的代码是:

代码语言:javascript
代码运行次数:0
复制
var formdata = new FormData();
formdata.append("image", fileInput.files[0], "Screenshot 2021-03-10 at 4.31.53 PM.png");

现在,问题是,我怎样才能从fileInput.files[0]获得React Native

EN

回答 1

Stack Overflow用户

发布于 2021-04-14 08:12:33

就像Aleksei说的,您需要设置headers,仅举一个小的例子,它看起来如下所示

代码语言:javascript
代码运行次数:0
复制
selectImage(async (result) => {
  try {
    if (!result) throw new Error('Not selected')
    setAvatarLoading(true)

    const localUri = result.uri
    const filename = localUri.split('/').pop()

    const formData = new FormData()
    formData.append('token', getToken())
    formData.append('file', {
      uri: localUri,
      name: filename,
      type: 'image/jpeg',
    })

    await fetch(avatarEndpoint, {
      method: 'POST',
      body: formData,
      header: { 'content-type': 'multipart/form-data' },
    })

    await onChange()
  } catch (ex) {
    console.log(ex)
    throw ex
  } finally {
    setAvatarLoading(false)
  }
})

稍后你将通过凤凰号控制器处理它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67091575

复制
相关文章
Hibernate @OneToMany 及 @Cascade级联操作
由此,就会使用级联操作,在一对多关系中,@Cascade属性(级联)只设置“一”的一方即可,外键由“多”的一方进行维护。
好好学java
2020/03/16
6.1K0
Hibernate @OneToMany 及 @Cascade级联操作
Java 多重选择结构
多重选择结构是一种程序控制结构,它允许程序在多个条件之间进行选择,并执行相应的操作。它使用一系列的if-else语句,以及一个或多个switch语句,以便在多个条件之间进行选择。
久绊A
2023/03/24
3550
对象持久化API之JPA入门教程
注意:JPA是规范,不是ORM框架,是ORM框架的规范,JPA没有实现ORM,具体实现由ORM厂商提供
SmileNicky
2019/01/17
1.1K0
JPA系列之对象持久化API JPA简介
注意:JPA是规范,不是ORM框架,是ORM框架的规范,JPA没有实现ORM,具体实现由ORM厂商提供
SmileNicky
2022/05/07
8360
JPA系列之对象持久化API JPA简介
Hibernate学习笔记 多表映射
前面说了Hibernate的单表映射,由于是实体类和数据表之间一对一的映射,所以比较简单。现在就来说说多表映射,这需要涉及到多个实体类和数据表之间的关系。因此稍微复杂一点。
乐百川
2022/05/05
1.6K0
【Hibernate】Hibernate框架配置详解
通过Hibernate我们可以方便地操作数据库读取出来的信息,减少了繁琐的JDBC操作。
陈树义
2022/04/29
1.4K0
JPA关系映射系列三:one-to-many和many-to-one
本篇文章引导你通过Spring Boot,Spring Data JPA和MySQL实现one-to-many和many-to-one关联映射。
java干货
2021/02/17
9890
Hibernate Annotation (Hibernate 注解)
英文:http://docs.jboss.org/hibernate/annotations/3.5/reference/en/html_single/
Hongten
2018/09/18
1.4K0
Hibernate检索策略
Hibernate的检索策略可以通过配置文件或注解来定义。以下是Hibernate中常用的几种检索策略:
堕落飞鸟
2023/05/16
4700
碎片化 | 第四阶段-56-ManyToOne和OneToMany映射关系-视频
http://v.qq.com/x/page/f0567zgfet1.html ManyToOne (多对1) 表结构: note表----usernote表----(多对1) 1:将usernote实体类进行hibernate映射 2:在note实体类中,增加属性值和注解,并将原有userId属性注释 @ManyToOne @JoinColumn(name="userId") private Usernote usernote; 3:修改listDetail.jsp文件
码神联盟
2018/04/03
9070
Hibernate关联关系
文章目录 1. Hibernate关联关系 1.1. 一对一 1.1.1. 背景 1.1.2. 准备 1.1.3. 单向外键关联 1.1.3.1. 通过丈夫访问妻子 1.1.3.2. 通过妻子访问丈夫 1.1.3.3. 总结 1.1.4. 双向外键关联(@OneToOne(mappedBy=””) 1.1.4.1. 问题 1.1.4.2. 解决办法 1.1.4.3. 实现 1.1.4.4. 测试 1.2. 一对多 1.2.1. 准备 1.2.2. 前提须知 1.2.3. 单向外键关联 1.2.3.1.
爱撒谎的男孩
2019/12/31
6.3K1
如何在 Spring Boot 中 读写数据
写在前面:2020年面试必备的Java后端进阶面试题总结了一份复习指南在Github上,内容详细,图文并茂,有需要学习的朋友可以Star一下! GitHub地址:https://github.com/abel-max/Java-Study-Note/tree/master
用户5546570
2020/09/28
15.9K0
如何在 Spring Boot 中 读写数据
hibernate的关联与级联
1、关联指的是类之间的引用关系。如果类A与类B关联,那么被引用的类B将被定义为类A的属性。 2、关联的分类:关联可以分为一对一、一对多/多对一、多对多关联
全栈程序员站长
2022/08/04
1.3K0
hibernate的关联与级联
JPA 注解学习
最近学习hibernate注解形式配置POJO类,将注解的解析记下来,以备以后使用。
一个会写诗的程序员
2018/08/17
2.9K0
Hibernate
一、什么是 Hibernate? Hibernate 是一个基于元数据的轻量级的 ORM 框架: 1、元数据(Meta Data):data about data(数据的数据),也就是说描述一个对
用户2038009
2021/03/08
1.3K0
Spring 全家桶之 Spring Data JPA(四)
只配置了客户到联系人的关系,查看执行的SQL,相比上一次测试多了一条update外键的sql语句
RiemannHypothesis
2022/08/19
1.6K0
Spring 全家桶之 Spring Data JPA(四)
Hibernate的入门(Hibernate的环境搭建、Hibernate的API)
Hibernate第一天(Hibernate的环境搭建、Hibernate的API、Hibernate的CRUD)
AlbertYang
2020/09/08
1.2K0
Hibernate的入门(Hibernate的环境搭建、Hibernate的API)
ssh搭建开发环境
公司一直不是ssh零配置的框架,每次写action都要在applicationcontext和struts里面配置,好麻烦,最近有空,写了一个ssh零配置的框架 这里写了一个小的项目,以用户权限管理为例 先做准备工作: 1.struts2去官网下载最新版struts开发包http://struts.apache.org/download.cgi#struts216 2.hibernate4去官网下载最新版hibernate4开发包http://sourceforge.net/projects/hiberna
xiangzhihong
2018/01/29
2.1K0
Hibernate配置access Hibernate 连接 access
个人测试结果,还是使用方法一比较妥当。方法3出现了一个奇怪错误~~ 1、Hibernate对于Access的支持 方法一: 下载两个jar包,一个是Access的JDBC驱动包;另一个是数据库方言包,里面有支持Access方言的类。 下载地址:http://www.hxtt.com/access.zip,http://www.hxtt.com/test/hibernate.zip。 配置如下:(URL那里可以使用相对路径) xml 代码 <property name="hibernate.dialec
用户1258909
2018/07/03
2.3K0
Hibernate 的应用(Hibernate 的结构)?
SessionFactory sessionFactory = new Configuration().configure().
MickyInvQ
2020/09/27
7490

相似问题

@OneToMany in hibernate

63

Hibernate onetomany映射

26

Hibernate,OneToMany,AnnotationException

35

Hibernate OnetoMany关系

11

Hibernate @OneToMany关系

21
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文