前面文章中,咱们已经完成了OSGI应用中Spring、Mybatis、Spring MVC的整合,本篇文章咱们就在这个基础上来完成一个简单的登陆应用,其中用户名和密码须要从数据库中查询。css
前面文章中,咱们已经搭建好的工做空间以下图所示:
本篇文章中,咱们只须要在com.csdn.osgi.user.web工程中添加页面及Controller便可。html
首先新增一个登陆界面,文件路径为在WebContent/WEB-INF/jsp/login.jsp,内容以下:java
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>用户登陆</title>
<link href="css/bootstrap/css/bootstrap.min.css" rel="stylesheet">
<link href="css/signin.css" rel="stylesheet">
</head>
<body>
<div class="signin">
<div class="signin-head"><img src="images/head_120.png" alt="" class="img-circle"></div>
<form class="form-signin" role="form" action="Login.do" method="post">
<input type="text" name="username" class="form-control" placeholder="用户名" required autofocus />
<input type="password" name="password" class="form-control" placeholder="密码" required />
<button class="btn btn-lg btn-warning btn-block" type="submit">登陆</button>
<label class="checkbox">
<input type="checkbox" value="remember-me"> 记住我
</label>
</form>
</div>
</body>
</html>
登陆成功后,跳转到成功页面,因此咱们还须要新增一个登陆成功页面,文件路径为WebContent/WEB-INF/jsp/success.jsp,页面代码以下:web
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>用户登陆</title>
<link href="css/bootstrap/css/bootstrap.min.css" rel="stylesheet">
<link href="css/signin.css" rel="stylesheet">
</head>
<body>
<h1>登陆成功</h1>
</body>
</html>
接下来须要定义两个控制器来处理业务逻辑,首先增长一个PreLoginControler,逻辑比较简单,用于跳转到首页面,代码以下:spring
package com.csdn.osgi.user.controllers;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.mvc.Controller;
import org.springframework.web.servlet.ModelAndView;
public class PreLoginControler implements Controller {
public ModelAndView handleRequest(HttpServletRequest request,
HttpServletResponse response) throws Exception {
return new ModelAndView("login");
}
}
而后还须要一个控制器LoginControler处理登陆逻辑,代码以下:sql
package com.csdn.osgi.user.controllers;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.ibatis.session.SqlSession;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
public class LoginControler implements Controller {
private SqlSession sqlMap;
public void setSqlMap(SqlSession sqlMap) {
this.sqlMap = sqlMap;
}
public ModelAndView handleRequest(HttpServletRequest request,
HttpServletResponse response) throws Exception {
String userName = request.getParameter("username");
String password = request.getParameter("password");
System.out.println("UserName=>" + userName + ";" + "Password=>" + password);
if(userName == null || password == null){
return new ModelAndView("login");
}
String pword = (String) sqlMap.selectOne("user.getPasswordByName", userName);
System.out.println(pword);
if(pword !=null && pword.equals(password)){
return new ModelAndView("success");
} else {
return new ModelAndView("login");
}
}
}
其中SqlSession 为Mybatis操做数据库的Session对象,经过Spring注入,Bean的配置以下:数据库
<bean name="/preLogin.do" class="com.csdn.osgi.user.controllers.PreLoginControler">
</bean>
<bean name="/Login.do" class="com.csdn.osgi.user.controllers.LoginControler">
<property name="sqlMap" ref="sqlMapService"></property>
</bean>
到此为止咱们已经完成了这个简单的登陆应用的开发,源码下载地址会在文章结尾提供,接下来就来看看效果,首先启动OSGI容器,打开浏览器访问http://localhost:8080/preLogin.do,以下图所示:
输入正确的用户名密码,例如Smith/Smith,则跳转到登陆成功界面,以下图所示:apache
用户名密码输入不正确则中止在登陆界面,固然还能够增长一些提示信息,告诉客户用户名密码错误,这里就不作演示了,本案例主要是用于证实Spring MVC是整合成功的,不然Mybatis的SqlSession对象是没法注入到Controller对象中的。bootstrap