From 861e92cc1db16b6dd180a1bb832f354bbe40fc79 Mon Sep 17 00:00:00 2001
From: 吴学文 <wuxuewen@wuxuewendeMacBook-Pro.local>
Date: 星期四, 21 三月 2019 01:13:58 +0800
Subject: [PATCH] 处理完成侦听测试

---
 WebService/src/main/java/com/java110/web/smo/impl/LoginServiceSMOImpl.java |   57 ++++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 38 insertions(+), 19 deletions(-)

diff --git a/WebService/src/main/java/com/java110/web/smo/impl/LoginServiceSMOImpl.java b/WebService/src/main/java/com/java110/web/smo/impl/LoginServiceSMOImpl.java
index 07ad536..439f4c4 100644
--- a/WebService/src/main/java/com/java110/web/smo/impl/LoginServiceSMOImpl.java
+++ b/WebService/src/main/java/com/java110/web/smo/impl/LoginServiceSMOImpl.java
@@ -1,12 +1,14 @@
 package com.java110.web.smo.impl;
 
 import com.alibaba.fastjson.JSONObject;
+import com.java110.common.cache.CommonCache;
 import com.java110.common.constant.CommonConstant;
 import com.java110.common.constant.ServiceConstant;
 import com.java110.common.util.Assert;
 import com.java110.core.base.smo.BaseServiceSMO;
 import com.java110.core.context.IPageData;
 import com.java110.core.factory.AuthenticationFactory;
+import com.java110.core.factory.ValidateCodeFactory;
 import com.java110.web.smo.ILoginServiceSMO;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
@@ -66,29 +68,46 @@
      */
     @Override
     public ResponseEntity<String> generateValidateCode(IPageData pd) {
+        int w = 200, h = 80;
+        String verifyCode = ValidateCodeFactory.generateVerifyCode(4);
+        ResponseEntity<String> verifyCodeImage = null;
+        try {
+            verifyCodeImage = new ResponseEntity<>(ValidateCodeFactory.outputImage(200, 80, verifyCode), HttpStatus.OK);
 
+            //灏嗛獙璇佺爜瀛樺叆Redis涓�
+            CommonCache.setValue(pd.getSessionId()+"_validateCode",verifyCode,CommonCache.defaultExpireTime);
 
-
-        BufferedImage image = new BufferedImage(IMG_WIDTH, IMG_HEIGHT, BufferedImage.TYPE_INT_RGB);    // 瀹炰緥鍖朆ufferedImage
-                    Graphics g = image.getGraphics();
-                    Color c = new Color(200, 200, 255);                                             // 楠岃瘉鐮佸浘鐗囩殑鑳屾櫙棰滆壊
-                    g.setColor(c);
-                    g.fillRect(0, 0, IMG_WIDTH, IMG_HEIGHT);                                        // 鍥剧墖鐨勮竟妗�
-
-                    StringBuffer sb = new StringBuffer();                                           // 鐢ㄤ簬淇濆瓨楠岃瘉鐮佸瓧绗︿覆
-                    int index;                                                                      // 鏁扮粍鐨勪笅鏍�
-                    for (int i = 0; i < NUMBER_OF_CHS; i++) {
-                            index = r.nextInt(chs.length);                                              // 闅忔満涓�涓笅鏍�
-                            g.setColor(new Color(r.nextInt(88), r.nextInt(210), r.nextInt(150)));       // 闅忔満涓�涓鑹�
-                            g.drawString(chs[index] + "", 15 * i + 3, 18);                              // 鐢诲嚭瀛楃
-                            sb.append(chs[index]);                                                      // 楠岃瘉鐮佸瓧绗︿覆
-                        }
-
-                    /*request.getSession().setAttribute("piccode", sb.toString());                    // 灏嗛獙璇佺爜瀛楃涓蹭繚瀛樺埌session涓�
-                    ImageIO.write(image, "jpg", response.getOutputStream());*/
-        return null;
+        }catch (Exception e){
+            logger.error("鐢熸垚楠岃瘉鐮佸け璐ワ紝",e);
+            verifyCodeImage = new ResponseEntity<>("", HttpStatus.INTERNAL_SERVER_ERROR);
+        }
+        return verifyCodeImage;
     }
 
+    /**
+     * 鏍¢獙楠岃瘉鐮�
+     * @param pd 椤甸潰璇锋眰瀵硅薄
+     * @return
+     */
+    public ResponseEntity<String> validate(IPageData pd){
+
+        logger.debug("鏍¢獙楠岃瘉鐮佸弬鏁�:{}",pd.toString());
+        ResponseEntity<String> verifyResult = null;
+        Assert.jsonObjectHaveKey(pd.getReqData(),"code","璇锋眰鎶ユ枃涓湭鍖呭惈 code鑺傜偣"+pd.toString());
+
+        String code = CommonCache.getValue(pd.getSessionId()+"_validateCode");
+
+        if(JSONObject.parseObject(pd.getReqData()).getString("code").equals(code)){
+            verifyResult = new ResponseEntity<>("鎴愬姛", HttpStatus.OK);
+        }else{
+            verifyResult = new ResponseEntity<>("楠岃瘉鐮侀敊璇�", HttpStatus.INTERNAL_SERVER_ERROR);
+        }
+
+
+        return verifyResult;
+    }
+
+
     public RestTemplate getRestTemplate() {
         return restTemplate;
     }

--
Gitblit v1.8.0