你的位置:首页 > Java教程

[Java教程]SSM框架的整合思路功能实现


这是我第一篇博客,关于SSM框架的整合思路以及简单功能实现。

首先,最近刚刚学习Spring+SpringMVC+Mybatis,在开发时遇到形形色色的问题,周遭人也为我提供了一些思路,我会一点点整理梳理,发上来,供自己温习,也可以分享给大家,希望有一个全面的理解,最好能够帮助到大家。

需求:开发属于自己的博客系统,要有登录注册,博客的增删改查等各种功能。

开发环境:IDEA,MySQL,JDK1.8等(不赘述)

首先对SSM框架有一个相应的认识。

SpringMVC:主要进行页面的 请求接受与响应。

  组件包括:前端控制器,处理器映射器,处理器适配器,视图解析器,处理器Handler,视图View。其中,只有处理器Handler和视图View需要程序员开发。

    View是一个借口,实现类支持不同的View类型(jsp,freemarker,pdf等)

    另外,处理器Handler就是Controller。

———————————————————————————我是分割线————————————————————————

Service层功能:注入dao,调用dao方法

——————————————————————我是分割线,对又是我————————————————————————

Mybatis:开始Mybatis时要记住最终目的,我们要对数据库的数据进行操作,所以你只需要记住,他的使用很方便,很方便,方便,即可。(详细讲解Myabtis配置等要一整天,不赘述)

  so,最后我们的开发思路就很明确了,从页面获取数据到Controller层,然后传递到service层进行相关操作(调用方法等),然后再传递到持久层对数据库进行相应增删改查即可。这样一说,是不是就明确了很多?

  下面的代码我只截取片段,只为了梳理我的思路。

首先要准备的一定是页面。我做一个简单的登录页面,页面片段如下:

<form action="/login" class="form-signin" method="post"> <h2 class="form-signin-heading">用户登录</h2> <input type="text" name="username" class="form-control" placeholder="用户名" required="" autofocus=""> <input type="password" name="pass_word" class="form-control" placeholder="密码" required=""> <div class="checkbox">  <label>   <input type="checkbox" value="remember-me"> 记住我  </label> </div> <button class="btn btn-primary btn-block" type="submit">确定</button><br> <a href="http://www.cnblogs.com//templates/register.jsp"><button class="btn btn-primary btn-block" type="button">注册</button></a></form>

 

页面有了,数据库也应该有,id,username,password等字段。并且准备好model(pojo)的相关字段get/set。片段如下:

public class User {  private BigInteger id;  private String username;  private String pass_word;  private String email;  public BigInteger getId() {    return id;  }  public void setId(BigInteger id) {    this.id = id;  }  public String getUsername() {    return username;  }  public void setUsername(String username) {    this.username = username;  }  public String getPass_word() {    return pass_word;  }  public void setPass_word(String pass_word) {    this.pass_word = pass_word;  }  public String getEmail() {    return email;  }  public void setEmail(String email) {    this.email = email;  }}

同时要准备好sql语句(我们要对数据库操作,sql语句是不可少的)放置在

以登录为例,

  <!--用户登录-->  <select id="login" parameterType="com.myblogs.model.User" resultType="int">    SELECT count(*) FROM user WHERE username =#{username} AND pass_word = #{pass_word}  </select>

  /**   * 用户登录   */  int login(User user);

要注意,输入/输出类型,名称等要一致。同时

我说一下我的sql语句思路。count(*)是统计数字,当账号密码和数据库的对上时,最少有一条记录。那我就拿获取到的记录数来判断是否登录成功!

这样,持久层就做好了,特别快,下面按照顺序是什么?业务层。也就是要对之前写的mapper文件方法做调用等。

需要一个service接口和实现类,也就是serviceimpl.java,由于service接口和mapper文件内容一致,可以不写,直接写接口实现类。我的实现类内容如下:

  @Autowired  private UserMapper userMapper;  //用户登录  int login(User user){    int count=userMapper.login(user);    if (count!=0){      return 1;    }    return 0;  }

在这里,我要实现判断。数据库得到的记录数字,记得之前的count(*)吗?得到的数据,如果返回的int不等于0,说明有数据获取到,也就是登录成功(页面输入的用户名密码和数据库对上了)反之则表示登录失败,用户名或者密码有错误,没对上。所以在这一层做了一个判断。

 

对的,service层也写好了,接下来呢?就是写Controller层,就是之前说的Handler(重申:两者是一个意思)

 @Autowired  UserMapper userMapper;  @RequestMapping("/login")  public String loginPageShow(){    return "login";  }  @RequestMapping(value = "/login",method = RequestMethod.POST)  public String loginPage(User user, HttpSession session){    int count=userMapper.login(user);    if (count==1){      session.setAttribute("username",user.getUsername());      return "loginsuccess";    }    return "login";  }

登录成功返回loginsuccess页面,登录失败继续返回login页面,重新输用户名密码。相应的页面上也要有这些字段,jsp文件在前面。

然后,运行,改bug,成功!一个简单的登录就实现了!!!!!!

效果如下图: