「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Cloudinary を Next.js アプリケーションに統合する

Cloudinary を Next.js アプリケーションに統合する

2024 年 11 月 8 日に公開
ブラウズ:337

Integrate Cloudinary in a Next.js application

Cloudinary とその価格についてお読みください。

1.Cloudinaryアカウントを作成する

Cloudinary にサインアップし、アカウントをお持ちでない場合は新しいアカウントを作成します。

2.Cloudinary SDKをインストールする

npm またはyarnを使用して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