SSM框架JSP登陆页面验证码实现

曾经终败给现在 2022-05-26 06:17 287阅读 0赞
  1. 一、前台:
  2. 1.这里是jsp页面的标签:
  3. <script src="../styles/js/jquery-3.2.1.min.js" type="text/javascript"></script>
  4. <link href="../styles/css/doctorlogin.css" rel="stylesheet" />
  5. <link rel='stylesheet' href='../styles/bootstrap/css/bootstrap.min.css'>
  6. 2.下面是script,直接拿过来用就行,注意往后台跳转的地址要改成自己的,用我的也可以.
  7. function reload(){
  8. document.getElementById("image").src="<%=request.getContextPath() %>/picCheck/imageServlet?date="+new Date().getTime();
  9. $("#checkcode").val(""); // 将验证码清空
  10. }
  11. function verificationcode(){
  12. var text=$.trim($("#checkcode").val());
  13. var sp=$('#span').val();
  14. $.post("${pageContext.request.contextPath}/Verification/verificationServlet",{op:text},function(data){
  15. data=parseInt($.trim(data));
  16. if(data>0){
  17. $("#span").text("验证成功!").css("color","green");
  18. }else{
  19. /* $("#span").text("验证失败!").css("color","red"); */
  20. alert(text);
  21. if(text==""){
  22. $("#span").text("验证为空,请君重新输入!").css("color","red");
  23. }else{
  24. $("#span").text("验证码错误").css("color","red");
  25. }
  26. reload(); //验证失败后需要更换验证码
  27. }
  28. });
  29. $("#checkcode").val(""); // 将验证码清空
  30. }
  31. 3.这里是 body 体部分(标签里面的class都是我的设计的静态css样式,不想设计的可以忽略)
  32. <div class="home">
  33. <div class="home_login">
  34. <h4 class="title"><strong>爱你么么哒医院管理系统๑乛◡乛๑</strong></h3>
  35. <input type="text" name="checkcode" id="checkcode" class="home_login_button3" placeholder="请输入验证码"/><br />
  36. <div>
  37. <img src="<%=request.getContextPath() %>/picCheck/imageServlet" alt="验证码" id="image" class="home_login_check_code"/>
  38. <a href="javascript:reload();" class="home_login_button3_font"><label>换一张</label></a><br>
  39. <span id="span"> </span>
  40. </div>
  41. <button type="button" class="home_login_button1" οnclick="javascript:verificationcode()" >提交</button>
  42. </div>
  43. </div>
  44. 二、下面是后台部分(后台(controller层)一共有两部分,一个是编写验证码的controller,一个是判断验证码是否正确的controller)
  45. 1.判断验证码是否正确的controller层(拿来直接用就行)
  46. /**
  47. *
  48. */
  49. package mvct.Controller;
  50. import java.io.IOException;
  51. import java.io.PrintWriter;
  52. import javax.servlet.ServletException;
  53. import javax.servlet.http.HttpServlet;
  54. import javax.servlet.http.HttpServletRequest;
  55. import javax.servlet.http.HttpServletResponse;
  56. import javax.servlet.http.HttpSession;
  57. import org.springframework.stereotype.Controller;
  58. import org.springframework.web.bind.annotation.RequestMapping;
  59. /**
  60. * @author zhouxingxing
  61. * @package mvct.Controller
  62. * @Description TODO
  63. * @date:2018年4月25日下午4:09:22
  64. */
  65. @Controller
  66. @RequestMapping("Verification")
  67. public class PicCodeVerificationServletController extends HttpServlet {
  68. /**
  69. *
  70. */
  71. private static final long serialVersionUID = 1L;
  72. @RequestMapping("/verificationServlet")
  73. protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  74. response.setCharacterEncoding("utf-8");
  75. response.setContentType("text/html;charset=utf-8");
  76. HttpSession session =request.getSession();
  77. String verificationCode = (String)session.getAttribute("verificationCode");
  78. String checkcode = request.getParameter("op");
  79. PrintWriter out = response.getWriter();
  80. if(checkcode.equals(verificationCode)){
  81. out.println(1);
  82. }else{
  83. out.println(0);
  84. }
  85. out.flush();
  86. out.close();
  87. }
  88. }
  89. 2.编写验证码的controller(直接拿过来用即可)
  90. /**
  91. *
  92. */
  93. package mvct.Controller;
  94. import java.awt.Color;
  95. import java.awt.Font;
  96. import java.awt.Graphics;
  97. import java.awt.image.BufferedImage;
  98. import java.io.IOException;
  99. import java.util.Random;
  100. import javax.imageio.ImageIO;
  101. import javax.servlet.ServletException;
  102. import javax.servlet.http.HttpServlet;
  103. import javax.servlet.http.HttpServletRequest;
  104. import javax.servlet.http.HttpServletResponse;
  105. import javax.servlet.http.HttpSession;
  106. import org.springframework.stereotype.Controller;
  107. import org.springframework.web.bind.annotation.RequestMapping;
  108. import org.springframework.web.bind.annotation.ResponseBody;
  109. /**
  110. * @author zhouxingxing
  111. * @package mvct.Controller
  112. * @Description TODO
  113. * @date:2018年4月25日下午4:00:23
  114. */
  115. @Controller
  116. @RequestMapping("/picCheck")
  117. public class PicCheckController extends HttpServlet {
  118. /**
  119. *
  120. */
  121. private static final long serialVersionUID = 1L;
  122. @ResponseBody
  123. @RequestMapping("/imageServlet")
  124. protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  125. request.setCharacterEncoding("utf-8");
  126. BufferedImage bfi = new BufferedImage(80,25,BufferedImage.TYPE_INT_RGB);
  127. Graphics g = bfi.getGraphics();
  128. g.fillRect(0, 0, 80, 25);
  129. //验证码字符范围
  130. char[] ch = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".toCharArray();
  131. Random r = new Random();
  132. int index;
  133. StringBuffer sb = new StringBuffer(); //保存字符串
  134. for(int i=0; i<4; i++){
  135. index = r.nextInt(ch.length);
  136. g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255)));
  137. Font font = new Font("宋体", 30, 20);
  138. g.setFont(font);
  139. g.drawString(ch[index]+"", (i*20)+2, 23);
  140. sb.append(ch[index]);
  141. }
  142. // 添加噪点
  143. int area = (int) (0.02 * 80 * 25);
  144. for(int i=0; i<area; ++i){
  145. int x = (int)(Math.random() * 80);
  146. int y = (int)(Math.random() * 25);
  147. bfi.setRGB(x, y, (int)(Math.random() * 255));
  148. }
  149. //设置验证码中的干扰线
  150. for (int i = 0; i < 6; i++) {
  151. //随机获取干扰线的起点和终点
  152. int xstart = (int)(Math.random() * 80);
  153. int ystart = (int)(Math.random() * 25);
  154. int xend = (int)(Math.random() * 80);
  155. int yend = (int)(Math.random() * 25);
  156. g.setColor(interLine(1, 255));
  157. g.drawLine(xstart, ystart, xend, yend);
  158. }
  159. HttpSession session = request.getSession(); //保存到session
  160. session.setAttribute("verificationCode", sb.toString());
  161. ImageIO.write(bfi, "JPG", response.getOutputStream()); //写到输出流
  162. }
  163. /**
  164. * 获取随机的颜色值,r,g,b的取值在Low到High之间
  165. * @param L 左区间
  166. * @param R 右区间
  167. * @return 返回随机颜色值
  168. */
  169. private static Color interLine(int Low, int High){
  170. if(Low > 255)
  171. Low = 255;
  172. if(High > 255)
  173. High = 255;
  174. if(Low < 0)
  175. Low = 0;
  176. if(High < 0)
  177. High = 0;
  178. int interval = High - Low;
  179. int r = Low + (int)(Math.random() * interval);
  180. int g = Low + (int)(Math.random() * interval);
  181. int b = Low + (int)(Math.random() * interval);
  182. return new Color(r, g, b);
  183. }
  184. // ------------------------------------------------------------------
  185. }

三、下面是我的运行结果,我把用户登录的部分和验证码合到了一起(你们单独写我上面的验证码就可以直接运行,如果想写用户登录的话,将两个前台的函数合到一起就行。验证码判断的部分:如果执行验证码验证成功,调用用户登录的函数,因为必须先验证才能登陆,对吧。然后登录的button按钮就不要了,就用验证码的按钮就可以。因为用户登录已经在验证码的函数里面执行了)。

70

发表评论

表情:
评论列表 (有 0 条评论,287人围观)

还没有评论,来说两句吧...

相关阅读