用mvc模式,整理前两次的代码并增加登陆注册
简单的servlet连接mysql数据库 使用mvc的登录注册
commons-dbutils-1.6
mysql-connector-java-5.1.40-bin
c3p0-0.9.5.2
mchange-commons-java-0.2.11
这里就要联系到前面的jsp-1了(以下全复制粘贴)
在MVC的项目中一般不会直接去访问JSP,都是通过.do来转发。
这样做的好处是:
1 所有请求全部通过action来转发,这样便于整体框架的处理。比如,可以加入登陆到某个页面的权限控制,只需要在配置文件中配置,而不用再每个JSP文件中加入相关的逻辑。
2 与数据库,文件等底层存储层连接,读取数据的代码可以在类(action)中执行。这样做,一方面可以将很多方法复用,另一方面使JSP页面的代码变得简单而容易维护。
3 其实.do也就是MVC当中的C,是控制器。在整个系统中起到中央枢纽的作用。先通过它的话就可以把逻辑代码隐藏在后台,使JSP文件作为单纯的VIEW分离出来,降低了系统的耦合性。
基本的意思就是在每次访问页面的时候都要访问一次服务器,并根据其结果判断能否访问。
就是mvc的分层的思想了
jdbcutils(数据库连接池-----c3p0)
package com.javaweb.utils; import java.sql.Connection;
import java.sql.SQLException; import javax.sql.DataSource; import com.mchange.v2.c3p0.ComboPooledDataSource; /**
* MAVEN
* 实现数据连接,通过数据库连接池(C3P0来获取DataSource)
* DataSource:数据库连接对象
*
*/
public class JdbcUtils { private static DataSource dataSource=null; static{
//找到c3p0-config里默认名为intergalactoApp的连接池
dataSource=new ComboPooledDataSource("intergalactoApp");
} /**
* 获取数据连接
* @return
* @throws SQLException
*/
public static Connection getConnection() throws SQLException{
return dataSource.getConnection();
} /**
* 关闭数据库连接
* @param conn
* @throws SQLException
*/
public static void closeConn(Connection conn) throws SQLException{
if(conn!=null){
conn.close();
}
} }
上一篇写了那么多的数据库连接池
这次导个jar就简单明了很多了
DBDao(数据库操作工具-----dbutils)
package com.javaweb.dao; import java.sql.Connection;
import java.sql.SQLException;
import java.util.List; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler; import com.javaweb.dao.impl.DBDaoImpl;
import com.javaweb.utils.JdbcUtils; public class DBDao<T> implements DBDaoImpl<T> { private QueryRunner queryRunner=new QueryRunner(); @Override
public List<T> selectAll(String sql, Class<T> clazz, List<Object> params) {
Connection conn=null;
try {
conn = JdbcUtils.getConnection();
if(params!=null && !params.isEmpty()){
return queryRunner.query(conn, sql, new BeanListHandler<>(clazz), params.toArray());
}
} catch (SQLException e) {
e.printStackTrace();
}
return null;
} @Override
public T selectOne(String sql, Class<T> clazz, List<Object> params) {
Connection conn=null;
try {
conn = JdbcUtils.getConnection();
if(params!=null && !params.isEmpty()){
return queryRunner.query(conn, sql, new BeanHandler<>(clazz), params.toArray());
}
} catch (SQLException e) {
e.printStackTrace();
}
return null;
} @Override
public int insert(String sql, List<Object> params) {
Connection conn=null;
try {
conn = JdbcUtils.getConnection();
if(params!=null && !params.isEmpty()){
return queryRunner.update(conn, sql, params.toArray());
}
} catch (SQLException e) {
e.printStackTrace();
}
return 0;
}
@Override
public int update(String sql, List<Object> params) {
Connection conn=null;
try {
conn = JdbcUtils.getConnection();
if(params!=null && !params.isEmpty()){
return queryRunner.update(conn, sql, params.toArray());
}
} catch (SQLException e) {
e.printStackTrace();
}
return 0;
} @Override
public int delete(String sql, List<Object> params) {
Connection conn=null;
try {
conn = JdbcUtils.getConnection();
if(params!=null && !params.isEmpty()){
return queryRunner.update(conn, sql, params.toArray());
}
} catch (SQLException e) {
e.printStackTrace();
}
return 0;
} @Override
public int insertOrUpdate(String sql, List params) {
// TODO Auto-generated method stub
return 0;
} }
同上一篇很多玩意,这次一个query就能省下很多不必要的代码
基本代码所要用到的方法都在前两篇有提及
mvc

