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.tsにfetchUsersサーバー関数があると仮定します
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/posts/[id]/page.tsx
import { EditPost } from './edit-post'
import { revalidatePath } from 'next/cache'
export default async function PostPage({ params }: { params: { id: string } }) {
const post = await getPost(params.id)
async function updatePost(formData: FormData) {
'use server'
await savePost(params.id, formData)
revalidatePath(`/posts/${params.id}`)
}
return <EditPost updatePostAction={updatePost} post={post} />
}セキュリティに関する考慮事項
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ドキュメントを参照してください。
役に立ちましたか?