新手搭ssm要多久_菜鸟 ssm 框架的学习之路

跟着老师学习了两个月的java语言,现在学习到了框架的部分,一直想在博客上写点东西的,只是自己一直没有时间,其实到底也是懒,鲁迅说过:"时间就像海绵里的水,只要愿意去挤还是有的",所以废话不多说,直接上代码。

首先框架一开始学还是比较难,ssm框架,就是Spring ,SpringMVC ,mybstis 的简称,我们是从mybstis 开始学起的,mybatis的作用作为一个连接数据库的框架,可以很好配置连接好数据库, 有mybatis,我们对数据库增删改查的操作更为简便了。SSM框架,我们用MAVEN工具对他们进行管理,maven 工具的主要作用就是为我们的工程自动配置好我们所需的架包,是通过POM.xml 文件进行依懒管理的。

ssm02这个工程使用maven工具进行管理和配置的,他的主要作用是实现用户的登陆和注册!以及对学生信息的管理,当然其中包括了增删改查的四个基本的操作,详细的具体的过程直接看后面的代码!

1 首先是POM.xml 文件的配置,他的作用主要是添加依懒的关系。

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">

4.0.0

com.zzty

ssm01

war

0.0.1-SNAPSHOT

ssm01 Maven Webapp

http://maven.apache.org

4.0.2.RELEASE

3.1.1

1.7.7

1.2.17

junit

junit

4.11

test

org.springframework

spring-core

${spring.version}

org.springframework

spring-web

${spring.version}

org.springframework

spring-oxm

${spring.version}

org.springframework

spring-tx

${spring.version}

org.springframework

spring-jdbc

${spring.version}

org.springframework

spring-webmvc

${spring.version}

org.springframework

spring-aop

${spring.version}

org.springframework

spring-context-support

${spring.version}

org.springframework

spring-test

${spring.version}

org.mybatis

mybatis

${mybatis.version}

org.mybatis

mybatis-spring

1.1.0

javax

javaee-api

7.0

mysql

mysql-connector-java

5.1.30

commons-dbcp

commons-dbcp

1.2.2

jstl

jstl

1.2

log4j

log4j

${log4j.version}

com.alibaba

fastjson

1.1.41

org.slf4j

slf4j-api

${slf4j.version}

org.slf4j

slf4j-log4j12

${slf4j.version}

org.codehaus.jackson

jackson-mapper-asl

1.9.13

commons-fileupload

commons-fileupload

1.3.1

commons-io

commons-io

2.4

commons-codec

commons-codec

1.9

ssm01

2  就是再配置resources  下面的四个文件

jdbc.properties   连接你的数据库的配置,还有一些作用自己理解。

driver=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/ssm01

username=root

password=root

#定义初始连接数

initialSize=0

#定义最大连接数

maxActive=20

#定义最大空闲

maxIdle=20

#定义最小空闲

minIdle=1

#定义最长等待时间

maxWait=60000

log4.properties   用来记录工程运行调试的记录什么的。

#定义LOG输出级别

log4j.rootLogger=INFO,Console,File

#定义日志输出目的地为控制台

log4j.appender.Console=org.apache.log4j.ConsoleAppender

log4j.appender.Console.Target=System.out

#可以灵活地指定日志输出格式,下面一行是指定具体的格式

log4j.appender.Console.layout = org.apache.log4j.PatternLayout

log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n

#文件大小到达指定尺寸的时候产生一个新的文件

log4j.appender.File = org.apache.log4j.RollingFileAppender

#指定输出目录

log4j.appender.File.File = logs/ssm.log

#定义文件最大大小

log4j.appender.File.MaxFileSize = 10MB

# 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志

log4j.appender.File.Threshold = ALL

log4j.appender.File.layout = org.apache.log4j.PatternLayout

log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n

3 spring mvc .xml

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"

xmlns:context="http://www.springframework.org/schema/context"

xmlns:mvc="http://www.springframework.org/schema/mvc"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.1.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.1.xsd

http://www.springframework.org/schema/mvc

http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">

class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">

text/html;charset=UTF-8

class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">

