当前位置: 首页 > news >正文

那个相亲网站做的比较好平台推广策划案

那个相亲网站做的比较好,平台推广策划案,论坛源码,微信网站开发流程目录 前言 一、Hutool工具介绍 1.1 Maven 1.2 介绍 1.3 实现类 二、验证码案例 2.1 需求 2.2 约定前后端交互接口 2.2.1 需求分析 2.2.2 接口定义 2.3 后端生成验证码 2.4 前端接收验证码图片 2.5 后端校验验证码 2.6 前端校验验证码 2.7 后端完整代码 前言…目录 前言 一、Hutool工具介绍 1.1 Maven  1.2 介绍 1.3 实现类  二、验证码案例 2.1 需求 2.2 约定前后端交互接口 2.2.1 需求分析 2.2.2 接口定义 2.3 后端生成验证码 2.4 前端接收验证码图片 2.5 后端校验验证码 2.6  前端校验验证码 2.7 后端完整代码  前言 验证码实现方式很多可以前端实现也可以后端实现网上也有比较多的插件或者工具包可以使用咱们选择使用Hutool提供的小工具来实现。 一、Hutool工具介绍 Hutool是一个Java工具包类库对文件、流、加密解密、转码、正则、线程、XML等JDK方法进行封装组成各种Util工具类。Hutool官网https://hutool.cn/ 1.1 Maven  如果你想在项目中使用Hutool中的某个模块在项目的pom.xml的dependencies中加入以下内容 dependencygroupIdcn.hutool/groupIdartifactIdhutool-captcha/artifactIdversion5.8.22/version /dependency1.2 介绍 验证码功能位于cn.hutool.captcha包中核心接口为ICaptcha此接口定义了以下方法 createCode 创建验证码实现类需同时生成随机验证码字符串和验证码图片getCode 获取验证码的文字内容verify 验证验证码是否正确建议忽略大小写write 将验证码图片写出到目标流中 其中write方法只有一个OutputStreamICaptcha实现类可以根据这个方法封装写出到文件等方法。 AbstractCaptcha为一个ICaptcha抽象实现类此类实现了验证码文本生成、非大小写敏感的验证、写出到流和文件等方法通过继承此抽象类只需实现createImage方法定义图形生成规则即可。  1.3 实现类  LineCaptcha线段干扰的验证码 贴栗子 import cn.hutool.captcha.CaptchaUtil; import cn.hutool.captcha.LineCaptcha; import cn.hutool.core.lang.Console;public class LineCaptchaTest {public static void main(String[] args) {//定义图形验证码的长和宽LineCaptcha lineCaptcha CaptchaUtil.createLineCaptcha(200, 100);//图形验证码写出可以写出到文件也可以写出到流lineCaptcha.write(d:/line.png);//输出codeConsole.log(lineCaptcha.getCode());//验证图形验证码的有效性返回boolean值lineCaptcha.verify(1234);//重新生成验证码lineCaptcha.createCode();lineCaptcha.write(d:/line.png);//新的验证码Console.log(lineCaptcha.getCode());//验证图形验证码的有效性返回boolean值lineCaptcha.verify(1234);} } 控制台截图生成的验证码 在写入的路径中查看代码生成的验证码截图 CircleCaptcha 圆圈干扰验证码  import cn.hutool.captcha.CaptchaUtil; import cn.hutool.captcha.CircleCaptcha; import cn.hutool.core.lang.Console;public class CircleCaptchaTest {public static void main(String[] args) {//定义图形验证码的长、宽、验证码字符数、干扰元素个数CircleCaptcha captcha CaptchaUtil.createCircleCaptcha(200, 100, 4, 20);//CircleCaptcha captcha new CircleCaptcha(200, 100, 4, 20);//图形验证码写出可以写出到文件也可以写出到流captcha.write(d:/circle.png);//输出codeConsole.log(captcha.getCode());//验证图形验证码的有效性返回boolean值captcha.verify(1234);} } 控制台截图生成的验证码 在写入的路径中查看代码生成的验证码截图 ShearCaptcha 扭曲干扰验证码  import cn.hutool.captcha.CaptchaUtil; import cn.hutool.captcha.ShearCaptcha; import cn.hutool.core.lang.Console;public class ShearCaptchaTest {public static void main(String[] args) {//定义图形验证码的长、宽、验证码字符数、干扰线宽度ShearCaptcha captcha CaptchaUtil.createShearCaptcha(200, 100, 4, 4);//ShearCaptcha captcha new ShearCaptcha(200, 100, 4, 4);//图形验证码写出可以写出到文件也可以写出到流captcha.write(d:/shear.png);//输出codeConsole.log(captcha.getCode());//验证图形验证码的有效性返回boolean值captcha.verify(1234);} } 控制台截图生成的验证码 在写入的路径中查看代码生成的验证码截图 二、验证码案例 2.1 需求 需求如下 页面生成验证码输入验证码点击提交验证用户输入验证码是否正确正确则进行页面跳转 2.2 约定前后端交互接口 2.2.1 需求分析 后端需要提供两个服务 生成验证码并返回验证码校验验证码是否正确 2.2.2 接口定义 1、生成验证码 url:/captcha/get param:无 return图片的内容 2、校验验证码 url:/captcha/check param:inputCode return:true/false 2.3 后端生成验证码 import cn.hutool.captcha.CaptchaUtil; import cn.hutool.captcha.LineCaptcha; import jakarta.servlet.http.HttpServletResponse; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import java.io.IOException;RestController RequestMapping(/captcha) public class CaptchaController {RequestMapping(/get)public void getCaptcha(HttpServletResponse response) {//定义图形验证码的长和宽LineCaptcha lineCaptcha CaptchaUtil.createLineCaptcha(200, 100);//图像验证码写出可以写出到文件也可以写出到流此处写出到流try {lineCaptcha.write(response.getOutputStream());} catch (IOException e) {throw new RuntimeException(e);}} } 小技巧在我们每写完一个后端代码模块时我们可以进行测试看是否有错误避免后续代码量过多发生错误时不知道哪块出错。 根据后端定义的url进行测试截图 2.4 前端接收验证码图片 !DOCTYPE html html langenheadmeta charsetutf-8title验证码/titlestyle#inputCaptcha {height: 30px;vertical-align: middle; }#verificationCodeImg{vertical-align: middle; }#checkCaptcha{height: 40px;width: 100px;}/style /headbodyh1输入验证码/h1div idconfirminput typetext nameinputCaptcha idinputCaptchaimg idverificationCodeImg src/captcha/get stylecursor: pointer; title看不清换一张 /input typebutton value提交 idcheckCaptcha/divscript srchttps://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js/scriptscript$(#verificationCodeImg).click(function(){$(this).hide().attr(src, /captcha/get?dt new Date().getTime()).fadeIn();});$(#checkCaptcha).click(function () {alert(验证码校验);});/script /body/html 验证前端是否有问题 2.5 后端校验验证码 import cn.hutool.captcha.CaptchaUtil; import cn.hutool.captcha.LineCaptcha; import com.example.demo.model.CaptchaProperties; import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpSession; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import java.io.IOException; import java.util.Date;RestController RequestMapping(/captcha) public class CaptchaController {private final static long session_valid_timeout 60 * 1000;Autowiredprivate CaptchaProperties captchaProperties;RequestMapping(/check)public Boolean check(HttpSession session, String inputCode) {//验证码输入的内容和用户输入的进行比较//从session获取信息if (!StringUtils.hasLength(inputCode)) {return false;}String savedCode (String) session.getAttribute(captchaProperties.getSession().getKey());Date saveDate (Date) session.getAttribute(captchaProperties.getSession().getDate());if (inputCode.equalsIgnoreCase(savedCode)) {//判断验证码是否过期if (saveDate ! null System.currentTimeMillis() - saveDate.getTime() session_valid_timeout) {return true;}return true;}return false;} } 检查校验验证码是否存在问题 1、先查看后端生成的验证码 2、根据校验验证的url进行验证 首先先输入错误的验证码观察返回ture或者false如果返回false证明验证码输入错误或者过期否则反正true。 先输入错误的验证码1234截图 再输入正确的验证码截图 2.6  前端校验验证码 !DOCTYPE html html langenheadmeta charsetutf-8title验证码/titlestyle#inputCaptcha {height: 30px;vertical-align: middle; }#verificationCodeImg{vertical-align: middle; }#checkCaptcha{height: 40px;width: 100px;}/style /headbodyh1输入验证码/h1div idconfirminput typetext nameinputCaptcha idinputCaptchaimg idverificationCodeImg src/captcha/get stylecursor: pointer; title看不清换一张 /input typebutton value提交 idcheckCaptcha/divscript srchttps://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js/scriptscript$(#verificationCodeImg).click(function(){$(this).hide().attr(src, /captcha/get?dt new Date().getTime()).fadeIn();});$(#checkCaptcha).click(function () {$.ajax({url: /captcha/check,type: post,data: {inputCode: $(#inputCaptcha).val()},success: function(result) {if (result) {location.href success.html;} else {alert(验证码错误或者过期);}}})});/script /body/html !DOCTYPE html html langen headmeta charsetUTF-8meta nameviewport contentwidthdevice-width, initial-scale1.0title验证成功页/title /head bodyh1验证成功/h1 /body /html 运行截图 2.7 后端完整代码  package com.example.demo.controller;import cn.hutool.captcha.CaptchaUtil; import cn.hutool.captcha.LineCaptcha; import com.example.demo.model.CaptchaProperties; import jakarta.servlet.http.HttpServletResponse; import jakarta.servlet.http.HttpSession; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import java.io.IOException; import java.util.Date;RestController RequestMapping(/captcha) public class CaptchaController {private final static long session_valid_timeout 60 * 1000;Autowiredprivate CaptchaProperties captchaProperties;RequestMapping(/get)public void getCaptcha(HttpSession session, HttpServletResponse response) {//定义图形验证码的长和宽LineCaptcha lineCaptcha CaptchaUtil.createLineCaptcha(captchaProperties.getWidth(), captchaProperties.getHeight());//设置缓存类型response.setContentType(image/jpeg);//禁止缓存response.setHeader(Progma, No-cache);//图像验证码写出可以写出到文件也可以写出到流此处写出到流try {lineCaptcha.write(response.getOutputStream());//存储sessionsession.setAttribute(captchaProperties.getSession().getKey(), lineCaptcha.getCode());session.setAttribute(captchaProperties.getSession().getDate(), new Date());} catch (IOException e) {throw new RuntimeException(e);}}RequestMapping(/check)public Boolean check(HttpSession session, String inputCode) {//验证码输入的内容和用户输入的进行比较//从session获取信息if (!StringUtils.hasLength(inputCode)) {return false;}String savedCode (String) session.getAttribute(captchaProperties.getSession().getKey());Date saveDate (Date) session.getAttribute(captchaProperties.getSession().getDate());if (inputCode.equalsIgnoreCase(savedCode)) {//判断验证码是否过期if (saveDate ! null System.currentTimeMillis() - saveDate.getTime() session_valid_timeout) {return true;}}return false;} }配置文件: captcha:width: 200height: 100session:key: captcha_session_keydate: captcha_session_date captcha配置 import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component;Component ConfigurationProperties(prefix captcha) Data public class CaptchaProperties {private Integer width;private Integer height;private Session session;Datapublic static class Session {private String key;private String date;} }
http://www.dnsts.com.cn/news/94102.html

