java jwt 单点登录_JWT实现单点登录

java jwt 单点登录_JWT实现单点登录importcom.atguigu.commonutils.JwtUtils;importcom.atguigu.commonutils.MD5;importcom.atguigu.eduservice.entity.UcenterMember;importcom.atguigu.eduservice.entity.vo.RegisterVo;importcom.atguigu.edus…

大家好,又见面了,我是你们的朋友全栈君。

import com.atguigu.commonutils.JwtUtils;

import com.atguigu.commonutils.MD5;

import com.atguigu.eduservice.entity.UcenterMember;

import com.atguigu.eduservice.entity.vo.RegisterVo;

import com.atguigu.eduservice.mapper.UcenterMemberMapper;

import com.atguigu.eduservice.service.UcenterMemberService;

import com.atguigu.servicebase.exceptionhandler.GuliException;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;

import org.apache.commons.lang.StringUtils;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.data.redis.core.RedisTemplate;

import org.springframework.stereotype.Service;

/**

*

* 会员表 服务实现类

*

*

* @author testjava

* @since 2020-06-05

*/

@Service

public class UcenterMemberServiceImpl extends ServiceImpl implements UcenterMemberService {

//注入

@Autowired

private RedisTemplate redisTemplate;

//登录的方法

@Override

public String login(UcenterMember member) {

String mobile = member.getMobile();

String password = member.getPassword();

//判断两者是否为空

if (StringUtils.isEmpty(mobile) || StringUtils.isEmpty(password)){

throw new GuliException(20001,”登录失败”);

}

//判断手机号是否正确

QueryWrapper wrapper = new QueryWrapper<>();

wrapper.eq(“mobile”,mobile);

UcenterMember mobilMenber = baseMapper.selectOne(wrapper);

//判断查出来的对象是否为空

if (mobilMenber == null){//没有这个手机号

throw new GuliException(20001,”登录失败手机号不存在”);

}

//判断对应手机号的密码是否正确

//因为存储在数据库中的密码进行了加密, 解决办法:把输入的密码进行加密,在和数据库中的密码比较

//加密方式MD5

if (!MD5.encrypt(password).equals(mobilMenber.getPassword())){

throw new GuliException(20001,”密码错误”);

}

//判断用户是否禁用

if (mobilMenber.getIsDisabled()){

throw new GuliException(20001,”用户名已被禁用”);

}

//登录成功

//生成token字符串,使用JWT做到,传查出来的对象mobilMenber

String jwtToken = JwtUtils.getJwtToken(mobilMenber.getId(), mobilMenber.getNickname());

return jwtToken;

}

//注册

@Override

public void register(RegisterVo registerVo) {

//获取注册的数据

String code = registerVo.getCode();//验证码

String mobile = registerVo.getMobile();//手机号

String nickname = registerVo.getNickname();//昵称

String password = registerVo.getPassword();//密码

//非空判断

if (StringUtils.isEmpty(code) || StringUtils.isEmpty(mobile) || StringUtils.isEmpty(nickname) || StringUtils.isEmpty(password)){

throw new GuliException(20001,”注册失败”);

}

//判断验证码是否正确,跟redis中验证吗是否一样

String rediscode = redisTemplate.opsForValue().get(mobile);

if (!code.equals(rediscode)){

throw new GuliException(20001,”注册失败”);

}

//判断手机号是否重复

QueryWrapper wrapper = new QueryWrapper<>();

wrapper.eq(“mobile”,mobile);

Integer integer = baseMapper.selectCount(wrapper);

if (integer > 0){

throw new GuliException(20001,”注册失败”);

}

//数据添加到数据库中

UcenterMember member = new UcenterMember();

member.setMobile(mobile);

member.setPassword(MD5.encrypt(password));

member.setNickname(nickname);

member.setIsDisabled(false);

member.setAvatar(“http://thirdwx.qlogo.cn/mmopen/vi_32/DYAIOgq83eoj0hHXhgJNOTSOFsS4uZs8x1ConecaVOB8eIl115xmJZcT4oCicvia7wMEufibKtTLqiaJeanU2Lpg3w/132”);

baseMapper.insert(member);

}

@Override

public UcenterMember getOpenIdMember(String openid) {

QueryWrapper wrapper = new QueryWrapper<>();

wrapper.eq(“openid”,openid);

UcenterMember member = baseMapper.selectOne(wrapper);

return member;

}

}

三controller层

packagecom.atguigu.eduservice.controller;importcom.atguigu.commonutils.JwtUtils;importcom.atguigu.commonutils.R;importcom.atguigu.eduservice.entity.UcenterMember;importcom.atguigu.eduservice.entity.vo.RegisterVo;importcom.atguigu.eduservice.service.UcenterMemberService;importorg.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.*;importjavax.servlet.http.HttpServletRequest;/***

* 会员表 前端控制器

*

*

*@authortestjava

*@since2020-06-05*/@RestController

@RequestMapping(“/educenter/member”)

@CrossOriginpublic classUcenterMemberController {

@AutowiredprivateUcenterMemberService memberService;//登录

@PostMapping(“login”)publicR loginUser(@RequestBody UcenterMember member) {//member对象封装手机号和密码//调用service方法实现登录//返回token值,使用jwt生成

String token =memberService.login(member);return R.ok().data(“token”,token);

}//注册

@PostMapping(“register”)publicR registerUser(@RequestBody RegisterVo registerVo) {

memberService.register(registerVo);returnR.ok();

}//根据token获取用户信息

@GetMapping(“getMemberInfo”)publicR getMemberInfo(HttpServletRequest request) {//调用jwt工具类的方法。根据request对象获取头信息,返回用户id

String memberId =JwtUtils.getMemberIdByJwtToken(request);//查询数据库根据用户id获取用户信息

UcenterMember member =memberService.getById(memberId);return R.ok().data(“userInfo”,member);

}

}

四前端调用方法获得token

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/143368.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 计算机清理垃圾代码,你也可以写代码系列,一键清除系统垃圾文件的代码(超简单)-清除垃圾文件…

