JAVAWEB应用模块(一)登录模块

摘要:
Java背景代码(MD5加密+令牌验证):importcom.smart.ssai.admin.domain。使用者importcom.smart.ssai.admin.service。用户服务;importcom.smart.ssai.VO。回答importcom.smart.ssai.com.mon.utils。结果VOUtil;importcom。

java后台代码(MD5加密+token验证):

import com.smart.ssai.admin.domain.User;
import com.smart.ssai.admin.service.UserService;
import com.smart.ssai.VO.Response;
import com.smart.ssai.common.utils.ResultVOUtil;
import com.smart.ssai.common.utils.ToolUtils;
import com.smart.ssai.constant.TokenConstant;
import io.jsonwebtoken.JwtBuilder;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.Date;
import java.util.HashMap;
import java.util.Map;


@RestController
@RequestMapping("/api")
public class LoginController {

    @Autowired
    private UserService userService;

    /**
     * 用户登录
     * @param username 用户名
     * @param password 密码
     * @return
     */
    @PostMapping("/login")
    public ResponseEntity<Response> login(@RequestParam(value = "username") String username
            , @RequestParam(value = "password") String password){
        User user = userService.getUserByUsername(username);
        //判断用户是否存在
        if(null == user){
            return ResultVOUtil.show(0,"用户不存在,请重新输入",null);
        }
        //判断密码是否正确
        String password1 = ToolUtils.md5Hex(password,String.valueOf(user.getCode()));
        if(!user.getPassword().equals(password1)){
            return ResultVOUtil.show(0,"用户密码错误",null);
        }
        //登录成功,生成token,并更新数据库token和过期时间
        Date date = new Date();
        Integer nowTime = (int)(date.getTime()/1000);//当前时间戳
        String token = createToken(user,date);//token
        User model = new User();
        BeanUtils.copyProperties(user,model);
//        model.setId(user.getId());
        model.setTimeout(nowTime);
        model.setToken(token);
        userService.insert(model);
        //跳转到指定页面,这里不跳转,返回token信息给前端
        Map<String,Object> map = new HashMap<>();
        map.put("token",token);
        return ResultVOUtil.show(1,"登录成功",map);
    }

    /**
     * 生成token,根据有效的用户信息
     * @param user 用户实例
     * @param date 当前日期
     * @return
     */
    private String createToken(User user, Date date){
        SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256;
        JwtBuilder builder = Jwts.builder().setHeaderParam("typ", "JWT")//设置header
                .setHeaderParam("alg", "HS256").setIssuedAt(date)//设置签发时间
                .setExpiration(new Date(date.getTime() + TokenConstant.EXPIRE))//设置过期时间,30天,超出int,要加L
                .claim("userid",String.valueOf(user.getId()))//设置内容
                .setIssuer(TokenConstant.ISSUER)//设置签发人
                .signWith(signatureAlgorithm, TokenConstant.SECRETKEY);//签名,需要算法和key
        String jwt = builder.compact();
        return jwt;
    }
}

免责声明:文章转载自《JAVAWEB应用模块(一)登录模块》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇iOS开发之Blockpython 字典的操作下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

实用向—总结一些唯一ID生成方式

在日常的项目开发中,我们经常会遇到需要生成唯一ID的业务场景,不同的业务对唯一ID的生成方式与要求都会不尽相同,一是生成方式多种多样,如UUID、雪花算法、数据库递增等;其次业务要求上也各有不同,有的只要保证唯一性即可,有的需要加上时间戳,有的要保证按顺序递增等。以下是我结合实际业务中的使用总结了几种唯一ID的生成方式,  要求就是在一般的应用场景下一方面...

幂等设计

最近做的项目的性能调优中关于幂等设计的一些总结 场景:假设有这样一个方法,包含了一些DB操作,check if existing then update else save. 如果两个线程同时去执行这个方法,并且他们处理的是同一条数据,期望应该是其中一个线程是save,另外一个是update。但是有可能线程的处理时间相当重合,线程A在check的时候,线程...

SpringBoot入门 (四) 数据库访问之JdbcTemplate

  本文记录在SpringBoot中使用JdbcTemplate访问数据库。 一 JDBC回顾   最早是在上学时接触的使用JDBC访问数据库,主要有以下几个步骤: 1 加载驱动 Class.forName(Driver) 2 获取数据库连接 conn = DriverManager.getConnection(url, user,password) 3...

c++ string 的函数replace()用法

basic_string::replace 将原string 中的元素或子串替换。返回替换后的string。 (1)用string 或C-string 代替操作string 中从 _Pos1 开始的 _Num1 个字符 basic _ string& replace( size _ type _Pos1 ,size _ type _Num1 ,...

dhtmlxscheduler使用

如何和数据库实现交互?增加,删除,修改? 增加,删除 ,修改的实现需要通过dhtmlxscheduler事件来实现,实现模板如下(注意需要引入prototype.js文件): scheduler.attachEvent("onBeforeEventDelete", function(event_id, event_object){     var url...

java基础知识--日期时间类

1.1 Date类  java.util.Date类 表示特定的瞬间,精确到毫秒。 继续查阅Date类的描述,发现Date拥有多个构造函数,只是部分已经过时,但是其中有未过时的构造函数可以把毫秒值转成日期对象。 public Date():分配Date对象并初始化此对象,以表示分配它的时间(精确到毫秒)。 public Date(long date)...