From 68bb0f6874b7562e3e13d7312c74c1469bca468f Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期五, 08 十二月 2023 15:06:55 +0800
Subject: [PATCH] 更新

---
 UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/UserInfoServiceImpl.java |  809 +++++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 643 insertions(+), 166 deletions(-)

diff --git a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/UserInfoServiceImpl.java b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/UserInfoServiceImpl.java
index 96662d0..be35644 100644
--- a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/UserInfoServiceImpl.java
+++ b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/UserInfoServiceImpl.java
@@ -21,6 +21,7 @@
 import com.stylefeng.guns.modular.system.util.GoogleMap.ReverseGeocodeVo;
 import com.stylefeng.guns.modular.system.util.Tingg.TinggPayUtil;
 import com.stylefeng.guns.modular.system.util.Tingg.model.CheckoutRequest;
+import com.stylefeng.guns.modular.system.util.itextpdf.HtmlToPdfUtils;
 import com.stylefeng.guns.modular.system.warpper.LoginWarpper;
 import com.stylefeng.guns.modular.taxi.model.PaymentRecord;
 import com.stylefeng.guns.modular.taxi.service.IPaymentRecordService;
@@ -40,6 +41,9 @@
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.FileWriter;
 import java.math.BigDecimal;
 import java.text.SimpleDateFormat;
 import java.util.*;
@@ -102,6 +106,9 @@
     @Autowired
     private PayMoneyUtil payMoneyUtil;
 
+    @Autowired
+    private IBankCardService bankCardService;
+
     @Value("${callbackPath}")
     private String callbackPath;
 
@@ -110,6 +117,12 @@
 
     private String salt = "&a.s";
 
+    @Autowired
+    private SMSUtil smsUtil;
+
+    @Autowired
+    private TEmailService emailService;
+
 
     /**
      * 获取短信验证码
@@ -117,7 +130,7 @@
      * @return
      */
     @Override
-    public ResultUtil queryCaptcha(String phone, Integer type) throws Exception {
+    public ResultUtil queryCaptcha(String phone, Integer type, Integer language) throws Exception {
         Random random = new Random();
         Object value = redisUtil.getValue(phone);
         if(value==null){
@@ -126,12 +139,22 @@
                 sb.append((int) (random.nextDouble() * 10));
             }
             String authCode = sb.toString();
-            String sms = "短信验证码【" + authCode + "】已发到您的手机,验证码将在5分钟后失效,请及时登录!";
+            String sms = "";
 
             //发送验证码短信
             redisUtil.setStrValue(phone, authCode, 5 * 60);//设置五分钟过期
-            SMSUtil.send_huawei_sms("b793ae3d41a049059197bfe92cf8bc83", "+" + phone, "[\"" + authCode + "\"]");
-            System.out.println(sms);
+            switch (language){
+                case 1:
+                    sms = "您的验证码为:" + authCode + ",该验证码5分钟内有效,请勿泄漏于他人!";
+                    break;
+                case 2:
+                    sms = "Your verification code is " + authCode + ",it is valid within 5 minutes, please do not reveal it to others.";
+                    break;
+                case 3:
+                    sms = "Votre code de validation est " + authCode + "et il est valide pendant 5 minutes. Veuillez ne pas le révéler à d’autres personnes.";
+                    break;
+            }
+            smsUtil.sendCellulantMessage(phone, sms);
         }
         return ResultUtil.success();
     }
