建立登入controller
重新開機e3-sso-web
一、登入業務邏輯層
建立登入的interface和service
package cn.e3mall.sso.service.impl;
import java.util.List;
import java.util.UUID;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import org.springframework.util.DigestUtils;
import cn.e3mall.common.jedis.JedisClient;
import cn.e3mall.common.util.E3Result;
import cn.e3mall.common.util.JsonUtils;
import cn.e3mall.mapper.TbUserMapper;
import cn.e3mall.pojo.TbUser;
import cn.e3mall.pojo.TbUserExample;
import cn.e3mall.pojo.TbUserExample.Criteria;
import cn.e3mall.sso.service.LoginService;
@Service
public class LoginServiceImpl implements LoginService {
@Autowired
private TbUserMapper userMapper;
@Autowired
private JedisClient jedisClient;
@Value("${SESSION_EXPIRE}")
private Integer SESSION_EXPIRE;
@Override
public E3Result userLogin(String username, String password) {
// 1、判斷使用者名和密碼是否正确
// 根據使用者名查詢使用者資訊
TbUserExample example = new TbUserExample();
userMapper.selectByExample(example);
Criteria criteria = example.createCriteria();
criteria.andUsernameEqualTo(username);
// 執行查詢
List<TbUser> list = userMapper.selectByExample(example);
if (list == null || list.size() == 0) {
// 傳回登入失敗
return E3Result.build(400, "使用者名或密碼錯誤");
}
// 取使用者資訊
TbUser user = list.get(0);
// 判斷密碼是否正确
if (!DigestUtils.md5DigestAsHex(password.getBytes()).equals(user.getPassword())) {
// 2、如果不正确,傳回登入失敗
return E3Result.build(400, "使用者名或密碼錯誤");
}
// 3、如果正确,生成token
String token = UUID.randomUUID().toString();
// 4、把使用者資訊寫入redis。key:token, value:使用者資訊
user.setPassword(null);
jedisClient.set("SESSION:" + token, JsonUtils.objectToJson(user));
// 5、設定Session的過期時間
jedisClient.expire("SESSION:" + token, SESSION_EXPIRE);
// 6、把token傳回
return E3Result.ok(token);
}
}
二、使用者登入處理-表現層
變現層調用新的dubbo服務
登入方法
測試:
session寫入到了redis。
cookie也儲存了。