在Java中嵌入驗證碼到Web頁面通常需要使用前端技術和后端技術配合完成。以下是一種常見的實現方式:
@RequestMapping("/captcha")
public void generateCaptcha(HttpServletRequest request, HttpServletResponse response) {
// 生成驗證碼文本和圖片
String text = CaptchaUtil.generateText();
BufferedImage image = CaptchaUtil.generateImage(text);
// 將驗證碼文本保存在Session中
request.getSession().setAttribute("captcha", text);
// 將驗證碼圖片輸出到前端
response.setContentType("image/jpeg");
ServletOutputStream out = response.getOutputStream();
ImageIO.write(image, "JPEG", out);
out.close();
}
<!DOCTYPE html>
<html>
<head>
<title>Captcha Example</title>
</head>
<body>
<h1>Enter the Captcha:</h1>
<img src="/captcha" alt="Captcha Image">
<input type="text" name="captchaInput">
<button onclick="submitForm()">Submit</button>
</body>
</html>
@RequestMapping("/submit")
public String submitForm(HttpServletRequest request) {
// 獲取用戶填寫的驗證碼
String captchaInput = request.getParameter("captchaInput");
// 獲取Session中保存的驗證碼
String captcha = (String) request.getSession().getAttribute("captcha");
// 驗證驗證碼是否正確
if (captchaInput.equals(captcha)) {
// 驗證通過
return "success";
} else {
// 驗證失敗
return "error";
}
}
以上就是在Java中嵌入驗證碼到Web頁面的簡單實現方法。您也可以根據具體需求和技術選擇適合的驗證碼生成庫和前端框架來完成驗證碼功能的集成。