这是我第一篇博客,关于SSM框架的整合思路以及简单功能实现。
首先,最近刚刚学习Spring+SpringMVC+Mybatis,在开发时遇到形形色色的问题,周遭人也为我提供了一些思路,我会一点点整理梳理,发上来,供自己温习,也可以分享给大家,希望有一个全面的理解,最好能够帮助到大家。
需求:开发属于自己的博客系统,要有登录注册,博客的增删改查等各种功能。
开发环境:IDEA,MySQL,JDK1.8等(不赘述)
首先对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,成功!一个简单的登录就实现了!!!!!!
效果如下图: