コンテンツにスキップ

use server

use serverディレクティブは、**サーバーサイド**で実行される関数またはファイルを指定します。ファイルの先頭で使用してファイル内のすべての関数がサーバーサイドであることを示すことも、関数の先頭でインラインで使用してその関数をサーバー関数としてマークすることもできます。これはReactの機能です。

ファイルの先頭でuse serverを使用する

以下の例は、先頭にuse serverディレクティブを持つファイルを示しています。ファイル内のすべての関数はサーバーで実行されます。

app/actions.ts
'use server'
import { db } from '@/lib/db' // Your database client
 
export async function createUser(data: { name: string; email: string }) {
  const user = await db.user.create({ data })
  return user
}

クライアントコンポーネントでサーバー関数を使用する

クライアントコンポーネントでサーバー関数を使用するには、ファイルの先頭でuse serverディレクティブを使用して、専用のファイルにサーバー関数を作成する必要があります。これらのサーバー関数は、クライアントコンポーネントおよびサーバーコンポーネントにインポートして実行できます。

actions.tsfetchUsersサーバー関数がある場合

app/actions.ts
'use server'
import { db } from '@/lib/db' // Your database client
 
export async function fetchUsers() {
  const users = await db.user.findMany()
  return users
}

その後、fetchUsersサーバー関数をクライアントコンポーネントにインポートし、クライアントサイドで実行できます。

app/components/my-button.tsx
'use client'
import { fetchUsers } from '../actions'
 
export default function MyButton() {
  return <button onClick={() => fetchUsers()}>Fetch Users</button>
}

use serverをインラインで使用する

以下の例では、use serverが関数の先頭でインラインで使用され、サーバー関数としてマークされています。

app/page.tsx
import { db } from '@/lib/db' // Your database client
 
export default function UserList() {
  async function fetchUsers() {
    'use server'
    const users = await db.user.findMany()
    return users
  }
 
  return <button onClick={() => fetchUsers()}>Fetch Users</button>
}

セキュリティに関する考慮事項

use serverディレクティブを使用する際は、すべてのサーバーサイドロジックが安全であり、機密データが保護されていることを確認することが重要です。

認証と認可

機密性の高いサーバーサイド操作を実行する前に、必ずユーザーを認証し、認可を行ってください。

app/actions.ts
'use server'
 
import { db } from '@/lib/db' // Your database client
import { authenticate } from '@/lib/auth' // Your authentication library
 
export async function createUser(
  data: { name: string; email: string },
  token: string
) {
  const user = authenticate(token)
  if (!user) {
    throw new Error('Unauthorized')
  }
  const newUser = await db.user.create({ data })
  return newUser
}

リファレンス

use serverの詳細については、Reactドキュメントを参照してください。