{"id":2545,"date":"2022-12-13T17:06:18","date_gmt":"2022-12-13T09:06:18","guid":{"rendered":"https:\/\/qaqaq.top\/?p=2545"},"modified":"2022-12-13T17:06:18","modified_gmt":"2022-12-13T09:06:18","slug":"kaptcha%e8%b0%b7%e6%ad%8c%e9%aa%8c%e8%af%81%e7%a0%81%e5%b7%a5%e5%85%b7","status":"publish","type":"post","link":"https:\/\/qaqaq.top\/?p=2545","title":{"rendered":"kaptcha\u8c37\u6b4c\u9a8c\u8bc1\u7801\u5de5\u5177"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">Kaptcha \u7b80\u4ecb<\/h2>\n\n\n\n<p>Kaptcha \u662f\u4e00\u4e2a\u53ef\u9ad8\u5ea6\u914d\u7f6e\u7684\u5b9e\u7528\u9a8c\u8bc1\u7801\u751f\u6210\u5de5\u5177\uff0c\u53ef\u81ea\u7531\u914d\u7f6e\u7684\u9009\u9879\u5982\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>\u9a8c\u8bc1\u7801\u7684\u5b57\u4f53<\/li><li>\u9a8c\u8bc1\u7801\u5b57\u4f53\u7684\u5927\u5c0f<\/li><li>\u9a8c\u8bc1\u7801\u5b57\u4f53\u7684\u5b57\u4f53\u989c\u8272<\/li><li>\u9a8c\u8bc1\u7801\u5185\u5bb9\u7684\u8303\u56f4(\u6570\u5b57\uff0c\u5b57\u6bcd\uff0c\u4e2d\u6587\u6c49\u5b57\uff01)<\/li><li>\u9a8c\u8bc1\u7801\u56fe\u7247\u7684\u5927\u5c0f\uff0c\u8fb9\u6846\uff0c\u8fb9\u6846\u7c97\u7ec6\uff0c\u8fb9\u6846\u989c\u8272<\/li><li>\u9a8c\u8bc1\u7801\u7684\u5e72\u6270\u7ebf<\/li><li>\u9a8c\u8bc1\u7801\u7684\u6837\u5f0f(\u9c7c\u773c\u6837\u5f0f\u30013D\u3001\u666e\u901a\u6a21\u7cca\u3001&#8230;)<\/li><\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Kaptcha \u8be6\u7ec6\u914d\u7f6e\u8868<\/h2>\n\n\n\n<figure class=\"wp-block-table\"><table><tbody><tr><td>kaptcha.border<\/td><td>\u56fe\u7247\u8fb9\u6846\uff0c\u5408\u6cd5\u503c\uff1ayes , no<\/td><td>yes<\/td><\/tr><tr><td>kaptcha.border.color<\/td><td>\u8fb9\u6846\u989c\u8272\uff0c\u5408\u6cd5\u503c\uff1a r,g,b (and optional alpha) \u6216\u8005 white,black,blue.<\/td><td>black<\/td><\/tr><tr><td>kaptcha.image.width<\/td><td>\u56fe\u7247\u5bbd<\/td><td>200<\/td><\/tr><tr><td>kaptcha.image.height<\/td><td>\u56fe\u7247\u9ad8<\/td><td>50<\/td><\/tr><tr><td>kaptcha.producer.impl<\/td><td>\u56fe\u7247\u5b9e\u73b0\u7c7b<\/td><td>com.google.code.kaptcha.impl.DefaultKaptcha<\/td><\/tr><tr><td>kaptcha.textproducer.impl<\/td><td>\u6587\u672c\u5b9e\u73b0\u7c7b<\/td><td>com.google.code.kaptcha.text.impl.DefaultTextCreator<\/td><\/tr><tr><td>kaptcha.textproducer.char.string<\/td><td>\u6587\u672c\u96c6\u5408\uff0c\u9a8c\u8bc1\u7801\u503c\u4ece\u6b64\u96c6\u5408\u4e2d\u83b7\u53d6<\/td><td>abcde2345678gfynmnpwx<\/td><\/tr><tr><td>kaptcha.textproducer.char.length<\/td><td>\u9a8c\u8bc1\u7801\u957f\u5ea6<\/td><td>5<\/td><\/tr><tr><td>kaptcha.textproducer.font.names<\/td><td>\u5b57\u4f53<\/td><td>Arial, Courier<\/td><\/tr><tr><td>kaptcha.textproducer.font.size<\/td><td>\u5b57\u4f53\u5927\u5c0f<\/td><td>40px.<\/td><\/tr><tr><td>kaptcha.textproducer.font.color<\/td><td>\u5b57\u4f53\u989c\u8272\uff0c\u5408\u6cd5\u503c\uff1a r,g,b \u6216\u8005 white,black,blue.<\/td><td>black<\/td><\/tr><tr><td>kaptcha.textproducer.char.space<\/td><td>\u6587\u5b57\u95f4\u9694<\/td><td>2<\/td><\/tr><tr><td>kaptcha.noise.impl<\/td><td>\u5e72\u6270\u5b9e\u73b0\u7c7b<\/td><td>com.google.code.kaptcha.impl.DefaultNoise<\/td><\/tr><tr><td>kaptcha.noise.color<\/td><td>\u5e72\u6270 \u989c\u8272\uff0c\u5408\u6cd5\u503c\uff1a r,g,b \u6216\u8005 white,black,blue.<\/td><td>black<\/td><\/tr><tr><td>kaptcha.obscurificator.impl<\/td><td>\u56fe\u7247\u6837\u5f0f\uff1a&lt;br \/&gt;\u6c34\u7eb9 com.google.code.kaptcha.impl.WaterRipple &lt;br \/&gt;\u9c7c\u773c com.google.code.kaptcha.impl.FishEyeGimpy &lt;br \/&gt;\u9634\u5f71 com.google.code.kaptcha.impl.ShadowGimpy<\/td><td>com.google.code.kaptcha.impl.WaterRipple<\/td><\/tr><tr><td>kaptcha.background.impl<\/td><td>\u80cc\u666f\u5b9e\u73b0\u7c7b<\/td><td>com.google.code.kaptcha.impl.DefaultBackground<\/td><\/tr><tr><td>kaptcha.background.clear.from<\/td><td>\u80cc\u666f\u989c\u8272\u6e10\u53d8\uff0c\u5f00\u59cb\u989c\u8272<\/td><td>light grey<\/td><\/tr><tr><td>kaptcha.background.clear.to<\/td><td>\u80cc\u666f\u989c\u8272\u6e10\u53d8\uff0c \u7ed3\u675f\u989c\u8272<\/td><td>white<\/td><\/tr><tr><td>kaptcha.word.impl<\/td><td>\u6587\u5b57\u6e32\u67d3\u5668<\/td><td>com.google.code.kaptcha.text.impl.DefaultWordRenderer<\/td><\/tr><tr><td>kaptcha.session.key<\/td><td>session key<\/td><td>KAPTCHA_SESSION_KEY<\/td><\/tr><tr><td>kaptcha.session.date<\/td><td>session date<\/td><td>KAPTCHA_SESSION_DATE<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">\u7528\u6cd5<\/h2>\n\n\n\n<p>\u53ef\u4ee5\u53bb\u5b98\u7f51<a href=\"http:\/\/code.google.com\/p\/kaptcha\/\">http:\/\/code.google.com\/p\/kaptcha\/<\/a>\u4e0b\u8f7djar\uff0c\u6216\u8005\u5728pom.xml\u4e2d\u5bfc\u5165<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;dependency&gt;\n    &lt;groupId&gt;com.google.code.kaptcha&lt;\/groupId&gt;\n    &lt;artifactId&gt;kaptcha&lt;\/artifactId&gt;\n    &lt;version&gt;2.3&lt;\/version&gt;\n&lt;\/dependency&gt;<\/code><\/pre>\n\n\n\n<p>\u6216\u8005<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;dependency&gt;\n    &lt;groupId&gt;com.github.penggle&lt;\/groupId&gt;\n    &lt;artifactId&gt;kaptcha&lt;\/artifactId&gt;\n    &lt;version&gt;2.3.2&lt;\/version&gt;\n&lt;\/dependency&gt;<\/code><\/pre>\n\n\n\n<p>\u9879\u76ee\u5206\u5c42\u7ed3\u6784<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qaqaq.top\/wp-content\/uploads\/2022\/12\/image-235.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"292\" height=\"465\" data-original=\"https:\/\/qaqaq.top\/wp-content\/uploads\/2022\/12\/image-235.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-2546\"  sizes=\"(max-width: 292px) 100vw, 292px\" \/><\/div><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\"><strong>\u4e3b\u8981\u4ee3\u7801<\/strong><\/h2>\n\n\n\n<p>KaptchaConfig.java<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>@Component\npublic class KaptchaConfig {\n    @Bean\n    public DefaultKaptcha getDDefaultKaptcha() {\n        DefaultKaptcha dk = new DefaultKaptcha();\n        Properties properties = new Properties();\n        \/\/ \u56fe\u7247\u8fb9\u6846\n        properties.setProperty(\"kaptcha.border\", \"yes\");\n        \/\/ \u8fb9\u6846\u989c\u8272\n        properties.setProperty(\"kaptcha.border.color\", \"105,179,90\");\n        \/\/ \u5b57\u4f53\u989c\u8272\n        properties.setProperty(\"kaptcha.textproducer.font.color\", \"red\");\n        \/\/ \u56fe\u7247\u5bbd\n        properties.setProperty(\"kaptcha.image.width\", \"110\");\n        \/\/ \u56fe\u7247\u9ad8\n        properties.setProperty(\"kaptcha.image.height\", \"40\");\n        \/\/ \u5b57\u4f53\u5927\u5c0f\n        properties.setProperty(\"kaptcha.textproducer.font.size\", \"30\");\n        \/\/ session key\n        properties.setProperty(\"kaptcha.session.key\", \"code\");\n        \/\/ \u9a8c\u8bc1\u7801\u957f\u5ea6\n        properties.setProperty(\"kaptcha.textproducer.char.length\", \"4\");\n        \/\/ \u5b57\u4f53\n        properties.setProperty(\"kaptcha.textproducer.font.names\", \"\u5b8b\u4f53,\u6977\u4f53,\u5fae\u8f6f\u96c5\u9ed1\");\n        Config config = new Config(properties);\n        dk.setConfig(config);\n\n        return dk;\n    }\n}<\/code><\/pre>\n\n\n\n<p>KaptchaController.java<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>@Controller\npublic class KaptchaController {\n    \/**\n     * \u9a8c\u8bc1\u7801\u5de5\u5177\n     *\/\n    @Autowired\n    DefaultKaptcha defaultKaptcha;\n\n    @RequestMapping(\"\/defaultKaptcha\")\n    public void defaultKaptcha(HttpServletRequest request, HttpServletResponse response) throws Exception {\n        byte&#91;] captcha = null;\n        ByteArrayOutputStream out = new ByteArrayOutputStream();\n\n        try {\n            \/\/ \u5c06\u751f\u6210\u7684\u9a8c\u8bc1\u7801\u4fdd\u5b58\u5728session\u4e2d\n            String createText = defaultKaptcha.createText();\n            request.getSession().setAttribute(\"rightCode\", createText);\n            BufferedImage bi = defaultKaptcha.createImage(createText);\n            ImageIO.write(bi, \"jpg\", out);\n        } catch (Exception e) {\n            response.sendError(HttpServletResponse.SC_NOT_FOUND);\n            return;\n        }\n\n        captcha = out.toByteArray();\n        response.setHeader(\"Cache-Control\", \"no-store\");\n        response.setHeader(\"Pragma\", \"no-cache\");\n        response.setDateHeader(\"Expires\", 0);\n        response.setContentType(\"image\/jpeg\");\n        ServletOutputStream sout = response.getOutputStream();\n        sout.write(captcha);\n        sout.flush();\n        sout.close();\n    }\n\n    \/**\n     * \u6821\u5bf9\u9a8c\u8bc1\u7801\n     * \n     * @param request\n     * @param response\n     * @return\n     *\/\n    @RequestMapping(value = \"\/login\", method = RequestMethod.POST)\n    public ModelAndView imgvrifyControllerDefaultKaptcha(HttpServletRequest request, HttpServletResponse response) {\n        ModelAndView model = new ModelAndView();\n        String rightCode = (String) request.getSession().getAttribute(\"rightCode\");\n        String tryCode = request.getParameter(\"tryCode\");\n        System.out.println(\"rightCode:\" + rightCode + \" \u2014\u2014\u2014\u2014 tryCode:\" + tryCode);\n        if (!rightCode.equals(tryCode)) {\n            model.addObject(\"info\", \"\u9a8c\u8bc1\u7801\u9519\u8bef,\u8bf7\u518d\u8f93\u4e00\u6b21!\");\n            model.setViewName(\"login\");\n        } else {\n            model.addObject(\"info\", \"\u767b\u9646\u6210\u529f\");\n            model.setViewName(\"index\");\n        }\n        return model;\n    }\n\n    \/**\n     * \u8fd4\u56de\u9996\u9875\n     * \n     * @return\n     *\/\n    @RequestMapping(value = \"\/login\", method = RequestMethod.GET)\n    public ModelAndView index() {\n        return new ModelAndView(\"login\");\n    }\n}<\/code><\/pre>\n\n\n\n<p>\u524d\u7aef\u9875\u9762<\/p>\n\n\n\n<p>login.html<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;!DOCTYPE html&gt;\n&lt;html xmlns:th=\"http:\/\/www.thymeleaf.org\"&gt;\n&lt;head lang=\"en\"&gt;\n&lt;meta charset=\"UTF-8\"&gt;\n&lt;title&gt;Insert title here&lt;\/title&gt;\n&lt;link rel=\"stylesheet\" href=\"https:\/\/cdn.staticfile.org\/twitter-bootstrap\/3.3.7\/css\/bootstrap.min.css\"&gt;  \n&lt;script src=\"https:\/\/cdn.staticfile.org\/jquery\/2.1.1\/jquery.min.js\"&gt;&lt;\/script&gt;\n&lt;script src=\"https:\/\/cdn.staticfile.org\/twitter-bootstrap\/3.3.7\/js\/bootstrap.min.js\"&gt;&lt;\/script&gt;\n&lt;style type=\"text\/css\"&gt;\nbody {\n    padding: 10px;\n}\n#inputtext {\n    width: 100%;\n}\n#login{\n    width: 300px;\n    margin:0px auto;\n    padding-top: 60px;\n}\n#flushimg{\n    text-decoration: underline;\n}\n#butt{\n    width: 60%;\n}\n&lt;\/style&gt;\n&lt;\/head&gt;\n&lt;body&gt;\n&lt;div id=\"login\"&gt;\n    &lt;form action=\"\/login\" method=\"post\"&gt;\n        &lt;h2 align=\"center\"&gt;L O G I N&lt;\/h2&gt;&lt;br\/&gt;&lt;br\/&gt;\n        &lt;input type=\"text\" name=\"userName\" class=\"form-control\" id=\"inputtext\" required autofocus placeholder=\"-----\u8bf7\u8f93\u5165\u7528\u6237\u540d-----\"\/&gt;&lt;br\/&gt;\n        &lt;input type=\"password\" name=\"userName\" class=\"form-control\" id=\"inputtext\" required placeholder=\"----\u8bf7\u8f93\u5165\u7528\u6237\u5bc6\u7801----\"\/&gt;&lt;br\/&gt;\n        &lt;div id=\"flushimg\"&gt;\n            &lt;img alt=\"\u9a8c\u8bc1\u7801\" onclick=\"this.src='\/defaultKaptcha?d=' + new Date()*1\" src=\"\/defaultKaptcha\" \/&gt;\n            &lt;a&gt;\u770b\u4e0d\u6e05\uff1f\u70b9\u51fb\u56fe\u7247\u5237\u65b0\u4e00\u4e0b&lt;\/a&gt;\n        &lt;\/div&gt; \n            &lt;input type=\"text\" name=\"tryCode\" class=\"form-control\" required placeholder=\"-----\u8bf7\u8f93\u5165\u9a8c\u8bc1\u7801-----\" \/&gt;\n            &lt;h4 th:text=\"${info}\" style=\"color: red\"&gt;&lt;\/h4&gt;\n            &lt;input type=\"checkbox\" name=\"rememberMe\"\/&gt;\u8bb0\u4f4f\u6211&lt;br\/&gt;\n            &lt;div style=\"width: 100%;text-align: center;\"&gt;&lt;input type=\"submit\" value=\"\u767b \u5f55\" id=\"butt\" class=\"btn btn-success\" \/&gt;&lt;\/div&gt;\n    &lt;\/form&gt;\n&lt;\/div&gt;\n&lt;\/body&gt;\n&lt;\/html&gt;<\/code><\/pre>\n\n\n\n<p>index.html<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;!DOCTYPE html&gt;\n&lt;html&gt;\n&lt;head&gt;\n&lt;meta charset=\"UTF-8\"&gt;\n&lt;title&gt;Insert title here&lt;\/title&gt;\n&lt;\/head&gt;\n&lt;body&gt;\n    &lt;h2&gt;\u9a8c\u8bc1\u6210\u529f\uff01&lt;\/h2&gt;\n&lt;\/body&gt;\n&lt;\/html&gt;<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\"><strong>\u9875\u9762\u6548\u679c<\/strong><\/h2>\n\n\n\n<p><strong>\u5730\u5740\u680f\u8f93\u5165\uff1alocalhost:8080\/login<\/strong><\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/qaqaq.top\/wp-content\/uploads\/2022\/12\/image-236.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"725\" height=\"443\" data-original=\"https:\/\/qaqaq.top\/wp-content\/uploads\/2022\/12\/image-236.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-2547\"  sizes=\"(max-width: 725px) 100vw, 725px\" \/><\/div><\/figure>\n","protected":false},"excerpt":{"rendered":"<p>Kaptcha \u7b80\u4ecb Kaptcha \u662f\u4e00\u4e2a\u53ef\u9ad8\u5ea6\u914d\u7f6e\u7684\u5b9e\u7528\u9a8c\u8bc1\u7801\u751f\u6210\u5de5\u5177\uff0c\u53ef\u81ea\u7531\u914d\u7f6e\u7684\u9009\u9879\u5982\uff1a \u9a8c\u8bc1\u7801\u7684\u5b57\u4f53 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[60],"tags":[61],"class_list":["post-2545","post","type-post","status-publish","format-standard","hentry","category-javaweb-","tag-javaweb"],"_links":{"self":[{"href":"https:\/\/qaqaq.top\/index.php?rest_route=\/wp\/v2\/posts\/2545"}],"collection":[{"href":"https:\/\/qaqaq.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/qaqaq.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/qaqaq.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/qaqaq.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2545"}],"version-history":[{"count":1,"href":"https:\/\/qaqaq.top\/index.php?rest_route=\/wp\/v2\/posts\/2545\/revisions"}],"predecessor-version":[{"id":2548,"href":"https:\/\/qaqaq.top\/index.php?rest_route=\/wp\/v2\/posts\/2545\/revisions\/2548"}],"wp:attachment":[{"href":"https:\/\/qaqaq.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2545"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/qaqaq.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2545"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/qaqaq.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2545"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}