    计算机清理垃圾代码,你也可以写代码系列,一键清除系统垃圾文件的代码(超简单)-清除垃圾文件…电脑使用久了,系统或者软件就会产生大量的日志文件、临时文件等垃圾文件。这些垃圾文件日积月累,不仅会大量占用磁盘空间,也会严重拖慢系统运行速度。所以定时清理垃圾文件十分有必要。我们可以手动删除,也可以借助本文提供的批处理自动删除。1,创建一个清除垃圾的.bat文件(1)在桌面上单击鼠标右键,选择“新建”选择“文本文档”(2)将新建的文件改名为“垃圾文件清除.bat”(注意.txt后缀要记得删掉)…

  • Python优秀开源项目Rich源码解析

    Python优秀开源项目Rich源码解析这篇文章对优秀的开源项目Rich的源码进行解析,OMG,盘他。为什么建议阅读源码,有两个原因,第一,单纯学语言很难在实践中灵活应用,通过阅读源码可以看到每个知识点的运用场景,印象会更深,以后写代码的时

  • 50个多线程面试题,你会多少?(一)[通俗易懂]

    50个多线程面试题,你会多少?(一)[通俗易懂]下面是Java线程相关的热门面试题,你可以用它来好好准备面试。什么是线程? 什么是线程安全和线程不安全? 什么是自旋锁? 什么是Java内存模型? 什么是CAS? 什么是乐观锁和悲观锁? 什么是AQS? 什么是原子操作?在JavaConcurrencyAPI中有哪些原子类(atomicclasses)? 什么是Executors框架? 什么是阻塞队列?如何使用阻塞队列来…

  • 网站被恶意刷流量解决方案

    网站被恶意刷流量解决方案很多站长朋友可能会经常遇到被同行竞争对手恶意刷流量的情况,而且流量ip来路是随机的,全国各地乃至全世界的ip都有,根本没办法查出来是谁干的。一般出现这种情况都是对方用流量宝或者流量精灵来刷你网站的,目的很明显,对方要么就是用这些垃圾流量来掩盖自己的ip,从而达到攻击入侵等不可告人的目的,要么就是想用恶意刷流量的方式让你合作的广告联盟帐号被封禁。大部分站长都会对此束手无策,有些甚至被吓得撤下广告,关…

  • 阿里云如何申请免费ssl证书_https证书部署

    阿里云如何申请免费ssl证书_https证书部署本文SSL证书相关申请管理员扫描微信公众号方式登录:https://cloud.tencent.com工作台->搜索SSL证书->申请免费证书部署申请完毕后,在列表下载证书,解压后找到tomcat文件夹,有两个文件keystorePass.txt存放秘钥,www.njpingpang.com.jks为证书。把www.njpingpang.com.jks证书放入服务器tomcat/conf文件夹下。更改server.xml文件keystorePass:keystore

  • Android退出APP 并杀掉相关的所有进程

    Android退出APP 并杀掉相关的所有进程代码如下:ActivityManagermActivityManager=(ActivityManager)AppApplication.getInstance().getSystemService(Context.ACTIVITY_SERVICE);List<ActivityManager.RunningAppProcessInfo>m…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号