Skip to content

ไฟล์

อัปโหลด, แสดงรายการ และเรียกดูไฟล์บน IPFS

Files page showing uploaded and pinned files

อัปโหลดไฟล์

POST /upload/new

อัปโหลดไฟล์ใดก็ได้ไปยัง IPFS ไฟล์จะถูกปักหมุดและส่งคืน CID ถาวร

เนื้อหาคำขอ

พารามิเตอร์ประเภทจำเป็นคำอธิบาย
contentstring | objectใช่อ็อบเจกต์/อาร์เรย์ JSON หรือข้อมูลไฟล์ที่เข้ารหัส base64 (รูปภาพ, PDF, HTML หรือไฟล์ประเภทใดก็ได้)
descriptionstringไม่คำอธิบายสั้นๆ ของเนื้อหาที่อัปโหลด
metadataobjectไม่คู่คีย์-ค่าที่กำหนดเองเพื่อแนบกับไฟล์ สูงสุด 10 คีย์ คีย์ต้องเป็นตัวอักษรและตัวเลขหรือขีดล่าง 1-64 ตัวอักษร ค่าต้องเป็นสตริง สูงสุด 256 ตัวอักษร ขนาด metadata รวมต้องไม่เกิน 4 KB

ตัวอย่างคำขอ

bash
curl -X POST https://api.ipfs.ninja/upload/new \
  -H "X-Api-Key: bws_your_api_key_here" \
  -H "Content-Type: application/json" \
  -d '{
    "content": { "name": "example", "value": 42 },
    "description": "Test upload",
    "metadata": {
      "project": "my-app",
      "environment": "production"
    }
  }'

อัปโหลดรูปภาพ (base64)

javascript
const fs = require("fs");
const image = fs.readFileSync("photo.png").toString("base64");

const response = await fetch("https://api.ipfs.ninja/upload/new", {
  method: "POST",
  headers: {
    "X-Api-Key": "bws_your_api_key_here",
    "Content-Type": "application/json"
  },
  body: JSON.stringify({
    content: image,
    description: "Profile photo"
  })
});

การตอบกลับ 200 OK

json
{
  "cid": "QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN",
  "sizeMB": 0.042,
  "uris": {
    "ipfs": "ipfs://QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN",
    "url": "https://ipfs.ninja/ipfs/QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN"
  }
}

แสดงรายการไฟล์

GET /upload/list

เรียกดูรายการไฟล์ IPFS ที่คุณอัปโหลดในช่วงเวลาที่กำหนด

พารามิเตอร์คิวรี

พารามิเตอร์ประเภทจำเป็นคำอธิบาย
fromnumberใช่เวลาเริ่มต้น, Unix timestamp เป็น milliseconds
tonumberใช่เวลาสิ้นสุด, Unix timestamp เป็น milliseconds

ตัวอย่างคำขอ

bash
curl "https://api.ipfs.ninja/upload/list?from=1704067200000&to=1735689600000" \
  -H "X-Api-Key: bws_your_api_key_here"

การตอบกลับ 200 OK

json
[
  {
    "cid": "QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN",
    "fileName": "Test upload",
    "fileType": "json",
    "sizeMB": 0.001,
    "createdAt": 1711036800000,
    "metadata": {
      "project": "my-app",
      "environment": "production"
    },
    "uris": {
      "ipfs": "ipfs://QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN",
      "url": "https://ipfs.ninja/ipfs/QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN"
    }
  }
]

รับข้อมูลไฟล์

GET /file/:cid

เรียกดู metadata สำหรับไฟล์ที่อัปโหลดเฉพาะโดย CID

พารามิเตอร์ path

พารามิเตอร์ประเภทจำเป็นคำอธิบาย
cidstringใช่ตัวระบุเนื้อหา IPFS ของไฟล์

ตัวอย่างคำขอ

bash
curl https://api.ipfs.ninja/file/QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN \
  -H "X-Api-Key: bws_your_api_key_here"

การตอบกลับ 200 OK

json
{
  "cid": "QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN",
  "fileName": "Test upload",
  "fileType": "json",
  "sizeMB": 0.001,
  "createdAt": 1711036800000,
  "uris": {
    "ipfs": "ipfs://QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN",
    "url": "https://ipfs.ninja/ipfs/QmXmCX9S6ANVjYJh3rJmXjqgYtYv7WZLUDL2XCwdPrvUwN"
  }
}