"use client"; import { useState } from "react"; import { useRouter } from "next/navigation"; import { Button } from "@/components/ui/button"; import { Input } from "@/components/ui/input"; import { Label } from "@/components/ui/label"; import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card"; export default function RegisterPage() { const router = useRouter(); const [form, setForm] = useState({ username: "", email: "", password: "", confirmPassword: "", }); const [error, setError] = useState(""); async function handleSubmit(e: React.FormEvent) { e.preventDefault(); setError(""); if (form.password !== form.confirmPassword) { setError("两次输入的密码不一致"); return; } const res = await fetch("/api/proxy/auth/register", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ username: form.username, email: form.email, password: form.password, }), }); if (!res.ok) { const data = await res.json(); setError(data.error || "注册失败"); return; } router.push("/login"); } return (
注册
setForm({ ...form, username: e.target.value })} required />
setForm({ ...form, email: e.target.value })} required />
setForm({ ...form, password: e.target.value })} required />
setForm({ ...form, confirmPassword: e.target.value }) } required />
{error &&

{error}

}

已有账号?{" "} 去登录

); }