如何通过 API 上传文件?

我正在尝试弄清楚如何通过 API 允许文件上传 通过 API。 我看到了一篇有帮助的帖子:https://meta.discourse.org/t/how-to-upload-a-file-via-api-and-get-its-url/123732/3,

但它没有提供实际的语法——这正是我困扰的地方。有人知道 AJAX 调用的实际语法吗?

我目前的代码如下:

 method: "post",
      url: [site]/uploads.json,
      contentType: "multipart/form-data",
      data: {
        type: "composer",
        file: '/path_to_file_from_users_machine'
      },
      headers: {
        "User-Api-Key": key
      },
      dataType: "json",
    }).then((result)=>{

但这返回了 422 响应——这个语法似乎有些问题。我该如何让它正常工作?

1 个赞

该响应是否有附带消息?这应该能为您提供更多信息。

据我所见,这是唯一的响应:
Error: Request failed with status code 422

我在日志中也没有看到任何内容。

这是一个有人成功运行的 Node.js 示例,或许能对您有所帮助:

非常感谢,@blake。这是一篇很有帮助的帖子,我之前没看到过(尽管我搜索过类似的内容)。它肯定会帮助我继续推进。不过,有一处引起了我的注意。链接代码中的这一行:

const file = fs.readFileSync(filename);

这行代码意味着上传到 Discourse 的并不是文件本身,而是文件的内容(在上面的代码中,file 变量等于从读取文件返回的字符串)。这让我感到意外,我想知道这对上传二进制文件或媒体文件意味着什么(这些文件如果大小合适,可以直接上传到 Discourse 且没有问题,但我不确定先读取它们会如何工作)。

不过,我会去查看一下。

1 个赞

大家好,经过一番挣扎和反复试验,我想分享一个适用于将文件上传到 Discourse 的 PHP 示例!给你们。另外,我一直在创建一个最初来自 communiteq/discourse-api-php: PHP API client for Discourse (github.com) 的更新库:

<?php
	
	$curl = curl_init();
	
	curl_setopt_array($curl, array(
		CURLOPT_URL => 'https://example.com/uploads.json',
		CURLOPT_RETURNTRANSFER => true,
		CURLOPT_ENCODING => '',
		CURLOPT_MAXREDIRS => 10,
		CURLOPT_TIMEOUT => 0,
		CURLOPT_FOLLOWLOCATION => true,
		CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
		CURLOPT_CUSTOMREQUEST => 'POST',
		CURLOPT_POSTFIELDS => array(
			'type' => 'composer',
			'synchronous' => 'true',
			'file'=> new CURLFILE('/directory/filename.txt')),
		CURLOPT_HTTPHEADER => array(
			'Content-Type: multipart/form-data',
			'Accept: application/json',
			'Api-Key: <your api key>',
			'Api-Username: <your api user id>'
		),
	));
	
	$response = curl_exec($curl);
	$info = curl_getinfo($curl);
	curl_close($curl);
	print_r(json_decode($response,1));
	print_r($info);
?>

示例输出:

Array
(
    [id] => 627
    [url] => https://example.com/uploads/default/original/1X/4661e3a873857e04440bcc3e4290e241eb6c08d7.txt
    [original_filename] => filename.txt
    [filesize] => 461
    [width] => 
    [height] => 
    [thumbnail_width] => 
    [thumbnail_height] => 
    [extension] => txt
    [short_url] => upload://a2D9hHsjwsdrVWkzlu5Go4c1VvV.txt
    [short_path] => /uploads/short-url/a2D9hHsjwsdrVWkzlu5Go4c1VvV.txt
    [retain_hours] => 
    [human_filesize] => 461 Bytes
    [dominant_color] => 
    [thumbnail] => 
)
Array
(
    [url] => https://example.com/uploads.json
    [content_type] => application/json; charset=utf-8
    [http_code] => 200
    [header_size] => 422
    [request_size] => 1244
    [filetime] => -1
    [ssl_verify_result] => 0
    [redirect_count] => 0
    [total_time] => 0.029617
    [namelookup_time] => 0.00046
    [connect_time] => 0.003265
    [pretransfer_time] => 0.003592
    [size_upload] => 911
    [size_download] => 460
    [speed_download] => 15531
    [speed_upload] => 30759
    [download_content_length] => 460
    [upload_content_length] => 911
    [starttransfer_time] => 0.029604
    [redirect_time] => 0
    [redirect_url] => 
    [primary_ip] => 192.168.192.40
    [certinfo] => Array
        (
        )

    [primary_port] => 80
    [local_ip] => 192.168.192.18
    [local_port] => 61613
    [http_version] => 2
    [protocol] => 1
    [ssl_verifyresult] => 0
    [scheme] => http
    [appconnect_time_us] => 0
    [connect_time_us] => 3265
    [namelookup_time_us] => 460
    [pretransfer_time_us] => 3592
    [redirect_time_us] => 0
    [starttransfer_time_us] => 29604
    [total_time_us] => 29617
    [effective_method] => POST
    [capath] => 
    [cainfo] => 
)

另外,在 Postman 的示例中也得到了巨大的帮助:Creates an upload | Discourse | Postman API Network

祝好

5 个赞