基础登录功能

本文介绍了使用SpringBoot框架开发的一个登录控制器,包括Emp实体类、EmpService接口、EmpServiceImpl实现以及EmpMapper接口,展示了如何处理员工登录验证、数据库操作如分页查询和CRUD功能。
摘要由CSDN通过智能技术生成

基础登录功能

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

package com.itheima.controller;


import com.itheima.pojo.Emp;
import com.itheima.pojo.Result;
import com.itheima.service.EmpService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
@Slf4j
public class LoginController {
    @Autowired
    private EmpService empService;

    @PostMapping("/login")
    public Result login(@RequestBody Emp emp) {
        log.info("这是员工登录");
        Emp emp1 = empService.login(emp);
        return emp1 != null ? Result.success() : Result.error("用户名或者密码错误");

    }

}

在这里插入图片描述

package com.itheima.service;


import com.itheima.pojo.Emp;
import com.itheima.pojo.PageBean;

import java.time.LocalDate;
import java.util.List;

public interface EmpService {


    /*批量删除员工*/
    void delete(List<Integer> ids);

    /*分页查询*/
    PageBean page(Integer page, Integer pageSiz, String name, Short gender, LocalDate begin, LocalDate end);

    /*新增员工*/
    void insert(Emp emp);

    /*根据id查询员工*/
    Emp getById(Integer id);
    /*修改员工*/
    void update(Emp emp);

    Emp login(Emp emp);
}

在这里插入图片描述

package com.itheima.service.impl;

import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import com.itheima.mapper.EmpMapper;
import com.itheima.pojo.Emp;
import com.itheima.pojo.PageBean;
import com.itheima.service.EmpService;
import org.springframework.beans.factory.BeanNameAware;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.List;

@Service
public class EmpServiceImpl implements EmpService {
    @Autowired
    private EmpMapper empMapper;


    /*批量删除员工*/
    @Override
    public void delete(List<Integer> ids) {
        empMapper.delete(ids);
    }

    /*分页查询*/

    @Override
    public PageBean page(Integer page, Integer pageSize, String name, Short gender, LocalDate begin, LocalDate end) {
        PageHelper.startPage(page, pageSize);
        List<Emp> empList = empMapper.list(page, pageSize, name, gender, begin, end);
        Page<Emp> p = (Page<Emp>) empList;
        return new PageBean(p.getTotal(), p.getResult());
    }


    /*新增员工*/

    @Override
    public void insert(Emp emp) {
        emp.setCreateTime(LocalDateTime.now());
        emp.setUpdateTime(LocalDateTime.now());
        empMapper.insert(emp);
    }


    /*根据id查询员工*/
    @Override
    public Emp getById(Integer id) {
        Emp emp = empMapper.getById(id);
        return emp;
    }

    /*修改员工*/
    @Override
    public void update(Emp emp) {
        emp.setUpdateTime(LocalDateTime.now());
        empMapper.update(emp);
    }

    @Override
    public Emp login(Emp emp) {
        Emp emp1 = empMapper.getByUsernameAndPassword(emp);
        return emp1;
    }

}

在这里插入图片描述

package com.itheima.mapper;


import com.fasterxml.jackson.datatype.jsr310.deser.InstantDeserializer;
import com.itheima.pojo.Emp;
import com.itheima.pojo.PageBean;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.time.LocalDate;
import java.util.List;

@Mapper
public interface EmpMapper {
    /*获取总记录数*/
    @Select("select count(*) from emp")
    Long count();

    /*分页查询,获取列表数据*/
    @Select("select * from emp limit #{start},#{pageSize}")
    List<Emp> page(Integer start, Integer pageSize);

    /*批量删除员工*/
    void delete(List<Integer> ids);

    /*分页查询*/


    List<Emp> list(Integer page, Integer pageSize, String name, Short gender, LocalDate begin, LocalDate end);

    /*新增员工*/
    @Insert("insert into emp (username, name, gender, image, job, entrydate, dept_id, create_time, update_time) value (#{username},#{name},#{gender},#{image},#{job},#{entrydate},#{deptId},#{createTime},#{updateTime})")
    void insert(Emp emp);

    /*根据id查询员工*/
    @Select("select * from emp where id =#{id}")
    Emp getById(Integer id);

    /*修改员工*/
    void update(Emp emp);



    /*根据用户名和密码查询用户*/
    @Select("select * from emp where username =#{username} and password =#{password}")
    Emp getByUsernameAndPassword(Emp emp);
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zkzap

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值