liusheng
8 天以前 c111e3eff1191b29d2d2baf2f485a4bf3a2edc00
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
package com.ruoyi.web.controller.system;
 
import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.Random;
import java.util.Set;
import java.util.concurrent.TimeUnit;
 
import com.ruoyi.common.core.redis.RedisCache;
import com.ruoyi.system.mapper.SysUserMapper;
import com.smartor.domain.BaseSmsRequest;
import com.smartor.service.IBaseSmsaccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import com.ruoyi.common.constant.Constants;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.domain.entity.SysMenu;
import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.core.domain.model.LoginBody;
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 javax.servlet.http.HttpServletResponse;
 
/**
 * 登录验证
 *
 * @author ruoyi
 */
@RestController
public class SysLoginController {
    @Autowired
    private SysLoginService loginService;
 
    @Autowired
    private ISysMenuService menuService;
 
    @Autowired
    private SysPermissionService permissionService;
 
    @Autowired
    private SysUserMapper sysUserMapper;
 
    @Autowired
    private RedisCache redisCache;
 
    @Autowired
    private IBaseSmsaccountService baseSmsaccountService;
 
 
    @Value("${spring.profiles.active}")
    private String active;
 
 
    /**
     * 登录方法
     *
     * @param loginBody 登录信息
     * @return 结果
     */
    @PostMapping("/login")
    public AjaxResult login(@RequestBody LoginBody loginBody) {
        AjaxResult ajax = AjaxResult.success();
        String token = null;
        if (loginBody.getPhoneCode() != null) {
            String phone = redisCache.getCacheObject(loginBody.getPhoneCode());
            token = loginService.loginByPhone(phone);
        } else {
            // 生成令牌
            token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(), loginBody.getUuid());
        }
        ajax.put(Constants.TOKEN, token);
        return ajax;
    }
 
    @GetMapping("/getToken")
    public void getToken(HttpServletResponse response) throws IOException {
        // 生成或获取token
        String token = "eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6IjRiZGRkMTI0LTViNWMtNDhmMC05YjNkLTA0YjFiMzU0Nzg5NSJ9.16hHNas7jXTlHVrnlZgAJ-YViD44YkKFuoxJxMPm5QLPeSHn3wRyd9xE0Bi7YMdO3zKcZNo6ef5diZvDWN7ImA";
        // 设置响应头,前端可以从响应头获取token
        response.addHeader("Authorization", "Bearer " + token);
 
        // 如果需要进行页面跳转,可以设置状态码为302,并设置Location头部
        response.setStatus(302);
        response.setHeader("Location", "http://localhost:8099/tool/module/classifythreea");
    }
 
    /**
     * 获取用户信息
     *
     * @return 用户信息
     */
    @GetMapping("/getInfo")
    public AjaxResult getInfo() {
        SysUser user = SecurityUtils.getLoginUser().getUser();
        SysUser user1 = new SysUser();
        user1.setUserId(user.getUserId());
        SysUser sysUserInfo = sysUserMapper.getSysUserInfo(user1);
        // 角色集合
        Set<String> roles = permissionService.getRolePermission(user);
        // 权限集合
        Set<String> permissions = permissionService.getMenuPermission(user);
        AjaxResult ajax = AjaxResult.success();
        ajax.put("user", user);
        ajax.put("roles", roles);
        ajax.put("permissions", permissions);
        ajax.put("idcard", sysUserInfo.getIdCard());
        return ajax;
    }
 
    /**
     * 获取路由信息
     *
     * @return 路由信息
     */
    @GetMapping("getRouters")
    public AjaxResult getRouters() {
        Long userId = SecurityUtils.getUserId();
        List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
        return AjaxResult.success(menuService.buildMenus(menus));
    }
 
    /**
     * 验证码发送
     *
     * @param payload
     * @return
     */
    @PostMapping("/phoneLogin")
    public AjaxResult sendCode(@RequestBody Map<String, String> payload) {
        String phone = payload.get("phone");
        String code = String.format("%06d", new Random().nextInt(999999));
 
        // 存入 Redis,有效期2分钟
        redisCache.setCacheObject(code, phone, 2, TimeUnit.MINUTES);
 
        //无锡线上环境才发短信
        if (active.equals("wx")) {
            BaseSmsRequest baseSmsRequest = new BaseSmsRequest();
            baseSmsRequest.setPhoneNumber(phone);
            baseSmsRequest.setContent("登陆验证码:" + code + " ,2分钟内效,切勿将验证码提供给他人,谨防被骗。");
            baseSmsaccountService.sendMsg(baseSmsRequest);
        }
        // 调用短信服务发送验证码
        System.out.println("登陆验证码:" + code);
 
        return AjaxResult.success(true);
    }
}