springmvc springJDBC 简单实训银行账户管理系统
1.简单介绍一下,在校时每周结束都会有一次学习总结,简称“实训”,这次实训内容是spring,因为是最近热门框架,我就先从基础方面开始练习,一路填坑,有点不容易。这是我第一次写文章,可能不太完善,希望多多包涵。喜欢的同学可以关注一下子。
项目建完大概是这样,看一下:
——————————————————————————————————————————————————————————————
2.项目搭建需求:
myEclipse + mysql + jdk1.6 + (spring 3.0 core Libraries+spring 3.0 AOP Libraries+spring 3.0 Web Libraries+spring 3.0+persistence JDBC Libraries+spring 3.0 persistence Core Libraries) + mysql5.17.jar
大致是这些,如还是不明白可以随时联系我:1763907618+备注(博客园)
——————————————————————————————————————————————————————————————
3.数据库搭建:
建立数据库名字 bank
建立表格trade 和 user 字段如下:
————————————————————————————————————————————————————————————————————————————————————
4.代码及功能的实现:
先看主要项目结构:
好了,不废话开始我们的第一步。
new--------web project-------输入name-------finish
右键单击项目 ---------MyEclipse-----------Add spring Capabilities 如图:
接下来选择spring3.0 选择所需要的jar包;如图:-------选择好后------finish
将applicationContext.xml拖入到webroot/web-inf内,如图:
同时将mysql驱动jar放入lib内。!!!!!
在src内建立四个包,我就不一一打了,如图:
嗯,现在基本准备好了,就先撸一个登录部分,直接上代码吧:
在applicationContext,xml里加代码:
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> class="org.springframework.web.servlet.view.InternalResourceViewResolver"> org.springframework.web.servlet.view.JstlView .jsp class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"> userAddAction userLoginAction class="com.service.UserService" id="userService"> class="com.dao.UserDao"> class="com.controller.UserLoginAction"> main shibai class="com.controller.UserAddAction"> index
可能会有错误提示,别急,一步步来;
在web.xml里修改,如:
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> CharacterEncodingFilter class>org.springframework.web.filter.CharacterEncodingFilter class>encoding utf-8 CharacterEncodingFilter /* index.jsp Dispatcher org.springframework.web.servlet.DispatcherServlet contextConfigLocation /WEB-INF/applicationContext.xml Dispatcher *.do
在index.jsp里修改如:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>登录title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> head> <body> <form action="userLogin.do" method="post" > <input type="text" name="username" placeholder="登录|账号" /><br /> <input type="password" name="password" placeholder="输入密码" /><br /> <input type="submit" value="登 录" />
<input type="button" name="button" id="button" value="注册" onClick="location.href='userAdd.jsp'" > form> body> html>
建立main.jsp里面添加几句话就行,一会登录成功跳转的页面。
建立userAdd.jsp,这是注册页面,顺手写了吧。
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>登录title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <style type="text/css"> .div_th{ width: 150px; text-align: center;height: 40px;background-color: teal; font-size: 20px;font-family: "楷体";color: white; } .div_td{ width: 300px;height: 40px; background-color: teal; font-size: 20px;font-family: "楷体" } style> head> <body> <form id="form3" name="form3" action="userAdd.do" method="post"> <table border="1" align="center"> <tr > <th class="div_th" >账号th> <td class="div_td"> <input type="text" name="username" style="width: 95%"> td> <th class="div_th">性别th> <td class="div_td"> <select name="sex" title="性别"> <option value="男" >男option> <option value="女" >女option> select> td> tr> <tr> <th class="div_th">密码 th> <td class="div_td"><input type="password" name="password" style="width: 95%"> td> <th class="div_th">确认密码th> <td class="div_td"><input type="password" name="confirmpassword" style="width: 95%">td> tr> <tr> <th class="div_th">用户年龄th> <td class="div_td"><input type="text" name="userage" style="width: 95%"> td> <th class="div_th">身份证号th> <td class="div_td"><input type="text" name="idcard" style="width: 95%" maxlength="18">td> tr> <tr> <th class="div_th">联系电话th> <td class="div_td"><input type="text" name="tel" style="width: 95%">td> <th class="div_th">居住城市th> <td class="div_td"><input type="text" name="city" style="width: 95%">td> tr> <tr> <th class="div_th">详细地址th> <td class="div_td"><input type="text" name="useradd" style="width: 95%">td> <th class="div_th">th> <td class="div_td">td> tr> table> <input type="hidden" name="userflag" value="否"> <div style="text-align: center; background-color: teal"> <input type="submit" value="注 册" name="submit" id="submit" style="width: 500px;height: 35px;color: white;background-color: orange;font-size: 20px;font-family: 楷体"> <br/> <input type="button" name="button" value="返 回" onClick="location.href='index.jsp'"style="width: 500px;height: 35px;color: white;background-color: greenyellow;margin-top: 1%; font-size: 20px;font-family: 楷体" > div> form> body> html>
在com.pojo里建立User.java
package com.pojo; public class User { public static final int PAGE_SIZE=10; private int id; private String username; private String password; private String userflag; private int userage; private String idcard; private String tel; private String city; private String useradd; private String sex; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getUserflag() { return userflag; } public void setUserflag(String userflag) { this.userflag = userflag; } public int getUserage() { return userage; } public void setUserage(int userage) { this.userage = userage; } public String getIdcard() { return idcard; } public void setIdcard(String idcard) { this.idcard = idcard; } public String getTel() { return tel; } public void setTel(String tel) { this.tel = tel; } public String getCity() { return city; } public void setCity(String city) { this.city = city; } public String getUseradd() { return useradd; } public void setUseradd(String useradd) { this.useradd = useradd; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public static int getPageSize() { return PAGE_SIZE; } }
上面那个相当好理解,也容易自动生成,不详细说明了。
在com.dao里建立UserDao.java代码如下:
package com.dao; import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.support.JdbcDaoSupport; import com.pojo.User; public class UserDao extends JdbcDaoSupport { //用户---- 用户登陆 @SuppressWarnings("unchecked") public List userLogin(User user){ JdbcTemplate jt=new JdbcTemplate(getDataSource()); String sql="select * from user where username='"+user.getUsername()+"' and password='"+user.getPassword()+"'"; List rows=jt.queryForList(sql); return rows; } //用户---- 用户注册 public int userAdd(User user){ JdbcTemplate jt=new JdbcTemplate(getDataSource()); String sql = "insert into user (username, password, userflag,userage,idcard,tel,city,useradd,sex) " + "value('"+user.getUsername()+"','"+user.getPassword()+"','"+user.getUserflag()+"','"+user.getUserage()+"','"+user.getIdcard()+"','"+user.getTel()+"','"+user.getCity()+"','"+user.getUseradd()+"','"+user.getSex()+"')"; int n=jt.update(sql); return n; } }
上面这个主要涉及到数据库一些内容,还是老样子不懂咨询我。
在com.service里建立UserService.java.如:
package com.service; import java.util.List; import com.dao.UserDao; import com.pojo.User; public class UserService { UserDao userDao; public UserDao getUserDao() { return userDao; } public void setUserDao(UserDao userDao) { this.userDao = userDao; } //用户---- 用户登陆 @SuppressWarnings("unchecked") public List userLogin(User user){ return userDao.userLogin(user); } //用户---- 用户注册 public int userAdd(User user){ return userDao.userAdd(user); } }
在com.controller里创建UserLoginAction.java 登录
package com.controller; import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.springframework.validation.BindException; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.mvc.SimpleFormController; import com.pojo.User; import com.service.UserService; @SuppressWarnings("deprecation") public class UserLoginAction extends SimpleFormController { public String success_view; public String shibai_view; public String getShibai_view() { return shibai_view; } public void setShibai_view(String shibaiView) { shibai_view = shibaiView; } public UserService userService; public String getSuccess_view() { return success_view; } public void setSuccess_view(String successView) { success_view = successView; } public UserService getUserService() { return userService; } public void setUserService(UserService userService) { this.userService = userService; } @SuppressWarnings("unchecked") protected ModelAndView onSubmit(HttpServletRequest request,HttpServletResponse response,Object cmd,BindException ex)throws Exception{ User user=(User)cmd; List list=userService.userLogin(user); String username=user.getUsername(); HttpSession session=request.getSession(); session.setAttribute("user", list); session.setAttribute("username", username); if(list==null||list.size()<1){ return new ModelAndView(this.getShibai_view()); }else { return new ModelAndView(this.getSuccess_view()); } } }
在com.controller里创建UserAddAction.java 注册
package com.controller; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.validation.BindException; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.mvc.SimpleFormController; import com.pojo.User; import com.service.UserService; @SuppressWarnings("deprecation") public class UserAddAction extends SimpleFormController { public String success_view; public UserService userService; public String getSuccess_view() { return success_view; } public void setSuccess_view(String successView) { success_view = successView; } public UserService getUserService() { return userService; } public void setUserService(UserService userService) { this.userService = userService; } protected ModelAndView onSubmit(HttpServletRequest request,HttpServletResponse response,Object cmd,BindException ex)throws Exception{ User user=(User)cmd; int n=userService.userAdd(user); request.setAttribute("user", user.getUsername()); if(n>0){ request.setAttribute("userAddMes", "注册成功"); }else{ request.setAttribute("userAddMes", "注册失败"); } return new ModelAndView(this.getSuccess_view()); } }
-____________________________________________________________________________________________________________________________________________
好了,登录和注册的功能已经完成,因为也是菜鸟,所以有很多地方,比如方法什么的出现错误还望各位大神指出,在下就多多学习。学习在于积累,勤奋一下总会有所成功。
这个程序因为时间紧,所以写的有点仓促,只是严格的按照要求把程序功能全部实现,而里面的好多效验什么的没有写。切记!
我的源码里是有css,和js样式的,所以还算美观。
但是不知道怎么上传源码,所以麻烦一下吧,需要源码的直接联系我吧。(个人爱好,免费)
QQ:1763907618。+备注(博客园)
我会一直在,期待小伙伴们的评论,哈哈!!!!
一年多了为了方便大家更新了个百度网盘
链接:https://pan.baidu.com/s/11eQigVlISy1ZqkO7hH9XWA
提取码:ofrk