菜鸟 ssm 框架的学习之路

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

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

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

菜鸟 ssm 框架的学习之路_第1张图片

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


  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  下面的四个文件

菜鸟 ssm 框架的学习之路_第2张图片

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



	
	
	
	
		
			
				text/html;charset=UTF-8
			
		
	
	
	
		
			
					
			
		
	
	
	
		  
		
		
	
	
	
	  
        
          
        
          
        
          
     


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



	
	
	
	
		
	

	
		
		
		
		
		
		
		
		
		
		
		
		
		
		
	

	
	
		
		
		
	

	
	
		
		
	

	
	
		
	


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



	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框架搭建起来,接下来就是上代码的时间到,其实真的写代码好像也不多

 

菜鸟 ssm 框架的学习之路_第3张图片

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

1首先看我的generator文件夹

菜鸟 ssm 框架的学习之路_第4张图片

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

"1.0" encoding="UTF-8"?>
"-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

    
    
    "C:\Users\Administrator.WIN-2L7BJUF4P9K\.m2\repository\mysql\mysql-connector-java\5.1.30\mysql-connector-java-5.1.30.jar" />
    "DB2Tables" targetRuntime="MyBatis3">
        
            "suppressAllComments" value="true" />
        
        
         "com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/test" userId="root" password="root"> 
        
        
        
            "forceBigDecimals" value="false" />
        
        
        "zz.model" targetProject="D:\zz\workspace\mybatis\src">
            "enableSubPackages" value="true" />
            "trimStrings" value="true" />
        
        
        "zz.mapping" targetProject="D:\zz\workspace\mybatis\src">
            "enableSubPackages" value="true" />
        
        
        "XMLMAPPER" targetPackage="zz.dao" targetProject="D:\zz\workspace\mybatis\src">
            "enableSubPackages" value="true" />
        
        
        "user_t" domainObjectName="User" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" />
        
    

菜鸟 ssm 框架的学习之路_第5张图片

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

菜鸟 ssm 框架的学习之路_第6张图片

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

菜鸟 ssm 框架的学习之路_第7张图片

三。我们现在要写的就是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 class UserController {
    @Resource
    private UserService userService;
    @Resource
    private StudentService studentService;
     @RequestMapping("/showUser")  
        public String 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")  
     public ModelAndView showTable(HttpServletRequest request){  
     ModelAndView view = new ModelAndView("tables");
        return view; 
           
} 
     @RequestMapping("/index")  
        public ModelAndView toIndex(HttpServletRequest request){  
         ModelAndView view = new ModelAndView("login");
        return view;
} 
     @RequestMapping("/login2")  
     public ModelAndView 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 = new ModelAndView(url);
         return view;
     } 
     @RequestMapping("/register")  
     public ModelAndView register(HttpServletRequest request,Model model){     
         String  username = request.getParameter("name");
         String pwd = request.getParameter("pwd");
         User user = new User(); 
         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 = new ModelAndView(url);
        return view;
     } 
    
     @RequestMapping("/updateUserPwd")  
        public String 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=new User();
        user.setPwd(pwd);
        user.setName(name);
        int i=this.userService.updateUserPwdByName(user);        
        return "success";
        }
        else{
            return "fail2";
        }
         }
     @RequestMapping("/getUserByName")  
     public ModelAndView selectByName(HttpServletRequest request,Model model){
        String name = request.getParameter("name");
        User user=new User();
        user=this.userService.getUserByName(name);
        String url="getUserByName";
        if(name!=null){
            url="updateUserPwd";
        }        
        ModelAndView view = new ModelAndView();
        view.setViewName(url);
        view.addObject("xxx", user);
        
        return view;
     }
    

}

 

2 useService 接口层

package zizai.service;

import zizai.model.User;

public interface UserService {
    public User getUserById(int id);
    public User getUserByName(String name);
    public int addUser(User user);
    public int updateUserPwdByName(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 class UserServiceImp implements UserService {
    @Resource
    private UserMapper userMapper;
    
    public User getUserById(int id) {
        // TODO Auto-generated method stub
        return userMapper.selectByPrimaryKey(id);
    }

    public int addUser(User user) {
        // TODO Auto-generated method stub
        return userMapper.insert(user);
    }

    public User getUserByName(String name) {
        // TODO Auto-generated method stub
        return userMapper.selectByName(name);
    }
    public int updateUserPwdByName(User user) {
        // TODO Auto-generated method stub
        return userMapper.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
  
  
  
  
  
    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 文件的吧,其他的我粘上去给你们。

菜鸟 ssm 框架的学习之路_第8张图片

 

 

login.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>  
  
  
    
    登录  
    
   

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

用户名:

    密码:

  

 

 

register.jsp

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

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

 

 

 

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

 菜鸟 ssm 框架的学习之路_第9张图片

 

 

你可能感兴趣的:(菜鸟 ssm 框架的学习之路)