所以
mvc我就根据目录来说一下了mvc就是model-view-control
其中简单的说
view
就是用户响应的收集,响应结果的显示
用.jsp来表示,webcontent
control
就是对用户响应的任务分配
用servlet来表示,com.javaweb.action
model
就是任务的具体完成
而其中
service是服务类,根据任务来划分什么服务
entity是实体类,就是实体,没什么好说的
utils是工具类,调用数据库,或者对字符串分割等。这类加工型操作
dao.impl是接口,表示应该具有什么操作
dao操作类,实现接口,对数据的操作,重点是逻辑方面
例如
userDao
package com.javaweb.dao; import java.util.List; import com.javaweb.dao.impl.UserDaoImpl;
import com.javaweb.entity.User; public class UserDao extends DBDao<User> implements UserDaoImpl { @Override
public User login(String sql, Class<User> clazz, List<Object> params) {
// TODO Auto-generated method stub
return selectOne(sql,clazz,params);
} @Override
public int register(String sql, List<Object> params) {
// TODO Auto-generated method stub
return insert(sql,params);
} }
假如用户要登录
我可以直接使用DBDao里的selectOne来实现登录
但是方法明里没有用户没有登录
这样逻辑就不清晰了
而我现在用UserDao继承DBDao,并在里面的login调用selectOne
这样一来逻辑就清晰很多了
代码有需要就下载吧
http://pan.baidu.com/s/1bpl9XSj
用mvc模式,整理前两次的代码并增加登陆注册的更多相关文章
- Extjs MVC模式开发,循序渐进(一)
本文讲述extjs mvc的Helloworld,tabPanel,event,页面布局layout等内容. 本页包含:MVC模式案例(一)~MVC模式案例(六),从搭建extjs mvc到点击按钮生 ...
- MVC 模式和模型 2
MVC框架 一个实现 MVC 模式的应用包含模型.视图.控制器 3 个模块: 模型:封装了应用的数据和业务逻辑,负责管理系统业务数据 视图:负责应用的展示 控制器:负责与用户进行交互,接收用户输入.改 ...
- 生活中的MVC模式,一个吃货的理解。
以下是生活中对于MVC模式的领悟,虽然可笑,轻喷. 2015年 8月 26日 M => Model 模型 我认为叫做模具更好的理解.批量加工生产具有相同特征的东西. ...
- 谈谈MVC模式
谈谈MVC模式 作者: 阮一峰 1. 如何设计一个程序的结构,这是一门专门的学问,叫做"架构模式"(architectural pattern),属于编程的方法论. MVC模式 ...
- Spring mvc 模式小结
http://www.taobaotesting.com/blogs/2375 1.spring mvc简介 Spring MVC框架是一个MVC框架,通过实现Model-View-Controlle ...
- [转]MVC模式已死?何不试试MOVE
在36Kr看到一篇译文,主要是提出一些新的概念,升华老的MVC模式.看上很不错,转过来,做个记录. ========================= 华丽的分割线 ================= ...
- MVC模式学习笔记
一.如何设计一个程序的结构,这是一门专门的学问,叫做“架构模式”(architectural pattern),属于编程的方法论. MVC模式就是架构模式的一种,我觉得它不仅适用于开发软件,也适用于其 ...
- 【iOS 开发】iOS 开发 简介 (IOS项目文件 | MVC 模式 | 事件响应机制 | Storyboard 控制界面 | 代码控制界面 | Retina 屏幕图片适配)
一. iOS 项目简介 1. iOS 文件简介 创建一个 HelloWorld 项目, 在这个 IOS 项目中有四个目录 : 如下图; -- HelloWorldTests 目录 : 单元测试相关的类 ...
- MVC模式-----struts2框架
MVC模式-----struts2框架 一.struts MVC模式 1.概述 MVC是模型(model)---视图model(view)---控制器(control)的缩写,是一种用于将逻辑.数据和 ...
随机推荐
- Mac 远程连接Linux服务器及上传、下载命令
1.使用ssh命令连接远程服务器主机 1.不设置端口,默认就是22 ssh root@192.168.18.129 1.1.设置端口例: ssh -p 22 root@192.168.18.1292. ...
- 项目积累demo-01
1 搭建Spring-Boot项目 在这里我使用intellij新建spring boot工程: 点击next; 输入Group以及artifact之后.点击next.之后点击web.接着finish ...
- kali linux学习笔记之系统定制及优化(附:中文输入法设置)
fix update flash plugin on kali rolling author:@kerker 0x00设置软件源 root@kali:~# vim /etc/apt/sources.l ...
- 为什么源码中很多方法就一行throw new RuntimeException("Stub!")
在使用某些类的方法时,发现其内部就一行throw new RuntimeException("Stub!"),但是实际运行中并没有抛出该错误,该方法也并没有语法报错. 因此可能是系 ...
- Java面向对象的三大特性 继承
继承是类与类的一种关系,是“is a"关系 子类拥有父类的属性和方法,private除外 class 子类 extends 父类 方法的重写 调用方法时会优先调用子类的方法 重写时,返 ...
- sourcetree 不停的让输入密码,报 password required
sourcetree 不停的让输入密码,报 password required sourcetree 不停的让输入密码,报 password required1.在终端(terminal)打开你的工程 ...
- bzoj 3944: Sum(杜教筛)
3944: Sum Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 4930 Solved: 1313[Submit][Status][Discuss ...
- centos 7 安装python3
centos系统默认已安装python2.7,python3需要手动安装.以上是安装步骤 一.备份原来的2.7版本 首先看一下默认的python2.7在哪里 [root@apple ~]# cd / ...
- 备份与恢复:MySQL系列之十二
一.备份策略赘述 1.备份的类型 类型1: 热备份:读写不受影响(MyISAM不支持热备,InnoDB支持热备) 温备份:仅可以执行读操作 冷备份:离线备份,读写操作均中止 类型2: 物理备份:复制数 ...
- shell学习(11)- seq
今天是五一劳动节,窗户外边,草长莺飞,惠风和畅,但坐在办公室里值班也需要做点事情,今天就写写seq的用法. 作用:用于以指定增量从首数开始打印数字到尾数,即产生从某个数到另外一个数之间的所有整数,并且 ...