相关文章:

  • 免费网站建站百度云网站如何paypal支付方式
  • 常平哪里有招计算机网站开发的wordpress电影主题博客
  • 个人网站怎么建设步骤怎么做网站不用备案
  • 可信网站图标 费流量广东平台网站建设哪家好
  • 德州市建设街小学网站首页深圳定制纸箱
  • 网站首页背景图片网站建立价格
  • 甘肃省建设银行网站网页游戏开服表怎么关闭
  • 网站 建设 计划书外贸网站搭建公司
  • 广东网站备案时间360建筑网证书
  • 苏州吴江做网站公司中国室内设计公司排名前十强
  • 北京网站建设价格便宜北京信息发布平台
  • 创恒建设有限公司网站公司网站建设企划书
  • 厦门唯一官方网站广告软文小故事200字
  • 德兴网站建设关键词优化排名软件
  • 网站底部的备案号动态设计参考网站
  • 南昌企业制作网站设计建什么网站做cpa
  • 免费外贸建站平台网站设计经典案例欣赏
  • 机关网站建设 方案upscale wordpress
  • 济南网站建设排名常用的html编辑器有哪些
  • 怎么建立自己的网站平台杭州手机网站制作公司哪家好
  • 昌邑建设网站华为荣耀商店
  • funpinpin建站平台网站忧化教程
  • 搜狗网站seo秦皇岛建设路小学网站
  • 做效果图挣钱的网站网站开发用户需求分析
  • 传奇广告网站怎么做免费注册域名哪里有
  • 哪个网站可以做试卷重庆专业做网站公司
  • 高大上的企业网站烟台网站建设价格
  • 如何建设自己的网站 知乎很小众却很惊艳的公众号名字
  • pc网站做app京东厦门网站建设 软件园
  • 重点建设专业 专题网站网站建设推广的10种方法