From 441eb455e1e8a9283cd569c132b14ba8da4c54a6 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期六, 11 十月 2025 17:49:47 +0800
Subject: [PATCH] 导出,短信,模板消息

---
 ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java |  118 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 112 insertions(+), 6 deletions(-)

diff --git a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
index 1d9186e..10a2f75 100644
--- a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
+++ b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
@@ -1,17 +1,33 @@
 package com.ruoyi.web.controller.system;
 
-import java.util.List;
-import java.util.Set;
+import java.util.*;
 import java.util.concurrent.TimeUnit;
 
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.domain.entity.SysRole;
+import com.ruoyi.common.core.domain.entity.TSysUserResp;
 import com.ruoyi.common.core.domain.model.LoginUser;
 import com.ruoyi.common.core.domain.model.LoginUserApplet;
 import com.ruoyi.common.core.redis.RedisCache;
+import com.ruoyi.common.redis.service.RedisService;
 import com.ruoyi.framework.web.service.TokenService;
-import com.ruoyi.system.service.ISysRoleService;
+import com.ruoyi.system.model.TSysAppUser;
+import com.ruoyi.system.model.TSysMessageTemplate;
+import com.ruoyi.system.service.*;
+import com.ruoyi.system.utils.wx.body.resp.Code2SessionRespBody;
+import com.ruoyi.system.utils.wx.body.resq.Code2SessionResqBody;
+import com.ruoyi.system.utils.wx.model.WeixinProperties;
+import com.ruoyi.system.utils.wx.pojo.AppletUserDecodeData;
+import com.ruoyi.system.utils.wx.pojo.AppletUserEncrypteData;
+import com.ruoyi.system.utils.wx.pojo.OfficeUserEncrypteData;
+import com.ruoyi.system.utils.wx.tools.WxAppletTools;
+import com.ruoyi.system.utils.wx.tools.WxUtils;
+import com.ruoyi.web.controller.tool.MsgUtils;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.StringUtils;
@@ -24,13 +40,16 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.framework.web.service.SysLoginService;
 import com.ruoyi.framework.web.service.SysPermissionService;
-import com.ruoyi.system.service.ISysMenuService;
+import org.springframework.web.client.RestTemplate;
+
+import javax.annotation.Resource;
 
 /**
  * 登录验证
  * 
  * @author ruoyi
  */
+@Slf4j
 @Api(tags = "登录")
 @RestController
 public class SysLoginController
@@ -49,7 +68,20 @@
     private TokenService tokenService;
     @Autowired
     private ISysRoleService roleService;
