热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SSM示例

User实体类packagecom.itheima.domain;importjava.io.Serializable;publicclassUserimplementsSeria

User 实体类


package com.itheima.domain; import java.io.Serializable; public class User implements Serializable { private Integer id; //用户id private String name; //用户名称 private String password; //用户密码 private String email; //用户邮箱(用户账号) private String role; //用户角色 private String status; //用户状态 // get, set ...... }

 

UserMapper


package com.itheima.mapper; import com.itheima.domain.User; import org.apache.ibatis.annotations.Result; import org.apache.ibatis.annotations.Results; import org.apache.ibatis.annotations.Select; public interface UserMapper{ @Select("select * from user where user_email=#{email} AND user_password=#{password} AND user_status!='1'") @Results(id = "userMap",value = { //id字段默认为false,表示不是主键 //column表示数据库表字段,property表示实体类属性名。 @Result(id = true,column = "user_id",property = "id"), @Result(column = "user_name",property = "name"), @Result(column = "user_password",property = "password"), @Result(column = "user_email",property = "email"), @Result(column = "user_role",property = "role"), @Result(column = "user_status",property = "status") }) User login(User user); }

 

 

UserService 接口


package com.itheima.service; import com.itheima.domain.User; /** *用户接口 */ public interface UserService{ //通过User的用户账号和用户密码查询用户信息 User login(User user); }

 

UserService 接口实现


package com.itheima.service.impl; import com.itheima.domain.User; import com.itheima.mapper.UserMapper; import com.itheima.service.UserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; /** *用户接口实现类 */ @Service public class UserServiceImpl implements UserService { //注入userMapper @Autowired private UserMapper userMapper; //通过User的用户账号和用户密码查询用户信息 @Override public User login(User user) { return userMapper.login(user); } }

 MyBatis-Spring 提供了一个动态代理的实现——MapperFactoryBean。这个类可以让你直接注入数据映射器接口到你的 service 层bean 中。当使用映射器时,你仅仅如调用你的 DAO 一样调用它们就可以了,但是你不需要编写任何 DAO 实现的代码,因为 MyBatis-Spring将会为你创建代理。同样,MapperFactoryBean创建的代理控制开放和关闭 session

 

UserController


package com.itheima.controller; import com.itheima.domain.User; import com.itheima.service.UserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; /** * 用户登录和注销Controller */ @Controller public class UserController { @RequestMapping("/toMainPage") public String toMainPage(){ return "main"; } //注入userService @Autowired private UserService userService; /* 用户登录 */ @RequestMapping("/login") public String login(User user, HttpServletRequest request){ try { User u=userService.login(user); /* 用户账号和密码是否查询出用户信息 是:将用户信息存入Session,并跳转到后台首页 否:Request域中添加提示信息,并转发到登录页面 */ if(u!=null){ request.getSession().setAttribute("USER_SESSION",u); return "redirect:/admin/main.jsp"; } request.setAttribute("msg","用户名或密码错误"); return "forward:/admin/login.jsp"; }catch(Exception e){ e.printStackTrace(); request.setAttribute("msg","系统错误"); return "forward:/admin/login.jsp"; } } }

 




推荐阅读
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 本文详细介绍了 MySQL 中 LAST_INSERT_ID() 函数的使用方法及其工作原理,包括如何获取最后一个插入记录的自增 ID、多行插入时的行为以及在不同客户端环境下的表现。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
author-avatar
烟灰TT
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有