@@ -147,6 +170,7 @@
     @Override
     public boolean checkCaptcha(String phone, String code) throws Exception {
         Object value = redisUtil.getValue(phone);
+        redisUtil.remove(phone);
         if("1246".equals(code)){
             return true;
         }
@@ -167,16 +191,17 @@
      * @return
      */
     @Override
-    public ResultUtil<LoginWarpper> captchaLogin(String phone, String code, String registIp, Double lat, Double lng,Integer uid,Integer type,
+    public ResultUtil<LoginWarpper> captchaLogin(String phoneOperator, String phone, String code, String registIp, Double lat, Double lng,Integer uid,Integer type,
                                                  Integer userType, Integer language) throws Exception {
         boolean b = this.checkCaptcha(phone, code);
         if(!b){
-            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid captcha" : "Code de vérification invalide");
+            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid CAPTCHA" : "CAPTCHA non valide");
         }
 
         UserInfo userInfo = userInfoMapper.queryByPhone(phone);
         if(null == userInfo){
             userInfo = new UserInfo();
+            userInfo.setPhoneOperator(phoneOperator);
             userInfo.setPhone(phone);
             userInfo.setPassWord(ShiroKit.md5("", salt));
             userInfo.setNickName(this.getDefaultName());
@@ -217,24 +242,67 @@
                 String path = templatePath + "user/register.html";
                 Document document = Jsoup.parse(new File(path), "UTF-8");
                 if(1 == language){
-                    document.getElementById("english").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("english").remove();
+                    document.getElementById("french").remove();
                     Element user_chinese = document.getElementById("user_chinese");
                     user_chinese.text("您好 " + userInfo.getNickName() + ",");
                 }
                 if(2 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("french").remove();
                     Element user_english = document.getElementById("user_english");
                     user_english.text("Hello " + userInfo.getNickName() + ",");
                 }
                 if(3 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("english").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("english").remove();
                     Element user_french = document.getElementById("user_french");
                     user_french.text("Bonjour " + userInfo.getNickName() + ",");
                 }
-                EmailUtil.send(userInfo.getEmail(), language == 1 ? "注册成功" : language == 2 ? "Successful registration" : "Inscription réussie",  document.html());
+                EmailUtil.send(userInfo.getEmail(), language == 1 ? "注册成功" : language == 2 ? "Registered successfully" : "Enregistré avec succès",  document.html());
+                //开始生成pdf收据和html收据
+                File file = new File("/usr/local/nginx/html/files/html/");
+                if(!file.exists()){
+                    file.mkdirs();
+                }
+                String randomString = ToolUtil.getRandomString(10);
+                file = new File("/usr/local/nginx/html/files/html/registration_" + randomString + ".html");
+                if(!file.exists()){
+                    file.createNewFile();
+                }
+                FileWriter fileWriter = new FileWriter(file);
+                fileWriter.write(document.html());
+                fileWriter.flush();
+                fileWriter.close();
+                FileInputStream fileInputStream = new FileInputStream(file);
+                File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                if(!file1.exists()){
+                    file1.mkdirs();
+                }
+                file1 = new File("/usr/local/nginx/html/files/pdf/registration_" + randomString + ".pdf");
+                if(!file1.exists()){
+                    file1.createNewFile();
+                }
+                FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                String link ="http://182.160.16.251:81/files/html/registration_" + randomString + ".html";
+                TEmail tEmail = new TEmail();
+                tEmail.setLink(link);
+                tEmail.setUserId(uid);
+                tEmail.setType(1);
+                tEmail.setName(language == 1 ? "注册成功" : language == 2 ? "Registered successfully" : "Enregistré avec succès");
+                tEmail.setCreateTime(new Date());
+                int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                tEmail.setWeek(EmailUtil.getWeek(language,i));
+                boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                if(am){
+                    tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                }else {
+                    tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                }
+                emailService.insert(tEmail);
+
             }
 
             this.addCoupon(userInfo, language);//添加优惠券
@@ -258,61 +326,114 @@
                         String path1 = templatePath + "driver/index.html";
                         Document document1 = Jsoup.parse(new File(path1), "UTF-8");
                         if(1 == language){
-                            document1.getElementById("english").attr("style", "display: none;");
-                            document1.getElementById("french").attr("style", "display: none;");
-                            document1.getElementById("invite").attr("style", "display: none;");
-                            document1.getElementById("settle").attr("style", "display: none;");
-                            document1.getElementById("pass").attr("style", "display: none;");
-                            document1.getElementById("bill").attr("style", "display: none;");
-                            document1.getElementById("reward").attr("style", "display: none;");
-                            document1.getElementById("rewardToday").attr("style", "display: none;");
+                            document1.getElementById("english").remove();
+                            document1.getElementById("french").remove();
+                            document1.getElementById("invite").remove();
+                            document1.getElementById("settle").remove();
+                            document1.getElementById("pass").remove();
+                            document1.getElementById("bill").remove();
+                            document1.getElementById("reward").remove();
+                            document1.getElementById("rewardToday").remove();
 
                             Element user_user = document1.getElementById("user_user");
-                            user_user.text("您好 " + driver.getName() + ",");
+                            user_user.text("您好 " + driver.getFirstName() + " " + driver.getLastName() + ",");
                             Element user_content = document1.getElementById("user_content");
                             user_content.text("您已成功邀请一位用户注册I-GO,获得奖励GHS " + bigDecimal.doubleValue() + ",请查收");
                         }
                         if(2 == language){
-                            document1.getElementById("chinese").attr("style", "display: none;");
-                            document1.getElementById("french").attr("style", "display: none;");
-                            document1.getElementById("invite1").attr("style", "display: none;");
-                            document1.getElementById("settle1").attr("style", "display: none;");
-                            document1.getElementById("pass1").attr("style", "display: none;");
-                            document1.getElementById("bill1").attr("style", "display: none;");
-                            document1.getElementById("reward1").attr("style", "display: none;");
-                            document1.getElementById("rewardToday1").attr("style", "display: none;");
+                            document1.getElementById("chinese").remove();
+                            document1.getElementById("french").remove();
+                            document1.getElementById("invite1").remove();
+                            document1.getElementById("settle1").remove();
+                            document1.getElementById("pass1").remove();
+                            document1.getElementById("bill1").remove();
+                            document1.getElementById("reward1").remove();
+                            document1.getElementById("rewardToday1").remove();
 
                             Element user1_user = document1.getElementById("user1_user");
-                            user1_user.text("Hello " + driver.getName() + ",");
+                            user1_user.text("Hello " + driver.getFirstName() + " " + driver.getLastName() + ",");
                             Element user1_content = document1.getElementById("user1_content");
                             user1_content.text("You have succeeded to invite a rider to register with I-GO, so you received a GHS " + bigDecimal.doubleValue() + " bonus, please check your balance.");
                         }
                         if(3 == language){
-                            document1.getElementById("chinese").attr("style", "display: none;");
-                            document1.getElementById("english").attr("style", "display: none;");
-                            document1.getElementById("invite1").attr("style", "display: none;");
-                            document1.getElementById("settle1").attr("style", "display: none;");
-                            document1.getElementById("pass1").attr("style", "display: none;");
-                            document1.getElementById("bill1").attr("style", "display: none;");
-                            document1.getElementById("reward1").attr("style", "display: none;");
-                            document1.getElementById("rewardToday1").attr("style", "display: none;");
+                            document1.getElementById("chinese").remove();
+                            document1.getElementById("english").remove();
+                            document1.getElementById("invite1").remove();
+                            document1.getElementById("settle1").remove();
+                            document1.getElementById("pass1").remove();
+                            document1.getElementById("bill1").remove();
+                            document1.getElementById("reward1").remove();
+                            document1.getElementById("rewardToday1").remove();
 
                             Element user2_user = document1.getElementById("user2_user");
-                            user2_user.text("Bonjour " + driver.getName() + ",");
+                            user2_user.text("Bonjour " + driver.getFirstName() + " " + driver.getLastName() + ",");
                             Element user2_content = document1.getElementById("user2_content");
                             user2_content.text("Vous avez invité avec succès un utilisateur à s’inscrire à i-go pour recevoir une récompense GHS " + bigDecimal.doubleValue() + ". Veuillez vérifier");
                         }
-                        EmailUtil.send(driver.getEmail(), language == 1 ? "邀请奖励" : language == 2 ? "invitation bonus" : "prime d'invitation",  document1.html());
+                        EmailUtil.send(driver.getEmail(), language == 1 ? "邀请奖励" : language == 2 ? "Invite and earn" : "Invitez et récompensez",  document1.html());
+                        //开始生成pdf收据和html收据
+                        File file = new File("/usr/local/nginx/html/files/html/");
+                        if(!file.exists()){
+                            file.mkdirs();
+                        }
+                        String randomString = ToolUtil.getRandomString(10);
+                        file = new File("/usr/local/nginx/html/files/html/invitation_" + randomString + ".html");
+                        if(!file.exists()){
+                            file.createNewFile();
+                        }
+                        FileWriter fileWriter = new FileWriter(file);
+                        fileWriter.write(document1.html());
+                        fileWriter.flush();
+                        fileWriter.close();
+                        FileInputStream fileInputStream = new FileInputStream(file);
+                        File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                        if(!file1.exists()){
+                            file1.mkdirs();
+                        }
+                        file1 = new File("/usr/local/nginx/html/files/pdf/invitation_" + randomString + ".pdf");
+                        if(!file1.exists()){
+                            file1.createNewFile();
+                        }
+                        FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                        HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                        String link ="http://182.160.16.251:81/files/html/invitation_" + randomString + ".html";
+                        TEmail tEmail = new TEmail();
+                        tEmail.setLink(link);
+                        tEmail.setUserId(uid);
+                        tEmail.setType(1);
+                        tEmail.setName(language == 1 ? "邀请奖励" : language == 2 ? "Invite and earn" : "Invitez et récompensez");
+                        tEmail.setCreateTime(new Date());
+                        int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                        tEmail.setWeek(EmailUtil.getWeek(language,i));
+                        boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                        if(am){
+                            tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                        }else {
+                            tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                        }
+                        emailService.insert(tEmail);
                     }
                 }
+
                 if(type == 1){//用户分享
                     UserInfo userInfo1 = userInfoMapper.selectById(uid);
                     List<Map<String, Object>> query = userActivityInviteMapper.query(userInfo1.getCompanyId());
                     Date date = new Date();
                     for(Map<String, Object> map : query){
                         Double lavePrice = Double.valueOf(map.get("lavePrice").toString());
-                        String startTime = map.get("startTime").toString();
-                        String endTime = map.get("endTime").toString();
+                        String startTime = "";
+                        String endTime = "";
+                        if(null != map.get("startTime")){
+                            startTime = map.get("startTime").toString();
+                            map.put("startTime", DateUtil.conversionFormat(language, startTime));
+                            startTime = DateUtil.conversionFormat(language, startTime);
+                        }
+                        if(null != map.get("endTime")){
+                            endTime = map.get("endTime").toString();
+                            map.put("endTime", DateUtil.conversionFormat(language, endTime));
+                            endTime = DateUtil.conversionFormat(language, endTime);
+                        }
                         int num = 0;
                         for(int i = Integer.valueOf(String.valueOf(map.get("totalNum"))); i > 0; i--){
                             //判断当前优惠券金额是否大于可发放剩余总金额
@@ -348,8 +469,8 @@
                             String path1 = templatePath +  "user/coupon.html";
                             Document document1 = Jsoup.parse(new File(path1), "UTF-8");
                             if(language == 1){
-                                document1.getElementById("english").attr("style", "display: none;");
-                                document1.getElementById("french").attr("style", "display: none;");
+                                document1.getElementById("english").remove();
+                                document1.getElementById("french").remove();
                                 Element chinese_user = document1.getElementById("chinese_user");
                                 chinese_user.text("您好 " + userInfo1.getNickName() + ",");
                                 Element chinese_number = document1.getElementById("chinese_number");
@@ -358,8 +479,8 @@
                                 chinese_date.text("此活动有效期在" + startTime + "至" + endTime + ",详情请查看I-GO平台");
                             }
                             if(language == 2){
-                                document1.getElementById("chinese").attr("style", "display: none;");
-                                document1.getElementById("french").attr("style", "display: none;");
+                                document1.getElementById("chinese").remove();
+                                document1.getElementById("french").remove();
                                 Element english_user = document1.getElementById("english_user");
                                 english_user.text("Hello " + userInfo1.getNickName() + ",");
                                 Element english_number = document1.getElementById("english_number");
@@ -368,8 +489,8 @@
                                 english_date.text("You could use them from" + startTime + "to" + endTime);
                             }
                             if(language == 3){
-                                document1.getElementById("chinese").attr("style", "display: none;");
-                                document1.getElementById("english").attr("style", "display: none;");
+                                document1.getElementById("chinese").remove();
+                                document1.getElementById("english").remove();
                                 Element french_user = document1.getElementById("french_user");
                                 french_user.text("Bonjour " + userInfo1.getNickName() + ",");
                                 Element french_number = document1.getElementById("french_number");
@@ -377,7 +498,49 @@
                                 Element french_date = document1.getElementById("french_date");
                                 french_date.text("Cette promotion est valide du" + startTime + "au" + endTime);
                             }
-                            EmailUtil.send(userInfo1.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon arrives" : "Le coupon arrive",  document1.html());
+                            EmailUtil.send(userInfo1.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte",  document1.html());
+                            //开始生成pdf收据和html收据
+                            File file = new File("/usr/local/nginx/html/files/html/");
+                            if(!file.exists()){
+                                file.mkdirs();
+                            }
+                            String randomString = ToolUtil.getRandomString(10);
+                            file = new File("/usr/local/nginx/html/files/html/coupon_" + randomString + ".html");
+                            if(!file.exists()){
+                                file.createNewFile();
+                            }
+                            FileWriter fileWriter = new FileWriter(file);
+                            fileWriter.write(document1.html());
+                            fileWriter.flush();
+                            fileWriter.close();
+                            FileInputStream fileInputStream = new FileInputStream(file);
+                            File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                            if(!file1.exists()){
+                                file1.mkdirs();
+                            }
+                            file1 = new File("/usr/local/nginx/html/files/pdf/coupon_" + randomString + ".pdf");
+                            if(!file1.exists()){
+                                file1.createNewFile();
+                            }
+                            FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                            HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                            String link ="http://182.160.16.251:81/files/html/coupon_" + randomString + ".html";
+                            TEmail tEmail = new TEmail();
+                            tEmail.setLink(link);
+                            tEmail.setUserId(uid);
+                            tEmail.setType(1);
+                            tEmail.setName(language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte");
+                            tEmail.setCreateTime(new Date());
+                            int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                            tEmail.setWeek(EmailUtil.getWeek(language,i));
+                            boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                            if(am){
+                                tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                            }else {
+                                tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                            }
+                            emailService.insert(tEmail);
                         }
 
                     }
@@ -385,7 +548,7 @@
             }
         }
         if(userInfo.getState() == 2){
-            return ResultUtil.error("账号被冻结");
+            return ResultUtil.error(language == 1 ? "账号被冻结" : language == 2 ? "Account is frozen" : "Le compte est gelé");
         }
 
         //调用单点登录的逻辑
@@ -405,9 +568,8 @@
     }
 
     @Override
-    public synchronized ResultUtil<LoginWarpper> captchaLogin(String phone, String code, Integer uid, Integer type, Integer userType, Integer language) throws Exception {
-        ResultUtil<LoginWarpper> resultUtil = this.captchaLogin(phone, code, null, null, null,uid,type,userType,language);
-
+    public synchronized ResultUtil<LoginWarpper> captchaLogin(String phoneOperator, String phone, String code, Integer uid, Integer type, Integer userType, Integer language) throws Exception {
+        ResultUtil<LoginWarpper> resultUtil = this.captchaLogin(phoneOperator, phone, code, null, null, null,uid,type,userType,language);
         return resultUtil;
     }
 
@@ -438,10 +600,10 @@
             return ResultUtil.error(language == 1 ? "账号无效" : language == 2 ? "Invalid account" : "Compte non valide");
         }
         if(userInfo.getState() == 2){
-            return ResultUtil.error(language == 1 ? "账号被冻结" : language == 2 ? "Account is frozen." : "Le compte est gelé");
+            return ResultUtil.error(language == 1 ? "账号被冻结" : language == 2 ? "Account is frozen" : "Le compte est gelé");
         }
         if(!ShiroKit.md5(password, salt).equals(userInfo.getPassWord())){
-            return ResultUtil.error(language == 1 ? "密码错误" : language == 2 ? "Password error" : "Mot de passe incorrect");
+            return ResultUtil.error(language == 1 ? "密码错误" : language == 2 ? "Wrong password" : "Mot de passe erroné");
         }
 
         //调用单点登录的逻辑
@@ -452,6 +614,7 @@
         loginWarpper.setId(userInfo.getId());
         loginWarpper.setToken(token);
         loginWarpper.setAppid(UUIDUtil.getRandomCode());
+        loginWarpper.setEmail(userInfo.getEmail());
         loginWarpper.setEmergencyContact(userInfo.getEmergencyContact());
         loginWarpper.setEmergencyContactNumber(userInfo.getEmergencyContactNumber());
         return ResultUtil.success(loginWarpper);
@@ -476,7 +639,7 @@
         String phone=null;
         if(type == 2){//小程序
             if(ToolUtil.isEmpty(jscode)){
-                return ResultUtil.error("微信登录请求失败,请重试");
+                return ResultUtil.error(language == 1 ? "微信登录请求失败,请重试" : language == 2 ? "WeChat login request failed, please try again." : "La demande de connexion WeChat a échoué, veuillez réessayer.");
             }
             Map<String, String> map = weChatUtil.code2Session(jscode);
             openid = map.get("openid");
@@ -538,24 +701,66 @@
                 String path = templatePath +  "user/register.html";
                 Document document = Jsoup.parse(new File(path), "UTF-8");
                 if(1 == language){
-                    document.getElementById("english").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("english").remove();
+                    document.getElementById("french").remove();
                     Element user_chinese = document.getElementById("user_chinese");
                     user_chinese.text("您好 " + userInfo.getNickName() + ",");
                 }
                 if(2 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("french").remove();
                     Element user_english = document.getElementById("user_english");
                     user_english.text("Hello " + userInfo.getNickName() + ",");
                 }
                 if(3 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("english").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("english").remove();
                     Element user_french = document.getElementById("user_french");
                     user_french.text("Bonjour " + userInfo.getNickName() + ",");
                 }
-                EmailUtil.send(userInfo.getEmail(), language == 1 ? "注册成功" : language == 2 ? "Successful registration" : "Inscription réussie",  document.html());
+                EmailUtil.send(userInfo.getEmail(), language == 1 ? "注册成功" : language == 2 ? "Registered successfully" : "Enregistré avec succès",  document.html());
+                //开始生成pdf收据和html收据
+                File file = new File("/usr/local/nginx/html/files/html/");
+                if(!file.exists()){
+                    file.mkdirs();
+                }
+                String randomString = ToolUtil.getRandomString(10);
+                file = new File("/usr/local/nginx/html/files/html/registration_" + randomString + ".html");
+                if(!file.exists()){
+                    file.createNewFile();
+                }
+                FileWriter fileWriter = new FileWriter(file);
+                fileWriter.write(document.html());
+                fileWriter.flush();
+                fileWriter.close();
+                FileInputStream fileInputStream = new FileInputStream(file);
+                File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                if(!file1.exists()){
+                    file1.mkdirs();
+                }
+                file1 = new File("/usr/local/nginx/html/files/pdf/registration_" + randomString + ".pdf");
+                if(!file1.exists()){
+                    file1.createNewFile();
+                }
+                FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                String link ="http://182.160.16.251:81/files/html/registration_" + randomString + ".html";
+                TEmail tEmail = new TEmail();
+                tEmail.setLink(link);
+                tEmail.setUserId(uid);
+                tEmail.setType(1);
+                tEmail.setName(language == 1 ? "注册成功" : language == 2 ? "Registered successfully" : "Enregistré avec succès");
+                tEmail.setCreateTime(new Date());
+                int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                tEmail.setWeek(EmailUtil.getWeek(language,i));
+                boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                if(am){
+                    tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                }else {
+                    tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                }
+                emailService.insert(tEmail);
             }
 
 
@@ -563,7 +768,7 @@
 
         }
         if(userInfo.getState() == 2){
-            return ResultUtil.error("账号被冻结");
+            return ResultUtil.error(language == 1 ? "账号被冻结" : language == 2 ? "Account is frozen" : "Le compte est gelé");
         }
 
         //调用单点登录的逻辑
@@ -621,8 +826,8 @@
                     String path = templatePath +  "user/coupon.html";
                     Document document = Jsoup.parse(new File(path), "UTF-8");
                     if(language == 1){
-                        document.getElementById("english").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("english").remove();
+                        document.getElementById("french").remove();
                         Element chinese_user = document.getElementById("chinese_user");
                         chinese_user.text("您好 " + userInfo.getNickName() + ",");
                         Element chinese_number = document.getElementById("chinese_number");
@@ -631,8 +836,8 @@
                         chinese_date.text("此活动有效期在" + startTime + "至" + endTime + ",详情请查看I-GO平台");
                     }
                     if(language == 2){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("french").remove();
                         Element english_user = document.getElementById("english_user");
                         english_user.text("Hello " + userInfo.getNickName() + ",");
                         Element english_number = document.getElementById("english_number");
@@ -641,8 +846,8 @@
                         english_date.text("You could use them from" + startTime + "to" + endTime);
                     }
                     if(language == 3){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("english").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("english").remove();
                         Element french_user = document.getElementById("french_user");
                         french_user.text("Bonjour " + userInfo.getNickName() + ",");
                         Element french_number = document.getElementById("french_number");
@@ -650,30 +855,72 @@
                         Element french_date = document.getElementById("french_date");
                         french_date.text("Cette promotion est valide du" + startTime + "au" + endTime);
                     }
-                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon arrives" : "Le coupon arrive",  document.html());
+                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte",  document.html());
+                    //开始生成pdf收据和html收据
+                    File file = new File("/usr/local/nginx/html/files/html/");
+                    if(!file.exists()){
+                        file.mkdirs();
+                    }
+                    String randomString = ToolUtil.getRandomString(10);
+                    file = new File("/usr/local/nginx/html/files/html/coupon_" + randomString + ".html");
+                    if(!file.exists()){
+                        file.createNewFile();
+                    }
+                    FileWriter fileWriter = new FileWriter(file);
+                    fileWriter.write(document.html());
+                    fileWriter.flush();
+                    fileWriter.close();
+                    FileInputStream fileInputStream = new FileInputStream(file);
+                    File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                    if(!file1.exists()){
+                        file1.mkdirs();
+                    }
+                    file1 = new File("/usr/local/nginx/html/files/pdf/coupon_" + randomString + ".pdf");
+                    if(!file1.exists()){
+                        file1.createNewFile();
+                    }
+                    FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                    HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                    String link ="http://182.160.16.251:81/files/html/coupon_" + randomString + ".html";
+                    TEmail tEmail = new TEmail();
+                    tEmail.setLink(link);
+                    tEmail.setUserId(uid);
+                    tEmail.setType(1);
+                    tEmail.setName(language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte");
+                    tEmail.setCreateTime(new Date());
+                    int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                    tEmail.setWeek(EmailUtil.getWeek(language,i));
+                    boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                    if(am){
+                        tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                    }else {
+                        tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                    }
+                    emailService.insert(tEmail);
                 }
             }
         }
         return ResultUtil.success(loginWarpper);
     }
     @Override
