MyBatis实现简单的登录验证功能

利用MyBatis实现简单的登录功能,关键在于构建出MyBatis骨架,并在UserController添加相对应的代码,实现用户登录验证的逻辑。

MyBatis骨架

在这里插入图片描述

IndexController.java

**
 * 登录接口
 *
 * @param model
 * @param loginData JSON格式的登录信息,可以使用Java类描述,也可以使用Map
 * @return
 */
@RequestMapping(value = {"login.json"})
@ResponseBody
public BaseResult login(HttpServletRequest request,Model model, @RequestBody Map<String, Object> loginData

) {
    //TODO: 从loginData中获取账号和密码,进行验证,根据验证结果返回信息
    BaseResult baseResult=null;
    String name=loginData.get("loginName").toString();
    User u = userService.Sel(name);
    if(u != null){
        //从数据库中获取的密码
        String ps = u.getPassWord();
        //从表单中获取的密码
        String psFromForm = loginData.get("loginPwd").toString();
        System.out.println("user:........"+u.toString());
        if(ps.equals(psFromForm)){
            baseResult = new BaseResult();
            baseResult.setSuccess(true);
            request.getSession().setAttribute("user",u);
        }else{
            baseResult = new BaseResult();
            baseResult.setSuccess(false);
        }
    }

    return baseResult;
}
/**
     * 注销页面
     *
     * @param request
     * @param response
     * @return
     */

    @RequestMapping(value = {"logout.html"})
    public String logout(HttpServletRequest request,
                         HttpServletResponse response) {

        //TODO: 从Session中删除用户信息
        HttpSession session = request.getSession();
        session.setAttribute("user",null);
        return "login";

    }

在UserMapping.xml中注意修改以下两项路径

在这里插入图片描述

在login.html中添加上οnsubmit="return false"取消自动登录

在这里插入图片描述

补充:left.html

<div class="user-block-info">
	<a id="gUserNickName" href="javascript:;" class="user-block-name"
          th:text="${session.user==null?'未登录':session.user.userName}">
    </a>
</div>
  • 24
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MyBatis 是一个持久层框架,可以通过它来实现对数据库的操作。下面是使用 MyBatis 实现登录功能的基本步骤: 1. 配置 MyBatis 的环境和数据源,在 mybatis-config.xml 文件中配置数据库连接信息。 2. 创建一个 User 实体类,用于表示用户的信息。 3. 创建一个 UserMapper 接口,用于定义对用户信息的操作方法,如登录验证方法。 4. 在 UserMapper.xml 文件中,编写相应的 SQL 语句,实现登录验证功能。 5. 在 UserMapper 接口中定义登录验证的方法,方法名应与 SQL 语句的 id 相对应。 6. 在 Java 代码中,通过 SqlSessionFactoryBuilder 和 SqlSessionFactory 创建 SqlSession 对象。 7. 在代码中通过 SqlSession 获取 UserMapper 对象,调用登录验证方法进行登录验证。 下面是一个简单MyBatis 登录验证示例代码: User.java ``` public class User { private int id; private String username; private String password; // 省略 getter 和 setter 方法 } ``` UserMapper.java ``` public interface UserMapper { User login(@Param("username")String username, @Param("password")String password); } ``` UserMapper.xml ``` <mapper namespace="com.example.mapper.UserMapper"> <select id="login" parameterType="map" resultType="com.example.entity.User"> select * from user where username = #{username} and password = #{password} </select> </mapper> ``` Java 代码 ``` SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = userMapper.login(username, password); sqlSession.close(); ``` 以上代码仅供参考,具体实现还需根据项目具体情况做出相应调整。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值