API测试平台的全链路压测建设路线图漏洞响应枢纽日志审计落地全景迷你轰炸台鸿盛云防手册邮箱: 密码: 确认密码: 注册 ``` ```j多媒体ascript // 获取元素 const form = document.getElementById("registration-form"); const submitBtn = document.getElementById("submit-btn"); // 添加提交事件监听器 form.addEventListener("submit", async (e) => { e.preventDefault(); // 验证表单 if (!validateForm()) return; // 禁止按钮并显示加载状态 submitBtn.disabled = true; submitBtn.innerHTML = "Loading..."; // 获取表单数据 const formData = new FormData(form); const data = Object.fromEntries(formData); try { // 发送注册请求 const response = await fetch("/register", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(data), }); const result = await response.json(); // 处理响应 if (result.success) { // 注册成功 alert("注册成功!"); // 重定向到登录页面 window.location.href = "/login"; } else { // 注册失败 alert(result.error); } } catch (error) { // 处理错误 alert("注册失败!请重试。"); console.error(error); } finally { // 启用按钮并还原按钮文本 submitBtn.disabled = false; submitBtn.innerHTML = "注册"; } }); // 表单验证函数 function validateForm() { // 获取表单数据 const formData = new FormData(form); const data = Object.fromEntries(formData); // 验证用户名 if (!data.username || data.username.length alert("用户名长度必须大于5!"); return false; } // 验证邮箱 if (!data.email || !validateEmail(data.email)) { alert("请输入有效的邮箱!"); return false; } // 验证密码 if (!data.password || data.password.length alert("密码长度必须大于8!"); return false; } // 验证确认密码 if (data.password !== data.confirm_password) { alert("两次输入的密码不一致!"); return false; } return true; } // 邮箱验证函数 function validateEmail(email) { const re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+))|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; return re.test(email); } ``` 服务器端代码(Node.js) ```j多媒体ascript const express = require("express"); const bcrypt = require("bcrypt"); const app = express(); app.use(express.json()); // 注册路由 app.post("/register", async (req, res) => { const { username, email, password } = req.body; // 验证输入 if (!username || !email || !password) { return res.status(400).json({ error: "Missing required fields" }); } // 检查用户是否存在 const existingUser = await User.findOne({ username }); if (existingUser) { return res.status(400).json({ error: "Username already exists" }); } // 哈希密码 const hashedPassword = await bcrypt.hash(password, 10); // 创建新用户 const user = new User({ username, email, password: hashedPassword, }); try { await user.s多媒体e(); res.status(201).json({ success: true }); } catch (error) { console.error(error); res.status(500).json({ error: "Error creating user" }); } }); ```