博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
菜鸟 ssm 框架的学习之路
阅读量:6478 次
发布时间:2019-06-23

本文共 17857 字,大约阅读时间需要 59 分钟。

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

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

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

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

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

driver=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/ssm01username=rootpassword=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.ConsoleAppenderlog4j.appender.Console.Target=System.out#可以灵活地指定日志输出格式,下面一行是指定具体的格式log4j.appender.Console.layout = org.apache.log4j.PatternLayoutlog4j.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 = ALLlog4j.appender.File.layout = org.apache.log4j.PatternLayoutlog4j.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框架搭建起来,接下来就是上代码的时间到,其实真的写代码好像也不多

 

如上图,在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 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 文件的吧,其他的我粘上去给你们。

 

 

login.jsp

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

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

用户名:
   &nbsp密码:

  

 

 

register.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>              注册                
   用户名:
    密码:

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

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

 

 

 

 

 

转载于:https://www.cnblogs.com/nn839155963/p/5731324.html

你可能感兴趣的文章
shell 中简单的运算
查看>>
VMware内存不足解决方案
查看>>
Nginx基础
查看>>
python列表解析和生成表达式浅要说明
查看>>
Java注解Annotation详解
查看>>
C++文件操作 判断文件是否存在和文件大小
查看>>
揭开AS程序的外纱(八) -- 容易被忽视的数组实用功能
查看>>
物理内存低于896M各个区到底是怎么映射的
查看>>
linux下的缓存机制及清理buffer/cache/swap的方法梳理
查看>>
安装和配置 Virtual Server
查看>>
Priority VS Bandwidth
查看>>
携程加入百度系 OTA王座利好呈现
查看>>
学习使用SAMinside心得笔记
查看>>
MySQL深入05-用户管理
查看>>
SQL存储过程中的几个常见设定SET QUOTED_IDENTIFIER/NOCOUNT/XACT_ABORT ON/OFF
查看>>
第一部分:基础知识(第一章)第一个 Silverlight 手机程序
查看>>
Silverlight与Flash区别之一
查看>>
删除恢复Hadoop集群中的DataNode
查看>>
Silverlight 2动态创建矩形对象(附完整源代码)
查看>>
PowerShell中对属性设置别名
查看>>