简单的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

jsp-3 简单的servlet连接mysql数据库 使用mvc的登录注册的更多相关文章

  1. jsp-2 简单的servlet连接mysql数据库 增删改查

    连接mysql数据库的操作 有增删改查 用的包有 commons-lang3-3.5 mysql-connector-java-5.1.40-bin 但是实际上也就是 数据查询和数据处理两种 所以对数 ...

  2. Ubuntu jsp平台使用JDBC来连接MySQL数据库

    Ubuntu 7.04 搭建Ubuntu jsp平台开发环境MySQL+tomcat+apache+j2sdk1.6在所有安装开始前先在Terminal中输入 rpm -q -a查看是否安装过rpm ...

  3. servlet连接mysql数据库和oracle数据库

    连接mysql数据库 package dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.P ...

  4. html文件form表单action调用servlet连接mysql数据库实例

    web.xml文件 <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi=&qu ...

  5. Myeclipse WEB工程JSP使用JNDI 数据库连接池连接Mysql数据库

    在网上查了很多,最后实现了.下面写一下过程: 首先,在WEBROOT/META-INF下建一个文件context.xml,内容为: <?xml version="1.0" e ...

  6. MVC Html辅助方法DropDownList的简单使用、连接MYSQL数据库用自定义model类接收

    附上启发链接:https://www.cnblogs.com/CreateMyself/p/5424894.html [HttpGet] public ActionResult Edit(int id ...

  7. 【C#】【MySQL】C#连接MySQL数据库(三)登陆注册代码

    项目结构 项目代码 WebForm_Login.aspx <%@ Page Language="C#" AutoEventWireup="true" Co ...

  8. JDBC连接MySQL数据库代码模板

    下面这个例子是最简单的JDBC连接MySQL数据库的例子. 一般步骤: 1.注册驱动: 2.建立连接: 3.创建语句: 4.处理结果: 5.释放资源. 注意: 1.软件开发环境:MyEclipse 8 ...

  9. 01_10_SERVLET如何连接Mysql数据库

    01_10_SERVLET如何连接Mysql数据库 1. 实现类 public void doGet(HttpServletRequest request, HttpServletResponse r ...

随机推荐

  1. Mysql 使用 select into outfile

    Mysql支持将查询结果到处 默认语法 select .. from table  into outfile "filepath\filename.txt"; 如果在执行的过程中遇 ...

  2. hadoop编程技巧(3)---定义自己的区划类别Partitioner

    Hadoop代码测试环境:Hadoop2.4 原则:在Hadoop的MapReduce过程.Mapper阅读过程完成后数据.它将数据发送到Partitioner.由Partitioner每个记录应当采 ...

  3. 几乎没用到过的css 样式

    1. :focus  选择器用于选取获得焦点的元素. 案例:http://www.w3school.com.cn/tiy/t.asp?f=css_sel_focus 2. clearfix清除浮动闭合 ...

  4. 如何在ubuntu 12.04下搭建Python Django环境

    1. 检查python是否安装:直接在shell里输入python,如果已经安装了python,即可进入python bash,并看到版本号(如Python 2.7.3) ——在ubuntu中pyth ...

  5. Swift之函数语法详解

    函数 函数是用来完成特定任务的独立的代码块.你给一个函数起一个合适的名字,用来标识函数做什么,并且当函数需要执行的时候,这个名字会被“调用”. Swift 统一的函数语法足够灵活,可以用来表示任何函数 ...

  6. 浅谈DevExpress<四>:TreeList中的拖拽功能

    本篇要实现的目标,简单来说就是把一个treelist的节点用鼠标拖到另外的节点(自身或其他的listview)上,如下图: 1 

  7. c内存结构

    每个进程都运行在自己私有的内存空间中(即虚拟地址空间).在32位系统中,4GB的进程地址东健被分为用户空间和内核空间两个部分.用户空间占据着 0~3GB(用16进制表示为0xC0000000),而内核 ...

  8. C#类的初始化

      类的构造函数 类的构造函数,有实例构造函数和静态构造函数.如果我们没有构造函数,系统会为我们生成一个默认构造函数,如果我们已经定义了构造函数,系统就不会再为我们生成构造函数. class Simp ...

  9. CSS居中方法搜集

    转自这里:http://jinlong.github.io/blog/2013/08/13/centering-all-the-directions/ 兼容低版本IE的方法 html使用表格结构 背景 ...

  10. IOS使用不同父类的 view 进行约束

    最终效果图如下: 很多限制条件都已经应用到了视图中,我们在解释一下: ·在我们的视图控制器的主视图中有两个灰色的视图.两个视图距视图控制器的视图左 边和右边都有一个标准的空白距离.视图的顶部距顶部的视 ...