class="org.springframework.web.multipart.commons.CommonsMultipartResolver">

4 spring mybatis.xml  他的作用就是就Spring 和Mybatis 整合起来。

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"

xmlns:context="http://www.springframework.org/schema/context"

xmlns:mvc="http://www.springframework.org/schema/mvc"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.1.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.1.xsd

http://www.springframework.org/schema/mvc

http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">

class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

destroy-method="close">

class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

5.还有webapp 下面的WEB-INF下面的web.xml 的配置

xmlns="http://java.sun.com/xml/ns/javaee"

xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"

version="3.0">

Archetype Created Web Application

contextConfigLocation

classpath:spring-mybatis.xml

encodingFilter

org.springframework.web.filter.CharacterEncodingFilter

true

encoding

UTF-8

encodingFilter

/*

org.springframework.web.context.ContextLoaderListener

org.springframework.web.util.IntrospectorCleanupListener

default

/resources/*

SpringMVC

org.springframework.web.servlet.DispatcherServlet

contextConfigLocation

classpath:spring-mvc.xml

1

true

SpringMVC

/

/index.jsp

15

二. 现在基本把SSM框架搭建起来,接下来就是上代码的时间到,其实真的写代码好像也不多

如上图,在zizai的文件夹有5个包,其中3个包使用工具generator生成的,这三个包是dao层,model层,mapping层,下面我也详细讲generator这个的用法。

1首先看我的generator文件夹

可以看到有四个文件,其中src是自己新建的,generator.xml 自带的,需要根据你自己数据库的来进行配值,先配置好我自己的generator.xml的文件

3 打开cmd ,执行txt 文件的那个生成语句

4 可以看到执行成功,这个时候src文件夹就会自动生成model ,mapping ,dao 三个层!

三。我们现在要写的就是Controller层,Service接口层,ServiceImp接口的实现层!就一个列子为例来说明的吧!这个UserController层,主要是实现用户的登陆和注册以及修改用户的密码

package zizai.controller;

import javax.annotation.Resource;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.servlet.ModelAndView;

import zizai.model.User;

import zizai.service.StudentService;

import zizai.service.UserService;

@Controller

@RequestMapping("/user")public classUserController {

@ResourceprivateUserService userService;

@ResourceprivateStudentService studentService;

@RequestMapping("/showUser")publicString showUser(HttpServletRequest request,Model model){int userId = Integer.parseInt(request.getParameter("id"));

User user= this.userService.getUserById(userId);

model.addAttribute("user", user);return "showUser";

}

@RequestMapping("/table")publicModelAndView showTable(HttpServletRequest request){

ModelAndView view= new ModelAndView("tables");returnview;

}

@RequestMapping("/index")publicModelAndView toIndex(HttpServletRequest request){

ModelAndView view= new ModelAndView("login");returnview;

}

@RequestMapping("/login2")publicModelAndView login(HttpServletRequest request,Model model){

String username= request.getParameter("name");

String pwd= request.getParameter("pwd");

User user= this.userService.getUserByName(username);

String url="login";if(user!=null&&pwd.equals(user.getPwd())){

url="sucess";

}else{

url="fail";

}

ModelAndView view= newModelAndView(url);returnview;

}

@RequestMapping("/register")publicModelAndView register(HttpServletRequest request,Model model){

String username= request.getParameter("name");

String pwd= request.getParameter("pwd");

User user= newUser();

user.setName(username);

user.setPwd(pwd);int i=this.userService.addUser(user);

String url="register";if(username!=null||pwd!=null){if(i>0){

url="login";

}else{

url="fail";

}

}

ModelAndView view= newModelAndView(url);returnview;

}

@RequestMapping("/updateUserPwd")publicString updateUserPwd(HttpServletRequest request,Model model){

String name=request.getParameter("name");

String pwd=request.getParameter("pwd");

String pwd1=request.getParameter("pwd1");if(pwd1.equals(pwd)&&pwd1!=null){

User user=newUser();

user.setPwd(pwd);

user.setName(name);int i=this.userService.updateUserPwdByName(user);return "success";

}else{return "fail2";

}

}

@RequestMapping("/getUserByName")publicModelAndView selectByName(HttpServletRequest request,Model model){

String name= request.getParameter("name");

User user=newUser();

user=this.userService.getUserByName(name);

String url="getUserByName";if(name!=null){

url="updateUserPwd";

}

ModelAndView view= newModelAndView();

view.setViewName(url);

view.addObject("xxx", user);returnview;

}

}

2 useService 接口层

package zizai.service;

import zizai.model.User;public interfaceUserService {public User getUserById(intid);publicUser getUserByName(String name);public intaddUser(User user);public intupdateUserPwdByName(User user);

}

3 UserServiceImp

package zizai.serviceImp;

import javax.annotation.Resource;

import org.springframework.stereotype.Service;

import zizai.dao.UserMapper;

import zizai.model.User;

import zizai.service.UserService;

@Service("userService")public classUserServiceImp implements UserService {

@ResourceprivateUserMapper userMapper;public User getUserById(intid) {//TODO Auto-generated method stub

returnuserMapper.selectByPrimaryKey(id);

}public intaddUser(User user) {//TODO Auto-generated method stub

returnuserMapper.insert(user);

}publicUser getUserByName(String name) {//TODO Auto-generated method stub

returnuserMapper.selectByName(name);

}public intupdateUserPwdByName(User user) {//TODO Auto-generated method stub

returnuserMapper.updateUserPwdByName(user);

}

}

4 model(USer model)

package zizai.model;

public class User {

private Integer id;

private String name;

private String pwd;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name == null ? null : name.trim();

}

public String getPwd() {

return pwd;

}

public void setPwd(String pwd) {

this.pwd = pwd == null ? null : pwd.trim();

}

}

5 mapping (USer mapping)

id, name, pwd

select

from suser

where id = #{id,jdbcType=INTEGER}

select

from suser

where name = #{name,jdbcType=VARCHAR}

delete from suser

where id = #{id,jdbcType=INTEGER}

insert into suser (id, name, pwd

)

values (#{id,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR}, #{pwd,jdbcType=VARCHAR}

)

insert into suser

id,

name,

pwd,

#{id,jdbcType=INTEGER},

#{name,jdbcType=VARCHAR},

#{pwd,jdbcType=VARCHAR},

update suser

name = #{name,jdbcType=VARCHAR},

pwd = #{pwd,jdbcType=VARCHAR},

where id = #{id,jdbcType=INTEGER}

update suser

set name = #{name,jdbcType=VARCHAR},

pwd = #{pwd,jdbcType=VARCHAR}

where id = #{id,jdbcType=INTEGER}

update suser

set pwd = #{pwd,jdbcType=VARCHAR}

where name = #{name,jdbcType=VARCHAR}

6 dao (user Dao)

package zizai.dao;

import zizai.model.User;

public interface UserMapper {

int deleteByPrimaryKey(Integer id);

int insert(User record);

int insertSelective(User record);

User selectByName(String name);

User selectByPrimaryKey(Integer id);

int updateByPrimaryKeySelective(User record);

int updateByPrimaryKey(User record);

int updateUserPwdByName(User user);

}

最后就是剩下WEB-INF 目录下的jsp文件夹下面的jsp 文件,这里主要带上用户登陆和注册的jsp 文件的吧,其他的我粘上去给你们。

login.jsp

登录

欢迎来到自在天原的登陆页面

用户名:

&nbsp&nbsp&nbsp&nbsp密码:

登陆

注册

register.jsp

注册

用户名:

    密码:

就是这些东西了! 第一次上传有干货的东西到博客园,其中难免会有许多的纰漏之处恳请各位园友兄弟一起指出,大家一起学习进步,本人也是刚开始学习java 语言,希望进步,提高自己的能力和水平,我写这些东西为了自己的理解和学习,以便日后工作可以很快可以回忆和使用,最后给我的码云的链接,里面有ssm02工程的完整代码以及自己平常学习的一些代码和大家一起分享。

http://git.oschina.net/nn839155963/Zizaitianyuan-luojunyuan/tree/master

喜欢呼呼的文章的朋友,可以关注呼呼的个人公众号:

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值