SSM框架的整合思路&功能实现

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

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

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

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

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

SSM框架的整合思路&功能实现

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

Spring 配备构建Web 应用的全功能MVC框架。Spring可以很便捷地和其他MVC框架集成,如Struts,Spring 的MVC框架用控制反转把业务对象和控制逻辑清晰地隔离。它也允许以声明的方式把请求参数和业务对象绑定。

  组件包括:前端控制器,处理器映射器,处理器适配器,视图解析器,处理器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="/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语句是不可少的)放置在xml文件中,以及相应的java文件中。

以登录为例,xml和相应mapper.java如下:

    <!--用户登录-->
<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);

要注意,输入/输出类型,名称等要一致。同时xml和相关mapper的文件目录要一致,比如都要是com.myblogs.mapper目录下

我说一下我的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,成功!一个简单的登录就实现了!!!!!!

效果如下图:

SSM框架的整合思路&功能实现

SSM框架的整合思路&功能实现

上一篇:DMSFrame 之简单用法(一)


下一篇:poj 2456 Aggressive cows && nyoj 疯牛 最大化最小值 二分