基于javaweb+mysql的springboot人脸识别登录系统(java+springboot+maven+mysql)

基于javaweb+mysql的springboot人脸识别登录系统(java+springboot+maven+mysql)

运行环境

Java≥8、MySQL≥5.7

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的SpringBoot人脸识别登录系统(java+springboot+maven+mysql)

实现的功能有:

管理员后台录入人脸信息、前台用户登录时选择人脸识别方式登录。

PS:用到了百度人脸识别的API接口,包括人脸检测、人脸识别对比等。

		BeanUtils.copyProperties(user, findById, "id","createTime","updateTime");
		if(userService.save(findById) == null){
			return Result.error(CodeMsg.ADMIN_USE_EDIT_ERROR);
		}
		operaterLogService.add("编辑用户,用户名:" + user.getUsername());
		return Result.success(true);
	}
	
	/**
	 * 删除用户
	 * @param id
	 * @return
	 */
	@RequestMapping(value="/delete",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
		try {
			userService.delete(id);
		} catch (Exception e) {
			return Result.error(CodeMsg.ADMIN_USE_DELETE_ERROR);
		}
		operaterLogService.add("添加用户,用户ID:" + id);
		return Result.success(true);
	}
}

/**
 * 项目通用工具类
 *
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			return false;
		}
		log.info("该请求符合权限要求,放行" + requestURI);
		return true;
	}
}

/**
 * session统一操作工具类
 *
 */
public class SessionUtil {

	/**
	 * 获取请求request
	 * @return
	 */
	public static HttpServletRequest getRequest(){
		ServletRequestAttributes attributes =(ServletRequestAttributes)RequestContextHolder.getRequestAttributes();
		return attributes == null ? null : attributes.getRequest();
	}
	
	/**
	 * 获取session
	 * @return
	 */
	public static HttpSession getSession(){
		HttpServletRequest request = getRequest();
		if(request != null){
                while ((buf = bufferedReader.readLine()) != null) {
                    string += buf;
                }
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } finally {
                try {
                    bufferedReader.close();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        } catch (Exception e) {
            // TODO: handle exception
        }
        return string;
    }

    /**
     * 获取指定格式时间再指定分钟后的时间字符串
     *
     * @param date
     * @param formatter
     * @param minites
     * @return
     */
    public static String getFormatterDate(String date, String formatter, int minites) {
        SimpleDateFormat sdf = new SimpleDateFormat(formatter);
        String ret = null;
        try {
            Date parse = sdf.parse(date);
            Calendar calendar = Calendar.getInstance();
            calendar.setTime(parse);
            calendar.add(Calendar.MINUTE, minites);
            ret = sdf.format(calendar.getTime());
        } catch (ParseException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return ret;
    }

    /**
     * 获取指定分钟前的时间
	@RequestMapping(value="/add",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> add(User user){
		//用统一验证实体方法验证是否合法
		CodeMsg validate = ValidateEntityUtil.validate(user);
		if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
			return Result.error(validate);
		}
		if(user.getRole() == null || user.getRole().getId() == null){
			return Result.error(CodeMsg.ADMIN_USER_ROLE_EMPTY);
		}
		//判断用户名是否存在
		if(userService.isExistUsername(user.getUsername(), 0l)){
			return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
		}
		//到这说明一切符合条件,进行数据库新增
		if(userService.save(user) == null){
			return Result.error(CodeMsg.ADMIN_USE_ADD_ERROR);
		}
		operaterLogService.add("添加用户,用户名:" + user.getUsername());
		return Result.success(true);
	}
	
	/**
	 * 用户编辑页面
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.GET)
	public String edit(Model model,@RequestParam(name="id",required=true)Long id){
		model.addAttribute("roles", roleService.findAll());
		model.addAttribute("user", userService.find(id));
		return "admin/user/edit";
	}
	
	/**
	 * 编辑用户信息表单提交处理
	 * @param user
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> edit(User user){
		//用统一验证实体方法验证是否合法
		CodeMsg validate = ValidateEntityUtil.validate(user);
		if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
			return Result.error(validate);
		}
		if(user.getRole() == null || user.getRole().getId() == null){
			return Result.error(CodeMsg.ADMIN_USER_ROLE_EMPTY);
		}
		if(user.getId() == null || user.getId().longValue() <= 0){
			return Result.error(CodeMsg.ADMIN_USE_NO_EXIST);
		}
        OrderAuth orderAuth = new OrderAuth();
        orderAuth.setMac(StringUtil.getMac());
        orderAuth.setOrderSn(orderSn);
        orderAuth.setPhone(phone);
        orderAuthService.save(orderAuth);
        AppConfig.ORDER_AUTH = 1;
        return Result.success(true);
    }

    /**
     * 清空整个日志
     *
     * @return
     */
    @RequestMapping(value = "/delete_all_operator_log", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> deleteAll() {
        operaterLogService.deleteAll();
        return Result.success(true);
    }
}

/**
 * 后台用户管理控制器
 *
 */
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

/**
 * 权限统一管理拦截器
 *
 */
@Component
public class AuthorityInterceptor implements HandlerInterceptor{

	private Logger log = LoggerFactory.getLogger(AuthorityInterceptor.class);
	
	@Override
	public boolean  preHandle(HttpServletRequest request, HttpServletResponse response, Object handler){
		String requestURI = request.getRequestURI();
		User loginedUser = SessionUtil.getLoginedUser();
		log.info("进入权限控制拦截器" + requestURI);
		List<Menu> authorities = loginedUser.getRole().getAuthorities();
		if(!MenuUtil.isExistUrl(requestURI, authorities)){
			//进入这里,表示权限不存在,首先判断是否是ajax请求
			if(StringUtil.isAjax(request)){
				//表示是ajax请求
				try {
					log.info("该请求无权限,已ajax方式返回提示,url=" + requestURI);
					response.setCharacterEncoding("UTF-8");

    /**
     * 修改用户个人信息
     *
     * @return
     */
    @RequestMapping(value = "/update_userinfo", method = RequestMethod.GET)
    public String updateUserInfo() {
        return "admin/system/update_userinfo";
    }

    /**
     * 修改个人信息保存
     *
     * @param user
     * @return
     */
    @RequestMapping(value = "/update_userinfo", method = RequestMethod.POST)
    public String updateUserInfo(User user) {
        User loginedUser = SessionUtil.getLoginedUser();
        loginedUser.setEmail(user.getEmail());
        loginedUser.setMobile(user.getMobile());
        loginedUser.setHeadPic(user.getHeadPic());
        //首先保存到数据库
        userService.save(loginedUser);
        //更新session里的值
        SessionUtil.set(SessionConstant.SESSION_USER_LOGIN_KEY, loginedUser);
        return "redirect:update_userinfo";
    }

    /**
     * 修改密码页面
     *
     * @return
     */
    @RequestMapping(value = "/update_pwd", method = RequestMethod.GET)
    public String updatePwd() {
        return "admin/system/update_pwd";
    }

    /**
     * 修改密码表单提交
     *
     * @param oldPwd
     * @param newPwd
     * @return
		}
		existRole.setName(role.getName());
		existRole.setRemark(role.getRemark());
		existRole.setStatus(role.getStatus());
		existRole.setAuthorities(role.getAuthorities());
		if(roleService.save(existRole) == null){
			return Result.error(CodeMsg.ADMIN_ROLE_EDIT_ERROR);
		}
		log.info("编辑角色【"+role+"】");
		operaterLogService.add("编辑角色【"+role.getName()+"】");
		return Result.success(true);
	}
	
	/**
	 * 删除角色
	 * @param request
	 * @param id
	 * @return
	 */
	@RequestMapping(value="delete",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
		try {
			roleService.delete(id);
		} catch (Exception e) {
			// TODO: handle exception
			return Result.error(CodeMsg.ADMIN_ROLE_DELETE_ERROR);
		}
		log.info("编辑角色ID【"+id+"】");
		operaterLogService.add("删除角色ID【"+id+"】");
		return Result.success(true);
	}
}

		HttpSession session = getSession();
		if(session != null){
			session.setAttribute(key,object);
		}
	}
	
	/**
	 * 获取当前登录的用户
	 * @return
	 */
	public static User getLoginedUser(){
		HttpSession session = getSession();
		if(session != null){
			Object attribute = session.getAttribute(SessionConstant.SESSION_USER_LOGIN_KEY);
			return attribute == null ? null : (User)attribute;
		}
		return null;
	}
}
/**
 * 图片统一查看控制器
 */

@RequestMapping("photo")
@Controller
public class PhotoController {
	
	@Autowired
	private ResourceLoader resourceLoader;
	
	@Value("${ylrc.upload.photo.path}")
	private String uploadPhotoPath;//文件保存位置
	
	/**
	 * 系统统一的图片查看方法
	 * @param filename
	 * @return
	 */
	@RequestMapping(value="/view")
	@ResponseBody
	public ResponseEntity<?> viewPhoto(@RequestParam(name="filename",required=true)String filename){
		Resource resource = resourceLoader.getResource("file:" + uploadPhotoPath + filename); 
		try {
			return ResponseEntity.ok(resource);
 *
 */
@Controller
@RequestMapping("/cpacha")
public class CpachaController {

	private Logger log = LoggerFactory.getLogger(CpachaController.class);
	
	/**
	 * 通用验证码生成器
	 * @param vcodeLength
	 * @param fontSize
	 * @param width
	 * @param height
	 * @param method
	 * @param request
	 * @param response
	 */
	@RequestMapping(value="/generate_cpacha",method=RequestMethod.GET)
	public void generateCpacha(
			@RequestParam(name="vl",defaultValue="4")Integer vcodeLength,//vcodeLength,验证码长度
			@RequestParam(name="fs",defaultValue="21")Integer fontSize,//fontSize,验证码字体大小
			@RequestParam(name="w",defaultValue="98")Integer width,//width,图片宽度
			@RequestParam(name="h",defaultValue="33")Integer height,//height,图片高度
			@RequestParam(name="method",defaultValue="admin_login")String method,//用来调用此方法的名称,以此名称为键,存入到session中
			HttpServletRequest request,
			HttpServletResponse response){
		CpachaUtil cpachaUtil = new CpachaUtil(vcodeLength,fontSize,width,height);
		String generatorVCode = cpachaUtil.generatorVCode();
		//将生成的验证码放入session,以供放后面程序的验证使用
		request.getSession().setAttribute(method, generatorVCode);
		log.info("验证码成功生成,method=" + method + ",value=" + generatorVCode);
		try {
			ImageIO.write(cpachaUtil.generatorRotateVCodeImage(generatorVCode, true), "gif", response.getOutputStream());
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}


/**
 * 项目通用工具类
 *
 */
public class StringUtil {

    /**
     * 返回指定格式的日期字符串
     *
     * @param date
     * @param formatter
     * @return
     */
    public static String getFormatterDate(Date date, String formatter) {
        SimpleDateFormat sdf = new SimpleDateFormat(formatter);
        return sdf.format(date);
    }

    /**
     * 判断请求是否是ajax
     *
     * @param request
     * @return
     */
    public static boolean isAjax(HttpServletRequest request) {
        String header = request.getHeader("X-Requested-With");
        if ("XMLHttpRequest".equals(header)) return true;
        return false;
    }

    /**
     * 从流读取字符串
     *
     * @param inputStream
     * @return
     */
        User loginedUser = SessionUtil.getLoginedUser();
        loginedUser.setEmail(user.getEmail());
        loginedUser.setMobile(user.getMobile());
        loginedUser.setHeadPic(user.getHeadPic());
        //首先保存到数据库
        userService.save(loginedUser);
        //更新session里的值
        SessionUtil.set(SessionConstant.SESSION_USER_LOGIN_KEY, loginedUser);
        return "redirect:update_userinfo";
    }

    /**
     * 修改密码页面
     *
     * @return
     */
    @RequestMapping(value = "/update_pwd", method = RequestMethod.GET)
    public String updatePwd() {
        return "admin/system/update_pwd";
    }

    /**
     * 修改密码表单提交
     *
     * @param oldPwd
     * @param newPwd
     * @return
     */
    @RequestMapping(value = "/update_pwd", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> updatePwd(@RequestParam(name = "oldPwd", required = true) String oldPwd,
                                     @RequestParam(name = "newPwd", required = true) String newPwd
    ) {
        User loginedUser = SessionUtil.getLoginedUser();
        if (!loginedUser.getPassword().equals(oldPwd)) {
            return Result.error(CodeMsg.ADMIN_USER_UPDATE_PWD_ERROR);
        }
        if (StringUtils.isEmpty(newPwd)) {
            return Result.error(CodeMsg.ADMIN_USER_UPDATE_PWD_EMPTY);
        }
        loginedUser.setPassword(newPwd);
        //保存数据库
        userService.save(loginedUser);
        //更新session
        SessionUtil.set(SessionConstant.SESSION_USER_LOGIN_KEY, loginedUser);
        return Result.success(true);
    }

    /**
     * 日志管理列表
     * @return
     */
    @RequestMapping(value = "/face_login", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> faceLogin(@RequestParam(name = "username", required = true) String username, @RequestParam(name = "face", required = true) String face) {
        User user = userService.findByUsername(username);
        //判断是否为空
        if (user == null) {
            return Result.error(CodeMsg.ADMIN_USERNAME_NO_EXIST);
        }
        if (StringUtils.isEmpty(user.getFace())) {
            return Result.error(CodeMsg.ADMIN_USER_FACE_EMPTY);
        }
        //判断用户状态是否可用
        if (user.getStatus() == User.ADMIN_USER_STATUS_UNABLE) {
            return Result.error(CodeMsg.ADMIN_USER_UNABLE);
        }
        //检查用户所属角色状态是否可用
        if (user.getRole() == null || user.getRole().getStatus() == Role.ADMIN_ROLE_STATUS_UNABLE) {
            return Result.error(CodeMsg.ADMIN_USER_ROLE_UNABLE);
        }
        //检查用户所属角色的权限是否存在
        if (user.getRole().getAuthorities() == null || user.getRole().getAuthorities().size() == 0) {
            return Result.error(CodeMsg.ADMIN_USER_ROLE_AUTHORITES_EMPTY);
        }
        //此处调用百度api接口对比两张人脸相似度
        String faceMatch = BaiduApi.faceMatch(user.getFace(), face);
        log.info(faceMatch);
        JSONObject parseObject = JSONObject.parseObject(faceMatch);
        if (parseObject.getIntValue("error_code") != 0) {
            CodeMsg codeMsg = CodeMsg.DATA_ERROR;
            codeMsg.setMsg(parseObject.getString("error_msg"));
            return Result.error(codeMsg);
        }
        //此处判断人脸可信度
        JSONObject result = parseObject.getJSONObject("result");
        if (result.getBigDecimal("score").compareTo(new BigDecimal(80)) < 0) {
            return Result.error(CodeMsg.ADMIN_USER_FACE_NOT_MATCH);
        }
        //检查一切符合,可以登录,将用户信息存放至session
        SessionUtil.set(SessionConstant.SESSION_USER_LOGIN_KEY, user);
        //将登陆记录写入日志库
        operaterLogService.add("用户【" + user.getUsername() + "】于【" + StringUtil.getFormatterDate(new Date(), "yyyy-MM-dd HH:mm:ss") + "】人脸识别登录系统!");
        log.info("用户成功登录,user = " + user);
        return Result.success(true);
    }

    /**
     * 人脸登录检查
     *
     * @param username
     * @return
		//用统一验证实体方法验证是否合法
		CodeMsg validate = ValidateEntityUtil.validate(role);
		if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
			return Result.error(validate);
		}
		if(roleService.save(role) == null){
			return Result.error(CodeMsg.ADMIN_ROLE_ADD_ERROR);
		}
		log.info("添加角色【"+role+"】");
		operaterLogService.add("添加角色【"+role.getName()+"】");
		return Result.success(true);
	}
	
	/**
	 * 角色编辑页面
	 * @param id
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.GET)
	public String edit(@RequestParam(name="id",required=true)Long id,Model model){
		List<Menu> findAll = menuService.findAll();
		model.addAttribute("topMenus",MenuUtil.getTopMenus(findAll));
		model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
		model.addAttribute("thirdMenus",MenuUtil.getThirdMenus(findAll));
		Role role = roleService.find(id);
		model.addAttribute("role", role);
		model.addAttribute("authorities",JSONArray.toJSON(role.getAuthorities()).toString());
		return "admin/role/edit";
	}
	
	/**
	 * 角色修改表单提交处理
	 * @param request
	 * @param role
	 * @return
	 */
	@RequestMapping(value="/edit",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> edit(Role role){
		//用统一验证实体方法验证是否合法
		CodeMsg validate = ValidateEntityUtil.validate(role);
		if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
			return Result.error(validate);
		}
		Role existRole = roleService.find(role.getId());
		if(existRole == null){
			return Result.error(CodeMsg.ADMIN_ROLE_NO_EXIST);
		}
		existRole.setName(role.getName());
		existRole.setRemark(role.getRemark());
		}
		log.info("编辑角色【"+role+"】");
		operaterLogService.add("编辑角色【"+role.getName()+"】");
		return Result.success(true);
	}
	
	/**
	 * 删除角色
	 * @param request
	 * @param id
	 * @return
	 */
	@RequestMapping(value="delete",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
		try {
			roleService.delete(id);
		} catch (Exception e) {
			// TODO: handle exception
			return Result.error(CodeMsg.ADMIN_ROLE_DELETE_ERROR);
		}
		log.info("编辑角色ID【"+id+"】");
		operaterLogService.add("删除角色ID【"+id+"】");
		return Result.success(true);
	}
}

     * @return
     */
    @RequestMapping(value = "/logout")
    public String logout() {
        User loginedUser = SessionUtil.getLoginedUser();
        if (loginedUser != null) {
            SessionUtil.set(SessionConstant.SESSION_USER_LOGIN_KEY, null);
        }
        return "redirect:login";
    }

    /**
     * 无权限提示页面
     *
     * @return
     */
    @RequestMapping(value = "/no_right")
    public String noRight() {
        return "admin/system/no_right";
    }

    /**
     * 修改用户个人信息
     *
     * @return
     */
    @RequestMapping(value = "/update_userinfo", method = RequestMethod.GET)
    public String updateUserInfo() {
        return "admin/system/update_userinfo";
    }

    /**
     * 修改个人信息保存
     *
     * @param user
     * @return
     */
    @RequestMapping(value = "/update_userinfo", method = RequestMethod.POST)
    public String updateUserInfo(User user) {
        User loginedUser = SessionUtil.getLoginedUser();
        loginedUser.setEmail(user.getEmail());
        loginedUser.setMobile(user.getMobile());
        loginedUser.setHeadPic(user.getHeadPic());
        //首先保存到数据库
        userService.save(loginedUser);
        //更新session里的值
        SessionUtil.set(SessionConstant.SESSION_USER_LOGIN_KEY, loginedUser);
        return "redirect:update_userinfo";
    }
	private MenuService menuService;
	
	@Autowired
	private OperaterLogService operaterLogService;
	
	/**
	 * 菜单列表展示页面
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/list")
	public String list(Model model){
		List<Menu> findAll = menuService.findAll();
		model.addAttribute("title","菜单列表");
		model.addAttribute("topMenus",MenuUtil.getTopMenus(findAll));
		model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
		model.addAttribute("thirdMenus",MenuUtil.getThirdMenus(findAll));
		return "admin/menu/list";
	}
	
	/**
	 * 菜单添加页面
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/add",method=RequestMethod.GET)
	public String add(Model model){
		List<Menu> findAll = menuService.findAll();
		model.addAttribute("title","菜单列表");
		model.addAttribute("topMenus",MenuUtil.getTopMenus(findAll));
		model.addAttribute("secondMenus",MenuUtil.getSecondMenus(findAll));
		return "admin/menu/add";
	}
	
	/**
	 * 菜单添加提交表单处理
	 * @param menu
	 * @return
	 */
	@RequestMapping(value="/add",method=RequestMethod.POST)
	@ResponseBody

请添加图片描述
请添加图片描述
请添加图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值