JSP color verification code

zhaozj2021-02-16  85

Generate file image.jsp for verification code images

<% @ Page ContentType = "Image / JPEG" Import = "java.awt. *,

Java.awt.Image. *, java.util. *, javax.imageio. * "%>

<%!

Color GetrandColor (int FC, int BC) {// given range by ¾ ¾ random color

Random Random = new random ();

IF (FC> 255) FC = 255;

IF (BC> 255) BC = 255;

INT R = FC Random.Nextint (BC-FC);

INT g = fc random.nextint (BC-FC);

INT b = fc random.nextint (BC-FC);

Return New Color (R, G, B);

}

%>

<%

/ / Set the page does not cache

Response.setHeader ("Pragma", "NO-Cache");

Response.setHeader ("cache-control", "no-cache");

Response.SetDateHeader ("Expires", 0);

/ / Create image in memory

INT width = 60, height = 20;

BufferedImage Image = New BufferedImage (width, height, bufferedimage.type_int_rgb);

/ / Get the graphical context

Graphics g = image.getgraphics ();

/ / Generate a random class

Random Random = new random ();

// Set the background color

G.SetColor (GetrandColor (200, 250));

g.fillRect (0, 0, Width, Height);

// Set the font

G.SetFont (New Font ("Times New Roman", Font.Plain, 18));

// Sea Box

//g.setcolor (New Color ());

//g.drawrect (0, 10 ,width-1, Height 1);

// randomly generate 155 interferent lines, so that the authentication code in the image is not easily detected by other programs

G.SetColor (GetrandColor (160,200));

For (int i = 0; i <155; i )

{

INT x = random.nextint (width);

INT Y = random.nextint (height);

INT XL = random.nextint (12);

INT YL = random.nextint (12);

g.drawline (X, Y, X XL, Y YL);

}

// Take the randomly generated authentication code (4 digits)

String SRAND = "";

For (int i = 0; i <4; i ) {

String Rand = String.Valueof (random.nextint (10));

SRAND = Rand;

// Display the authentication code to the image

G.SetColor (New Color (20 Random.Nextint (110), 20 Random.Nextint (110), 20 Random.Nextint (110))));

// The color of the call function is the same, it may be because the seed is too close, so it can only be generated directly.

g.drawstring (rand, 13 * i 6, 16);

// Deposit the authentication code into the session

Session.setttribute ("Rand", SRAND);

// Image take effect

g.dispose ();

// Output image to page

Imageio.write (Image, "JPEG", response.getOutputStream ());

%>

File A.jsp using the verification code picture

<% @ Page ContentType = "text / html; charset = GB2312"%>

Certification code input page </ title></p> <p><meta http-equiv = "content-type" content = "text / html; charSet = GB2312"></p> <p><Meta http-equiv = "pragma" Content = "no-cache"></p> <p><Meta http-equiv = "cache-control" Content = "no-cache"></p> <p><Meta http-equiv = "expires" Content = "0"></p> <p></ hEAD></p> <p><body></p> <p><form method = post action = "check.jsp"></p> <p><table></p> <p><tr></p> <p><TD Align = Left> The authentication code generated by the system: </ td></p> <p><TD> <img border = 0 src = "image.jsp"> </ td></p> <p></ TR></p> <p><tr></p> <p><TD Align = Left> Enter the above authentication code: </ td></p> <p><TD> <input type = text name = rand maxlength = 4 value = "> </ td></p> <p></ TR></p> <p><tr></p> <p><TD COLSPAN = 2 Align = Center> <input type = Submit value = "Submit Detection"> </ td></p> <p></ TR></p> <p></ form></p> <p></ body></p> <p></ html></p> <p>Verified page Check.jsp</p> <p><% @ Page ContentType = "Text / HTML; Charset = GB2312" Language = "Java" Import = "java.sql. *" ErrorPage = ""%></p> <p><html></p> <p><HEAD></p> <p><title> Certification code verification page </ title></p> <p><meta http-equiv = "content-type" content = "text / html; charSet = GB2312"></p> <p><Meta http-equiv = "pragma" Content = "no-cache"> <meta http-equiv = "cache-control" content = "no-cache"></p> <p><Meta http-equiv = "expires" Content = "0"></p> <p></ hEAD></p> <p><body></p> <p><%</p> <p>String rand = (string) session.getattribute ("rand");</p> <p>String Input = Request.getParameter ("Rand");</p> <p>%></p> <p>The authentication code generated by the system is: <% = rand%> <br></p> <p>The authentication code you entered is: <% = INPUT%> <br></p> <p><br></p> <p><%</p> <p>IF (Rand.equals (Input)) {</p> <p>%></p> <p><font color = green> The same, the authentication is successful! </ font></p> <p><%</p> <p>} else {</p> <p>%></p> <p><font color = red> Enter different, certification failed! </ font></p> <p><%</p> <p>}</p> <p>%></p> <p></ body></p> <p></ html></p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-18906.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="18906" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.040</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = 'WH18wLgrkK82WLfwxlb7Znu_2FlUS6Iv_2BuGVe4lfE_2BiQgPrpbSqT27vkagGgcDnm4fe71igI17jDDN_2BcNlLzhS1A_3D_3D'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>