-
+    @Autowired
+    private WeixinProperties wxConfig;
+    @Autowired
+    private RestTemplate wxRestTemplate;
+    @Autowired
+    private MsgUtils msgUtils;
+    @Autowired
+    private TSysMessageTemplateService sysMessageTemplateService;
+    @Autowired
+    private RedisService redisService;
+    @Autowired
+    private TSysAppUserService sysAppUserService;
+    @Autowired
+    private ISysUserService sysUserService;
     /**
      * 账号密码登录
      * 
@@ -79,6 +111,76 @@
         ajax.put("roleName",roles.get(0).getRoleName());
         ajax.put("userInfo",loginUser);
         return ajax;
+    }
+
+    @ApiOperation(value = "通过code获得openid,获取用户信息",tags = {"微信小程序登录"})
+    @PostMapping("/openIdByJsCode")
+    public R<Map<String, Object>> openIdByJsCode(@RequestBody AppletUserEncrypteData data) {
+        log.info("<<<<<<<<换取openid开始<<<<<<<<:{}", data.getCode());
+        WxAppletTools appletTools = new WxAppletTools(wxRestTemplate, wxConfig, redisService);
+        Code2SessionRespBody body = appletTools.getOpenIdByJscode2session(new Code2SessionResqBody().build(data.getCode()));
+        String openid = body.getOpenid();
+        String sessionKey = body.getSessionKey();
+        // 用户信息解密 数据验签
+//        if (StringUtils.isNotBlank(data.getSignature())) {
+//            WxUtils.verifySignature(data.getRawData(), sessionKey, data.getSignature());
+//        }
+        if(StringUtils.isEmpty(data.getEncryptedData()) || StringUtils.isEmpty(data.getIv())){
+            return R.fail("已拒绝授权");
+        }
+        AppletUserDecodeData appletUserDecodeData = WxUtils.encryptedData(data.getEncryptedData(), sessionKey,  data.getIv());
+        appletUserDecodeData.setOpenId(openid);
+        // 先使用openId和当前手机号进行查询
+        TSysAppUser sysAppUser = sysAppUserService.getOne(Wrappers.lambdaQuery(TSysAppUser.class)
+                .and(e->e.eq(TSysAppUser::getOpenId, appletUserDecodeData.getOpenId()).or()
+                        .eq(TSysAppUser::getPhone, appletUserDecodeData.getPhoneNumber())));
+        if (sysAppUser==null){
+            sysAppUser = new TSysAppUser();
+            sysAppUser.setPhone(appletUserDecodeData.getPhoneNumber());
+            sysAppUser.setOpenId(appletUserDecodeData.getOpenId());
+            // 手机号中间四位替换为*
+            sysAppUser.setNickName(appletUserDecodeData.getPhoneNumber().replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2"));
+            sysAppUserService.save(sysAppUser);
+        }else {
+            // 手机号相同但openId为空的情况
+            sysAppUser.setOpenId(appletUserDecodeData.getOpenId());
+        }
+        LoginUserApplet loginUserApplet = new LoginUserApplet();
+        TSysUserResp sysUserResp = new TSysUserResp();
+        BeanUtils.copyProperties(sysAppUser, sysUserResp);
+        loginUserApplet.setUser(sysUserResp);
+        loginUserApplet.setUserId(sysAppUser.getId());
+        Map<String, Object> tokenInfos = new HashMap<>();
+        tokenInfos.put("token",tokenService.createTokenApplet(loginUserApplet));
+        tokenInfos.put("info",loginUserApplet);
+        return R.ok(tokenInfos);
+    }
+
+    @ApiOperation(value = "通过code获得openid",tags = {"微信服务号、公众号登录"})
+    @PostMapping("/openIdByCode")
+    public R<Map<String, Object>> openIdByCode(@RequestBody OfficeUserEncrypteData data) {
+        log.info("<<<<<<<<换取openid开始<<<<<<<<:{}", data.getCode());
+        WxAppletTools appletTools = new WxAppletTools(wxRestTemplate, wxConfig, redisService);
+        Code2SessionRespBody body = appletTools.getOpenIdByJscode2session(new Code2SessionResqBody().build(data.getCode()));
+        String openid = body.getOpenid();
+        String phone = data.getPhone();
+        if(StringUtils.isEmpty(phone)){
+            return R.fail("请输入手机号");
+        }
+        TSysAppUser sysAppUser = sysAppUserService.getOne(Wrappers.lambdaQuery(TSysAppUser.class)
+                        .eq(TSysAppUser::getPhone, phone));
+        if(Objects.nonNull(sysAppUser)){
+            sysAppUser.setOfficeOpenId(openid);
+            sysAppUserService.updateById(sysAppUser);
+        }
+        // 获取诊所信息
+        SysUser sysUser = sysUserService.selectByPhone(phone);
+        if(Objects.nonNull(sysUser) && (sysUser.getRoleType() == 5 || sysUser.getRoleType() == 3)){
+            // 诊所
+            sysUser.setOpenId(openid);
+            sysUserService.updateUserInfo(sysUser);
+        }
+        return R.ok();
     }
 
     /**
@@ -114,7 +216,11 @@
             String code = String.valueOf((int) (Math.random() * 1000000));
             redisCache.setCacheObject(phone, code,5*60,TimeUnit.SECONDS);
             try {
-//                smsUtil.sendSms(phone, "2369926", new String[]{code});
+                TSysMessageTemplate messageTemplate = sysMessageTemplateService.getOne(Wrappers.lambdaQuery(TSysMessageTemplate.class)
+                        .eq(TSysMessageTemplate::getTemplateType, 1));
+                Map<String,String> params = new HashMap<>();
+                params.put("code", code);
+                msgUtils.sendMsg(phone, params, messageTemplate.getTemplateCode());
             } catch (Exception e) {
                 throw new RuntimeException(e);
             }

--
Gitblit v1.7.1