javaweb利用servlet實現圖片驗證碼
驗證碼是登錄驗證的技術,可以一定程度防止惡意腳本刷網站,造成服務器壓力。
具體實現思想很簡單:
首先利用servlet產生一個隨機的驗證碼,
保存在session中,
然后將它畫作圖片,輸出到瀏覽器
在登錄時對輸入的驗證碼判斷即可。
**注意事項:
1.由于struts2會過濾所有action,
在對servlet配置時,不能配置為與action類似的名稱,需要為name.ssss;ssss可以是其他,不能是action.
2.對驗證碼圖片的點擊刷新,由于直接使用onclick事件對圖片的src刷新,是行不通的,
因為瀏覽器會認為即使你刷新,他也只是將已經生成的圖片再一次發送給你,看起來驗證碼是沒有變得。
那么你就需要一個變化的參數跟著src后即可,例如隨機數(不好,隨后體驗,在訪問量一定程度后就無法了,因為重疊程度大,不一定會刷新),時間戳等,就好了
**
代碼:
參生驗證碼圖片的servlet
步驟
// 圖片格式
// 設置瀏覽器不要緩存此圖片
// 創建內存圖像并獲得圖形上下文(BufferedImage)
// 畫圖片
//輸出圖片
{ServletOutputStream sos = resp.getOutputStream();
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ImageIO.write(image, “JPEG”, baos);
byte[] buffer = baos.toByteArray();
resp.setContentLength(buffer.length);
sos.write(buffer);
baos.close();
sos.close();}
package servlet.checkcode;import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;@WebServlet(name = "code", value = "/code.servlet")public class Code extends HttpServlet {/*** @author joker 驗證碼servlet*/private static final long serialVersionUID = -1139461793398415115L;@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {// TODO 自動生成的方法存根this.doPost(req, resp);}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {// TODO 自動生成的方法存根HttpSession session=req.getSession(true);resp.setContentType("image/jpeg");// 圖片格式// 設置瀏覽器不要緩存此圖片resp.setHeader("Pragma", "No-cache");resp.setHeader("Cache-Control", "no-cache");resp.setDateHeader("Expires", 0);// 創建內存圖像并獲得圖形上下文int width = 85;int height = 30;BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);Graphics graphics = image.getGraphics();// 驗證碼String table = "0123456789QWERTYUIOPASDFGHJKLZXCVBNMzxcvbnmasdfghjklqwertyuiop";char code[] = new char[4];for (int i = 0; i < 4; i++) {int rand = (int) (Math.random() * (table.length() - 1));code[i] = table.charAt(rand);}// 畫背景graphics.setColor(Color.getHSBColor(211, 211, 211));graphics.fillRect(0, 0, width, height);graphics.setColor(Color.BLACK);graphics.setFont(new Font("", 1, 20));graphics.drawLine(0, 17, width, 23);if (code[0] <= 69) {graphics.setColor(Color.BLUE);graphics.drawLine(0, 8, width, 28);} else if (code[2] >= 90) {graphics.setColor(Color.RED);graphics.drawLine(0, 28, width, 15);}else if (code[3] >= 111) {graphics.setColor(Color.black);graphics.drawLine(0, 28, width, 15);}// 畫驗證碼graphics.drawString("" + code[0], 2, 20);graphics.setColor(Color.YELLOW);graphics.drawString(" " + code[1], 20, 23);graphics.setColor(Color.RED);graphics.drawString(" " + code[2], 40, 20);graphics.setColor(Color.BLACK);graphics.drawString(" " + code[3], 60, 25);// 將圖像傳到客戶端ServletOutputStream sos = resp.getOutputStream();ByteArrayOutputStream baos = new ByteArrayOutputStream();ImageIO.write(image, "JPEG", baos);byte[] buffer = baos.toByteArray();resp.setContentLength(buffer.length);sos.write(buffer);baos.close();sos.close();// 驗證session.setAttribute("truecode", ""+code[0]+code[1]+code[2]+code[3]);}@Overridepublic void service(ServletRequest arg0, ServletResponse arg1) throws ServletException, IOException {// TODO 自動生成的方法存根super.service(arg0, arg1);}
}
前端:
<s:textfield name=“code” title=“請輸入驗證碼”></s:textfield>
登錄驗證的action:
package controller.login;import org.apache.struts2.ServletActionContext;import com.opensymphony.xwork2.ActionSupport;import model.linkdbm.JDBC_DBM;public class Login_db extends ActionSupport {/*** @author joker* * action* 驗證登錄*/private static final long serialVersionUID = 6346619400337792820L;public String user;public String pass;public String code;//驗證碼public String getCode() {return code;}public void setCode(String code) {this.code = code;}public String getUser() {return user;}public void setUser(String user) {this.user = user;}public String getPass() {return pass;}public void setPass(String pass) {this.pass = pass;}public String execute() throws Exception {String truecode=(String) ServletActionContext.getRequest().getSession().getAttribute("truecode");//登錄驗證碼驗證if(!code.equals(truecode)) {this.addFieldError("user", "輸入的驗證碼有誤!!!");return INPUT;}boolean oginflag=true;if (loginflag) {this.addFieldError("user", "登錄成功");return SUCCESS;} else {this.addFieldError("user", "賬號或密碼錯誤!!!");return INPUT;}}@Overridepublic void validate() {// TODO 自動生成的方法存根if (user == null || user.trim().equals("")) {this.addFieldError("user", "用戶名不能為空");return;}if (pass == null || pass.trim().equals("")) {this.addFieldError("pass", "密碼不能為空");}}}
總結
以上是生活随笔為你收集整理的javaweb利用servlet与struts2实现可点击刷新的基础图片验证码的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。