如何解决在 phoenix 框架 (absinthe) 中使用 grahql 在 API 响应中发送可下载文件
我目前正在使用 absinthe 发送 json 字符串以响应 graphql 中的 API 请求。它的架构如下所示:
object :export_data do
field :resp_data,:json
end
我现在想在 API 响应中发送可下载的 json 文件而不是 json 字符串。我最初的想法是在 absinthe 模式中使用 :file
类型,并使用 File.write/2
或文件支持的任何数据类型从解析器返回文件。但是我在他们的 documentation 中找不到苦艾酒支持的文件数据类型。如何在 graphql API 响应中发送 json 文件?
解决方法
我认为最好在这里跳过graphql并通过控制器来完成。这是一个如何处理可下载的 CSV 文件的伪示例,也可以使用 put_resp_header 处理文件类型。
CSV 控制器
def download_csv(conn,%{"id" => id}) do
fields = # Call fields from struct or DB
header = Enum.map(fields,&Phoenix.Naming.humanize/1)
items = # transform data more,Enum.map() |> etc...
csv = CSV.encode([header] ++ items) |> Enum.join
conn
|> put_resp_content_type("text/csv")
|> put_resp_header("content-disposition",~s[attachment; filename="data.csv"])
|> text(csv)
end
路由器
get "/csv/:id/download_csv",CsvController,:download_csv
Csv 模板
<%= form_for @conn,Routes.customer_path(@conn,:download_csv,@customer.id),[method: :get],fn f -> %>
<button class="btn btn-primary">Download Full CDRs</button>
<% end %>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。