"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Next.js 애플리케이션에 Cloudinary 통합

Next.js 애플리케이션에 Cloudinary 통합

2024-11-08에 게시됨
검색:342

Integrate Cloudinary in a Next.js application

Cloudinary 및 가격에 대해 알아보세요.

1. Cloudinary 계정 생성

Cloudinary에 가입하고 계정이 없으면 새 계정을 만드세요.

2. Cloudinary SDK 설치

npm 또는 원사를 사용하여 Cloudinary SDK를 설치할 수 있습니다.

npm install cloudinary

3. Cloudinary 구성

Cloudinary 자격 증명을 보관할 구성 파일을 생성할 수 있습니다. 이를 환경 변수에 보관하는 것이 좋습니다.

프로젝트 루트에 .env.local 파일을 생성하고 Cloudinary 자격 증명을 추가합니다.

CLOUDINARY_URL=cloudinary://:@

4. 애플리케이션에서 Cloudinary 설정

// utils/cloudinary.js
import { v2 as cloudinary } from 'cloudinary';

cloudinary.config({
  cloud_name: process.env.CLOUDINARY_CLOUD_NAME,
  api_key: process.env.CLOUDINARY_API_KEY,
  api_secret: process.env.CLOUDINARY_API_SECRET,
});

export const uploadImage = async (file) => {
  try {
    const result = await cloudinary.uploader.upload(file, {
      folder: 'your_folder_name', // optional
    });
    return result.secure_url; // Return the URL of the uploaded image
  } catch (error) {
    console.error('Cloudinary upload error:', error);
    throw new Error('Upload failed');
  }
};

5. 업로드 기능을 활용하세요

// pages/api/upload.js
import { uploadImage } from '../../utils/cloudinary';

export default async function handler(req, res) {
  if (req.method === 'POST') {
    const { file } = req.body; // Assume you're sending a file in the body

    try {
      const url = await uploadImage(file);
      res.status(200).json({ url });
    } catch (error) {
      res.status(500).json({ error: error.message });
    }
  } else {
    res.setHeader('Allow', ['POST']);
    res.status(405).end(`Method ${req.method} Not Allowed`);
  }
}

6. 프런트엔드에서 업로드

// components/ImageUpload.js
import { useState } from 'react';

const ImageUpload = () => {
  const [file, setFile] = useState(null);
  const [imageUrl, setImageUrl] = useState('');

  const handleFileChange = (event) => {
    setFile(event.target.files[0]);
  };

  const handleSubmit = async (event) => {
    event.preventDefault();
    const formData = new FormData();
    formData.append('file', file);

    const res = await fetch('/api/upload', {
      method: 'POST',
      body: formData,
    });

    const data = await res.json();
    if (data.url) {
      setImageUrl(data.url);
    } else {
      console.error('Upload failed:', data.error);
    }
  };

  return (
    
{imageUrl && Uploaded}
); }; export default ImageUpload;

7. 설정 테스트

Next.js 애플리케이션을 실행하고 이미지 업로드 기능을 테스트하세요.

결론

이제 Next.js 앱에 Cloudinary가 통합되어 작동할 것입니다! 특정 요구 사항이 있거나 추가 맞춤화가 필요한 경우 언제든지 문의하세요!

릴리스 선언문 이 글은 https://dev.to/devops_den/integrate-cloudinary-in-a-nextjs-application-8op?1에 복제되어 있습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3