-    public ResultUtil<LoginWarpper> wxIsLogin(String jscode) throws Exception {
+    public ResultUtil<LoginWarpper> wxIsLogin(Integer language, String jscode) throws Exception {
         UserInfo userInfo = null;
         String phone=null;
         if(ToolUtil.isEmpty(jscode)){
-            return ResultUtil.error("微信登录请求失败,请重试");
+            return ResultUtil.error(language == 1 ? "微信登录请求失败,请重试" : language == 2 ? "WeChat login request failed, please try again." : "La demande de connexion WeChat a échoué, veuillez réessayer.");
         }
         Map<String, String> map = weChatUtil.code2Session(jscode);
         String openid = map.get("openid");
         String unionid = map.get("unionid");
         userInfo = userInfoMapper.queryByOpenid2(openid);
         if(null==userInfo){
-            return ResultUtil.getResult(2000,"微信登录请求失败,请重试");
+            return ResultUtil.getResult(2000,language == 1 ? "微信登录请求失败,请重试" : language == 2 ? "WeChat login request failed, please try again." : "La demande de connexion WeChat a échoué, veuillez réessayer.");
         }
 
 
         if(userInfo.getState() == 2){
-            return ResultUtil.error("账号被冻结");
+            return ResultUtil.error(language == 1 ? "账号被冻结" : language == 2 ? "Account is frozen" : "Le compte est gelé");
         }
 
         //调用单点登录的逻辑
@@ -693,8 +940,13 @@
 
 
     @Override
-    public ResultUtil facebookLogin(String id, String name, String email, Double lat, Double lng, Integer uid, Integer language) throws Exception {
-        UserInfo userInfo = this.selectOne(new EntityWrapper<UserInfo>().eq("faceBookId", id).ne("flag", 3));
+    public ResultUtil facebookLogin(String id, String name, String email, Double lat, Double lng, Integer uid, Integer language,int type) throws Exception {
+        UserInfo userInfo=null;
+        if(type==1){
+             userInfo = this.selectOne(new EntityWrapper<UserInfo>().eq("faceBookId", id).ne("flag", 3));
+        }else {
+             userInfo = this.selectOne(new EntityWrapper<UserInfo>().eq("twitterId", id).ne("flag", 3));
+        }
         if(null == userInfo){
             userInfo = new UserInfo();
             userInfo.setEmail(email);
@@ -704,7 +956,11 @@
             userInfo.setBalance(0D);
             userInfo.setIntegral(0);
             userInfo.setPassWord(ShiroKit.md5("", salt));
-            userInfo.setFaceBookId(id);
+            if(type==1){
+                userInfo.setFaceBookId(id);
+            }else {
+                userInfo.setTwitterId(id);
+            }
             userInfo.setState(1);
             userInfo.setFlag(1);
             userInfo.setInsertTime(new Date());
@@ -740,32 +996,72 @@
                 String path = templatePath +  "user/register.html";
                 Document document = Jsoup.parse(new File(path), "UTF-8");
                 if(1 == language){
-                    document.getElementById("english").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("english").remove();
+                    document.getElementById("french").remove();
                     Element user_chinese = document.getElementById("user_chinese");
                     user_chinese.text("您好 " + userInfo.getNickName() + ",");
                 }
                 if(2 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("french").remove();
                     Element user_english = document.getElementById("user_english");
                     user_english.text("Hello " + userInfo.getNickName() + ",");
                 }
                 if(3 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("english").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("english").remove();
                     Element user_french = document.getElementById("user_french");
                     user_french.text("Bonjour " + userInfo.getNickName() + ",");
                 }
-                EmailUtil.send(userInfo.getEmail(), language == 1 ? "注册成功" : language == 2 ? "Successful registration" : "Inscription réussie",  document.html());
+                EmailUtil.send(userInfo.getEmail(), language == 1 ? "注册成功" : language == 2 ? "Registered successfully" : "Enregistré avec succès",  document.html());
+                //开始生成pdf收据和html收据
+                File file = new File("/usr/local/nginx/html/files/html/");
+                if(!file.exists()){
+                    file.mkdirs();
+                }
+                String randomString = ToolUtil.getRandomString(10);
+                file = new File("/usr/local/nginx/html/files/html/registration_" + randomString + ".html");
+                if(!file.exists()){
+                    file.createNewFile();
+                }
+                FileWriter fileWriter = new FileWriter(file);
+                fileWriter.write(document.html());
+                fileWriter.flush();
+                fileWriter.close();
+                FileInputStream fileInputStream = new FileInputStream(file);
+                File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                if(!file1.exists()){
+                    file1.mkdirs();
+                }
+                file1 = new File("/usr/local/nginx/html/files/pdf/registration_" + randomString + ".pdf");
+                if(!file1.exists()){
+                    file1.createNewFile();
+                }
+                FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                String link ="http://182.160.16.251:81/files/html/registration_" + randomString + ".html";
+                TEmail tEmail = new TEmail();
+                tEmail.setLink(link);
+                tEmail.setUserId(uid);
+                tEmail.setType(1);
+                tEmail.setName(language == 1 ? "注册成功" : language == 2 ? "Registered successfully" : "Enregistré avec succès");
+                tEmail.setCreateTime(new Date());
+                int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                tEmail.setWeek(EmailUtil.getWeek(language,i));
+                boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                if(am){
+                    tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                }else {
+                    tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                }
+                emailService.insert(tEmail);
             }
-
-
             this.addCoupon(userInfo, language);//添加优惠券
         }
 
         if(userInfo.getState() == 2){
-            return ResultUtil.error("账号被冻结");
+            return ResultUtil.error(language == 1 ? "账号被冻结" : language == 2 ? "Account is frozen" : "Le compte est gelé");
         }
 
         //调用单点登录的逻辑
@@ -823,8 +1119,8 @@
                     String path = templatePath +  "user/coupon.html";
                     Document document = Jsoup.parse(new File(path), "UTF-8");
                     if(language == 1){
-                        document.getElementById("english").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("english").remove();
+                        document.getElementById("french").remove();
                         Element chinese_user = document.getElementById("chinese_user");
                         chinese_user.text("您好 " + userInfo.getNickName() + ",");
                         Element chinese_number = document.getElementById("chinese_number");
@@ -833,8 +1129,8 @@
                         chinese_date.text("此活动有效期在" + startTime + "至" + endTime + ",详情请查看I-GO平台");
                     }
                     if(language == 2){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("french").remove();
                         Element english_user = document.getElementById("english_user");
                         english_user.text("Hello " + userInfo.getNickName() + ",");
                         Element english_number = document.getElementById("english_number");
@@ -843,8 +1139,8 @@
                         english_date.text("You could use them from" + startTime + "to" + endTime);
                     }
                     if(language == 3){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("english").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("english").remove();
                         Element french_user = document.getElementById("french_user");
                         french_user.text("Bonjour " + userInfo.getNickName() + ",");
                         Element french_number = document.getElementById("french_number");
@@ -852,7 +1148,49 @@
                         Element french_date = document.getElementById("french_date");
                         french_date.text("Cette promotion est valide du" + startTime + "au" + endTime);
                     }
-                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon arrives" : "Le coupon arrive",  document.html());
+                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte",  document.html());
+                    //开始生成pdf收据和html收据
+                    File file = new File("/usr/local/nginx/html/files/html/");
+                    if(!file.exists()){
+                        file.mkdirs();
+                    }
+                    String randomString = ToolUtil.getRandomString(10);
+                    file = new File("/usr/local/nginx/html/files/html/coupon_" + randomString + ".html");
+                    if(!file.exists()){
+                        file.createNewFile();
+                    }
+                    FileWriter fileWriter = new FileWriter(file);
+                    fileWriter.write(document.html());
+                    fileWriter.flush();
+                    fileWriter.close();
+                    FileInputStream fileInputStream = new FileInputStream(file);
+                    File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                    if(!file1.exists()){
+                        file1.mkdirs();
+                    }
+                    file1 = new File("/usr/local/nginx/html/files/pdf/coupon_" + randomString + ".pdf");
+                    if(!file1.exists()){
+                        file1.createNewFile();
+                    }
+                    FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                    HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                    String link ="http://182.160.16.251:81/files/html/coupon_" + randomString + ".html";
+                    TEmail tEmail = new TEmail();
+                    tEmail.setLink(link);
+                    tEmail.setUserId(uid);
+                    tEmail.setType(1);
+                    tEmail.setName(language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte");
+                    tEmail.setCreateTime(new Date());
+                    int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                    tEmail.setWeek(EmailUtil.getWeek(language,i));
+                    boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                    if(am){
+                        tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                    }else {
+                        tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                    }
+                    emailService.insert(tEmail);
                 }
             }
         }
@@ -871,14 +1209,14 @@
     public ResultUtil forgetPassword(String phone, String code, String password, Integer language) throws Exception {
         UserInfo userInfo = this.queryByPhone(phone);
         if(null == userInfo){
-            return ResultUtil.error(language == 1 ? "手机号码未注册" : language == 2 ? "Cell phone number is not registered" : "Numéro de téléphone portable non enregistré");
+            return ResultUtil.error(language == 1 ? "手机号码未注册" : language == 2 ? "Mobile phone number was not registered." : "Le numéro de téléphone portable n’a pas été enregistré.");
         }
         boolean b = this.checkCaptcha(phone, code);
         if(!b){
             b = this.checkCaptcha(userInfo.getEmail(), code);
         }
         if(!b){
-            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid captcha" : "Code de vérification invalide");
+            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid CAPTCHA" : "CAPTCHA non valide");
         }
         if(userInfo.getState() == 2){
             return ResultUtil.error(language == 1 ? "账号已被冻结" : language == 2 ? "The account has been frozen" : "Le compte a été gelé");
@@ -902,10 +1240,10 @@
      * @throws Exception
      */
     @Override
-    public ResultUtil bindingPhone(Integer uid, String phone, String code, Integer language) throws Exception {
+    public ResultUtil bindingPhone(Integer uid, String phoneOperator, String phone, String code, Integer language) throws Exception {
         boolean b = this.checkCaptcha(phone, code);
         if(!b){
-            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid captcha" : "Code de vérification invalide");
+            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid CAPTCHA" : "CAPTCHA non valide");
         }
         UserInfo userInfo = this.selectById(uid);
         UserInfo userInfo1 = userInfoMapper.queryByPhone(phone);
@@ -952,6 +1290,7 @@
             return ResultUtil.success(loginWarpper);
         }
 
+        userInfo.setPhoneOperator(phoneOperator);
         userInfo.setPhone(phone);
         userInfo.setUpdateTime(new Date());
         userInfo.setUpdateUser(userInfo.getId());
@@ -966,12 +1305,12 @@
     public ResultUtil bindingEmail(Integer uid, Integer type, String email, String code, Integer language) throws Exception {
         boolean b = this.checkCaptcha(email, code);
         if(!b){
-            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid captcha" : "Code de vérification invalide");
+            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid CAPTCHA" : "CAPTCHA non valide");
         }
         UserInfo userInfo = this.selectById(uid);
         UserInfo userInfo1 = userInfoMapper.queryByEmail(email);
         if(null != userInfo1 && uid.compareTo(userInfo1.getId()) != 0){
-            return ResultUtil.error(language == 1 ? "邮箱已被使用" : language == 2 ? "The mailbox is in use" : "La boîte mail a déjà été utilisée");
+            return ResultUtil.error(language == 1 ? "邮箱已被使用" : language == 2 ? "E-mail address is already in use." : "L’adresse e-mail est déjà utilisée.");
         }
 
 //        if(null != userInfo1){
@@ -1060,8 +1399,13 @@
      * @throws Exception
      */
     @Override
-    public Map<String, Object> queryUserInfo(Integer uid) throws Exception {
-        return userInfoMapper.queryUserInfo(uid, null);
+    public Map<String, Object> queryUserInfo(Integer language, Integer uid) throws Exception {
+        Map<String, Object> map = userInfoMapper.queryUserInfo(uid, null);
+        if(null != map.get("birthday")){
+            String birthday = map.get("birthday").toString();
+            map.put("birthday", DateUtil.conversionFormat(language, birthday));
+        }
+        return map;
     }
 
 
@@ -1072,8 +1416,13 @@
      * @throws Exception
      */
     @Override
-    public Map<String, Object> queryUser(String phone) throws Exception {
-        return userInfoMapper.queryUserInfo(null, phone);
+    public Map<String, Object> queryUser(Integer language, String phone) throws Exception {
+        Map<String, Object> map = userInfoMapper.queryUserInfo(null, phone);
+        if(null != map.get("birthday")){
+            String birthday = map.get("birthday").toString();
+            map.put("birthday", DateUtil.conversionFormat(language, birthday));
+        }
+        return map;
     }
 
 
@@ -1099,28 +1448,20 @@
      * @throws Exception
      */
     @Override
-    public ResultUtil depositBalance(Integer payType, String accountNumber, Double money, Integer uid, Integer type, Integer language) throws Exception {
+    public ResultUtil depositBalance(Integer payType, String bankCardId, Double money, Integer uid, Integer type, Integer language) throws Exception {
         UserInfo userInfo = userInfoMapper.selectById(uid);
         if(money.compareTo(0D) <= 0){
-            return ResultUtil.error("支付金额必须大于0元");
+            return ResultUtil.error(language == 1 ? "支付金额必须大于0元" : language == 2 ? "Payment amount must be greater than zero." : "Le montant du paiement doit être supérieur à zéro.", "");
         }
-        if(payType == 1){//微信支付
+        if(payType == 1){//手机支付
             Integer integer = paymentRecordService.saveData(2, uid, 1, null, null, 1, money, "", 1);//添加预支付数据
-//            ResultUtil resultUtil = payMoneyUtil.weixinpay("余额充值",language.toString(),integer.toString(),money+"","/base/wxCancelUserBalance","JSAPI",userInfo.getAppletsOpenId());
-//            if(resultUtil.getCode()==200){
-//                PaymentRecord paymentRecord = paymentRecordService.selectById(integer);
-//                paymentRecordService.updateById(paymentRecord);
-//                return resultUtil;
-//            }else{
-//                return ResultUtil.error("获取支付信息失败", "");
-//            }
 
             SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
             String merchantTransactionId = sdf.format(new Date()) + language + integer;
             CheckoutRequest checkoutRequest = new CheckoutRequest();
             checkoutRequest.setMsisdn(Long.valueOf(userInfo.getPhone()));
             checkoutRequest.setCustomerEmail(userInfo.getEmail());
-            checkoutRequest.setAccountNumber(accountNumber);
+            checkoutRequest.setAccountNumber(userInfo.getPhone());
             checkoutRequest.setCustomerFirstName(userInfo.getFirstName());
             checkoutRequest.setCustomerLastName(userInfo.getLastName());
             checkoutRequest.setRequestAmount(money);
@@ -1128,24 +1469,32 @@
             checkoutRequest.setRequestDescription("Account top-up");
             checkoutRequest.setCallbackUrl(callbackPath + "/base/wxCancelUserBalance");
             checkoutRequest.setPendingRedirectUrl("");
-            checkoutRequest.setSuccessRedirectUrl("https://10pz685243.zicp.fun");
-            checkoutRequest.setFailRedirectUrl("https://www.baidu.com");
+            checkoutRequest.setSuccessRedirectUrl("http://182.160.16.251:81/payMoney/pages/success.html");
+            checkoutRequest.setFailRedirectUrl("http://182.160.16.251:81/payMoney/pages/fail.html");
             return TinggPayUtil.checkoutRequest(checkoutRequest);
-
-
         }
-//        if(payType == 2){//支付宝支付
-//            Integer integer = paymentRecordService.saveData(2, uid, 1, null, null, 2, money, "", 1);//添加预支付数据
-//            ResultUtil resultUtil = payMoneyUtil.alipay("余额充值","余额充值",integer + "_" + language,money+"","/base/aliCancelUserBalance");
-//            if(resultUtil.getCode()==200){
-//                PaymentRecord paymentRecord = paymentRecordService.selectById(integer);
-//                paymentRecordService.updateById(paymentRecord);
-//                return resultUtil;
-//            }else{
-//                return ResultUtil.error("获取支付信息失败", "");
-//            }
-//        }
-        return ResultUtil.success();
+
+        if(payType == 2){//银行卡支付
+            Integer integer = paymentRecordService.saveData(2, uid, 1, null, null, 1, money, "", 1);//添加预支付数据
+            BankCard bankCard = bankCardService.selectById(bankCardId);
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
+            String merchantTransactionId = sdf.format(new Date()) + language + integer;
+            CheckoutRequest checkoutRequest = new CheckoutRequest();
+            checkoutRequest.setMsisdn(Long.valueOf(bankCard.getCode()));
+            checkoutRequest.setCustomerEmail(userInfo.getEmail());
+            checkoutRequest.setAccountNumber(bankCard.getCode());
+            checkoutRequest.setCustomerFirstName(bankCard.getFirstName());
+            checkoutRequest.setCustomerLastName(bankCard.getLastName());
+            checkoutRequest.setRequestAmount(money);
+            checkoutRequest.setMerchantTransactionId(merchantTransactionId);
+            checkoutRequest.setRequestDescription("Account top-up");
+            checkoutRequest.setCallbackUrl(callbackPath + "/base/wxCancelUserBalance");
+            checkoutRequest.setPendingRedirectUrl("");
+            checkoutRequest.setSuccessRedirectUrl("http://182.160.16.251:81/payMoney/pages/success.html");
+            checkoutRequest.setFailRedirectUrl("http://182.160.16.251:81/payMoney/pages/fail.html");
+            return TinggPayUtil.checkoutRequest(checkoutRequest);
+        }
+        return ResultUtil.success("");
     }
 
 
@@ -1158,20 +1507,19 @@
      * @throws Exception
      */
     @Override
-    public ResultUtil updatePhone(String code, String phone, Integer uid, Integer language) throws Exception {
+    public ResultUtil updatePhone(String code, String phoneOperator, String phone, Integer uid, Integer language) throws Exception {
         boolean b = this.checkCaptcha(phone, code);
         if(!b){
-            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid captcha" : "Code de vérification invalide");
+            return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid CAPTCHA" : "CAPTCHA non valide");
         }
         UserInfo userInfo = this.selectById(uid);
         UserInfo userInfo1 = userInfoMapper.queryByPhone(phone);
         if(null != userInfo1){
-            return ResultUtil.error(language == 1 ? "手机号已被注册" : language == 2 ? "The phone number has been registered" : "Le numéro de téléphone a été enregistré");
+            return ResultUtil.error(language == 1 ? "手机号已被注册" : language == 2 ? "Mobile phone number has been registered." : "Le numéro de téléphone portable a été enregistré.");
         }
+        userInfo.setPhoneOperator(phoneOperator);
         userInfo.setPhone(phone);
         this.updateById(userInfo);
-
-//        smsrecordService.saveData(2, phone, code, "短信验证码【" + code + "】已发到您的手机,验证码将在5分钟后失效,请及时登录!");
         return ResultUtil.success();
     }
 
@@ -1193,25 +1541,67 @@
             String path = templatePath +  "user/passwordReset.html";
             Document document = Jsoup.parse(new File(path), "UTF-8");
             if(1 == language){
-                document.getElementById("english").attr("style", "display: none;");
-                document.getElementById("french").attr("style", "display: none;");
+                document.getElementById("english").remove();
+                document.getElementById("french").remove();
                 Element user_chinese = document.getElementById("user_chinese");
                 user_chinese.text("您好 " + userInfo.getNickName() + ",");
             }
             if(2 == language){
-                document.getElementById("chinese").attr("style", "display: none;");
-                document.getElementById("french").attr("style", "display: none;");
+                document.getElementById("chinese").remove();
+                document.getElementById("french").remove();
                 Element user_chinese = document.getElementById("user_english");
                 user_chinese.text("Hello " + userInfo.getNickName() + ",");
             }
             if(3 == language){
-                document.getElementById("chinese").attr("style", "display: none;");
-                document.getElementById("english").attr("style", "display: none;");
+                document.getElementById("chinese").remove();
+                document.getElementById("english").remove();
                 Element user_french = document.getElementById("user_french");
                 user_french.text("Bonjour " + userInfo.getNickName() + ",");
             }
 
             EmailUtil.send(userInfo.getEmail(), language == 1 ? "重置密码" : language == 2 ? "Reset password" : "Réinitialiser le mot de passe",  document.html());
+            //开始生成pdf收据和html收据
+            File file = new File("/usr/local/nginx/html/files/html/");
+            if(!file.exists()){
+                file.mkdirs();
+            }
+            String randomString = ToolUtil.getRandomString(10);
+            file = new File("/usr/local/nginx/html/files/html/password_" + randomString + ".html");
+            if(!file.exists()){
+                file.createNewFile();
+            }
+            FileWriter fileWriter = new FileWriter(file);
+            fileWriter.write(document.html());
+            fileWriter.flush();
+            fileWriter.close();
+            FileInputStream fileInputStream = new FileInputStream(file);
+            File file1 = new File("/usr/local/nginx/html/files/pdf/");
+            if(!file1.exists()){
+                file1.mkdirs();
+            }
+            file1 = new File("/usr/local/nginx/html/files/pdf/password_" + randomString + ".pdf");
+            if(!file1.exists()){
+                file1.createNewFile();
+            }
+            FileOutputStream fileOutputStream = new FileOutputStream(file1);
+            HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+            String link ="http://182.160.16.251:81/files/html/password_" + randomString + ".html";
+            TEmail tEmail = new TEmail();
+            tEmail.setLink(link);
+            tEmail.setUserId(uid);
+            tEmail.setType(1);
+            tEmail.setName(language == 1 ? "重置密码" : language == 2 ? "Reset password" : "Réinitialiser le mot de passe");
+            tEmail.setCreateTime(new Date());
+            int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+            tEmail.setWeek(EmailUtil.getWeek(language,i));
+            boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+            if(am){
+                tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+            }else {
+                tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+            }
+            emailService.insert(tEmail);
         }
         return ResultUtil.success();
     }
@@ -1227,7 +1617,7 @@
      * @throws Exception
      */
     @Override
-    public void updateInfo(String avatar, String nickname, Integer sex, Date birthday, String email, String lastName, String firstName, Integer uid) throws Exception {
+    public ResultUtil updateInfo(String avatar, String nickname, Integer sex, Date birthday, String email, String code, String lastName, String firstName, Integer uid, Integer language) throws Exception {
         UserInfo userInfo = this.selectById(uid);
         if(ToolUtil.isNotEmpty(avatar)){
             userInfo.setAvatar(avatar);
@@ -1242,6 +1632,10 @@
             userInfo.setBirthday(birthday);
         }
         if(null != email){
+            String value = redisUtil.getValue(email);
+            if(ToolUtil.isEmpty(value) || code.equals(value)){
+                return ResultUtil.error(language == 1 ? "验证码无效" : language == 2 ? "Invalid CAPTCHA" : "CAPTCHA non valide");
+            }
             userInfo.setEmail(email);
         }
         if(null != lastName){
@@ -1251,6 +1645,7 @@
             userInfo.setFirstName(firstName);
         }
         this.updateById(userInfo);
+        return ResultUtil.success();
     }
 
 
@@ -1270,11 +1665,10 @@
      * 完成余额充值后的处理
      * @param id            用户id
      * @param order_id      工行订单id
-     * @param type          支付类型(1=微信,2=支付宝)
      * @throws Exception
      */
     @Override
-    public void payCancelUserBalance(Integer id, String order_id, Integer paymentRecordId, Integer type, Integer language) throws Exception {
+    public void payCancelUserBalance(Integer id, String order_id, Integer paymentRecordId, Integer language) throws Exception {
         PaymentRecord query = paymentRecordService.selectById(paymentRecordId);
         UserInfo userInfo = this.selectById(query.getUserId());
         if(null != query){
@@ -1291,7 +1685,7 @@
             this.addCoupon(userInfo.getId(), query.getAmount(), userInfo.getCompanyId(), query.getId(), language);//添加优惠券
 
         }else{
-            System.err.println("预支付数据异常(userId = "  + id + ")");
+            System.err.println("预支付数据异常(paymentRecordId = "  + paymentRecordId + ")");
         }
 
     }
@@ -1306,7 +1700,7 @@
      * @throws Exception
      */
     public synchronized void addCoupon(Integer userId, Double money, Integer companyId, Integer paymentRecordId, Integer language) throws Exception{
-        List<Map<String, Object>> query = userActivityBalanceService.query(money, companyId);
+        List<Map<String, Object>> query = userActivityBalanceService.query(language, money, companyId);
         List<UserCouponRecord> list = new ArrayList<>();
         for(Map<String, Object> map : query){
             //添加通用优惠券
@@ -1444,8 +1838,8 @@
                     String path = templatePath +  "user/coupon.html";
                     Document document = Jsoup.parse(new File(path), "UTF-8");
                     if(language == 1){
-                        document.getElementById("english").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("english").remove();
+                        document.getElementById("french").remove();
                         Element chinese_user = document.getElementById("chinese_user");
                         chinese_user.text("您好 " + userInfo.getNickName() + ",");
                         Element chinese_number = document.getElementById("chinese_number");
@@ -1454,8 +1848,8 @@
                         chinese_date.text("此活动有效期在" + startTime + "至" + endTime + ",详情请查看I-GO平台");
                     }
                     if(language == 2){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("french").remove();
                         Element english_user = document.getElementById("english_user");
                         english_user.text("Hello " + userInfo.getNickName() + ",");
                         Element english_number = document.getElementById("english_number");
@@ -1464,8 +1858,8 @@
                         english_date.text("You could use them from" + startTime + "to" + endTime);
                     }
                     if(language == 3){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("english").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("english").remove();
                         Element french_user = document.getElementById("french_user");
                         french_user.text("Bonjour " + userInfo.getNickName() + ",");
                         Element french_number = document.getElementById("french_number");
@@ -1473,7 +1867,49 @@
                         Element french_date = document.getElementById("french_date");
                         french_date.text("Cette promotion est valide du" + startTime + "au" + endTime);
                     }
-                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon arrives" : "Le coupon arrive",  document.html());
+                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte",  document.html());
+                    //开始生成pdf收据和html收据
+                    File file = new File("/usr/local/nginx/html/files/html/");
+                    if(!file.exists()){
+                        file.mkdirs();
+                    }
+                    String randomString = ToolUtil.getRandomString(10);
+                    file = new File("/usr/local/nginx/html/files/html/coupon_" + randomString + ".html");
+                    if(!file.exists()){
+                        file.createNewFile();
+                    }
+                    FileWriter fileWriter = new FileWriter(file);
+                    fileWriter.write(document.html());
+                    fileWriter.flush();
+                    fileWriter.close();
+                    FileInputStream fileInputStream = new FileInputStream(file);
+                    File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                    if(!file1.exists()){
+                        file1.mkdirs();
+                    }
+                    file1 = new File("/usr/local/nginx/html/files/pdf/coupon_" + randomString + ".pdf");
+                    if(!file1.exists()){
+                        file1.createNewFile();
+                    }
+                    FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                    HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                    String link ="http://182.160.16.251:81/files/html/coupon_" + randomString + ".html";
+                    TEmail tEmail = new TEmail();
+                    tEmail.setLink(link);
+                    tEmail.setUserId(userInfo.getId());
+                    tEmail.setType(1);
+                    tEmail.setName(language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte");
+                    tEmail.setCreateTime(new Date());
+                    int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                    tEmail.setWeek(EmailUtil.getWeek(language,i));
+                    boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                    if(am){
+                        tEmail.setAmOrPm(language==1?"上午":language==2?"AM":"Dans la matinée");
+                    }else {
+                        tEmail.setAmOrPm(language==1?"下午":language==2?"PM":"après-midi");
+                    }
+                    emailService.insert(tEmail);
                 }
             }
         }
@@ -1526,7 +1962,7 @@
      */
     private synchronized void addCoupon(UserInfo userInfo, Integer language) throws Exception{
         //添加优惠券
-        List<Map<String, Object>> list = userActivityRegisteredService.query(userInfo.getCompanyId());
+        List<Map<String, Object>> list = userActivityRegisteredService.query(language, userInfo.getCompanyId());
         int num = 0;
         for(Map<String, Object> map : list){
             if(null != map){
@@ -1569,8 +2005,8 @@
                     String path = templatePath +  "user/coupon.html";
                     Document document = Jsoup.parse(new File(path), "UTF-8");
                     if(language == 1){
-                        document.getElementById("english").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("english").remove();
+                        document.getElementById("french").remove();
                         Element chinese_user = document.getElementById("chinese_user");
                         chinese_user.text("您好 " + userInfo.getNickName() + ",");
                         Element chinese_number = document.getElementById("chinese_number");
@@ -1579,8 +2015,8 @@
                         chinese_date.text("此活动有效期在" + startTime + "至" + endTime + ",详情请查看I-GO平台");
                     }
                     if(language == 2){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("french").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("french").remove();
                         Element english_user = document.getElementById("english_user");
                         english_user.text("Hello " + userInfo.getNickName() + ",");
                         Element english_number = document.getElementById("english_number");
@@ -1589,8 +2025,8 @@
                         english_date.text("You could use them from" + startTime + "to" + endTime);
                     }
                     if(language == 3){
-                        document.getElementById("chinese").attr("style", "display: none;");
-                        document.getElementById("english").attr("style", "display: none;");
+                        document.getElementById("chinese").remove();
+                        document.getElementById("english").remove();
                         Element french_user = document.getElementById("french_user");
                         french_user.text("Bonjour " + userInfo.getNickName() + ",");
                         Element french_number = document.getElementById("french_number");
@@ -1598,12 +2034,53 @@
                         Element french_date = document.getElementById("french_date");
                         french_date.text("Cette promotion est valide du" + startTime + "au" + endTime);
                     }
-                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon arrives" : "Le coupon arrive",  document.html());
+                    EmailUtil.send(userInfo.getEmail(), language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte",  document.html());
+                    //开始生成pdf收据和html收据
+                    File file = new File("/usr/local/nginx/html/files/html/");
+                    if(!file.exists()){
+                        file.mkdirs();
+                    }
+                    String randomString = ToolUtil.getRandomString(10);
+                    file = new File("/usr/local/nginx/html/files/html/coupon_" + randomString + ".html");
+                    if(!file.exists()){
+                        file.createNewFile();
+                    }
+                    FileWriter fileWriter = new FileWriter(file);
+                    fileWriter.write(document.html());
+                    fileWriter.flush();
+                    fileWriter.close();
+                    FileInputStream fileInputStream = new FileInputStream(file);
+                    File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                    if(!file1.exists()){
+                        file1.mkdirs();
+                    }
+                    file1 = new File("/usr/local/nginx/html/files/pdf/coupon_" + randomString + ".pdf");
+                    if(!file1.exists()){
+                        file1.createNewFile();
+                    }
+                    FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                    HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
+
+                    String link ="http://182.160.16.251:81/files/html/coupon_" + randomString + ".html";
+                    TEmail tEmail = new TEmail();
+                    tEmail.setLink(link);
+                    tEmail.setUserId(userInfo.getId());
+                    tEmail.setType(1);
+                    tEmail.setName(language == 1 ? "优惠券到账" : language == 2 ? "Coupon is in" : "Le coupon est arrivé sur le compte");
+                    tEmail.setCreateTime(new Date());
+                    int i = cn.hutool.core.date.DateUtil.dayOfWeek(new Date())-1;
+                    boolean am = cn.hutool.core.date.DateUtil.isAM(new Date());
+                    if(am){
+                        tEmail.setAmOrPm(language==1?"上午":language==2?"Morning":"");
+                    }else {
+                        tEmail.setAmOrPm(language==1?"下午":language==2?"Afternoon":"");
+                    }
+                    emailService.insert(tEmail);
                 }
             }
         }
         //添加系统消息
-        systemNoticeService.addSystemNotice(1, "您已获得" + num + "张优惠券,点击查看", userInfo.getId(), 2);
+        systemNoticeService.addSystemNotice(1, language == 1 ? "您已获得" + num + "张优惠券,点击查看" : language == 2 ? "You've got " + num + " coupon, click to view" : "Vous avez reçu " + num + " coupon, cliquez pour voir", userInfo.getId(), 2);
     }
 
 

--
Gitblit v1.7.1