chen.lin
3 天以前 9140aee230de0ef41de9682a9353fbd372e2bcaa
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
package com.vincent.rsf.server.system.service.impl;
 
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.vincent.rsf.server.system.entity.OpenApiApp;
import com.vincent.rsf.server.system.mapper.OpenApiAppMapper;
import com.vincent.rsf.server.system.service.OpenApiAppService;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.stereotype.Service;
 
import javax.annotation.Resource;
 
@Service
public class OpenApiAppServiceImpl extends ServiceImpl<OpenApiAppMapper, OpenApiApp> implements OpenApiAppService {
 
    @Resource
    private PasswordEncoder passwordEncoder;
 
    @Override
    public boolean save(OpenApiApp entity) {
        encodeScrectIfPlain(entity);
        return super.save(entity);
    }
 
    @Override
    public boolean updateById(OpenApiApp entity) {
        encodeScrectIfPlain(entity);
        return super.updateById(entity);
    }
 
    /** 若为明文则改为 BCrypt 再存库,便于 getToken 时用 BCrypt 校验 */
    private void encodeScrectIfPlain(OpenApiApp entity) {
        if (entity == null) {
            return;
        }
        String s = entity.getScrect();
        if (s == null || s.isEmpty() || s.startsWith("$2")) {
            return;
        }
        entity.setScrect(passwordEncoder.encode(s));
    }
}