package com.product.jdbc.dbutil;
import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class JdbcUtils {
// 表示定义数据库的用户名
private final String USERNAME = "root";
// 定义数据库的密码
private final String PASSWORD = "yanzi";
// 定义数据库的驱动信息
private final String DRIVER = "com.mysql.jdbc.Driver";
// 定义访问数据库的地址
private final String URL = "jdbc:mysql://localhost:3306/mydb";
// 定义数据库的链接
private Connection connection;
// 定义sql语句的执行对象
private PreparedStatement pstmt;
// 定义查询返回的结果集合
private ResultSet resultSet;
// 实现批处理操作的功能
private Statement stmt;
public JdbcUtils() {
try {
Class.forName(DRIVER);
System.out.println("注册驱动成功!!");
} catch (Exception e) {
// TODO: handle exception
}
}
// 定义获得数据库的链接
public Connection getConnection() {
try {
connection = DriverManager.getConnection(URL, USERNAME, PASSWORD);
} catch (Exception e) {
// TODO: handle exception
}
return connection;
}
public boolean deleteByBatch(String[] sql) throws SQLException{
boolean flag = false;
stmt = connection.createStatement();
if(sql!=null){
for(int i=0;i<sql.length;i++){
stmt.addBatch(sql[i]);
}
}
int[] count = stmt.executeBatch();
if(count!=null){
flag = true;
}
return flag;
}
/**
* 完成对数据库的表的添加删除和修改的操作
*
* @param sql
* @param params
* @return
* @throws SQLException
*/
public boolean updateByPreparedStatement(String sql, List<Object> params)
throws SQLException {
boolean flag = false;
int result = -1;// 表示当用户执行添加删除和修改的时候所影响数据库的行数
pstmt = connection.prepareStatement(sql);
int index = 1;
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
result = pstmt.executeUpdate();
flag = result > 0 ? true : false;
return flag;
}
/**
* 查询返回单条记录
*
* @param sql
* @param params
* @return
* @throws SQLException
*/
public Map<String, Object> findSimpleResult(String sql, List<Object> params)
throws SQLException {
Map<String, Object> map = new HashMap<String, Object>();
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();// 返回查询结果
ResultSetMetaData metaData = resultSet.getMetaData();
int col_len = metaData.getColumnCount();// 获得列的名称
while (resultSet.next()) {
for (int i = 0; i < col_len; i++) {
String cols_name = metaData.getColumnName(i + 1);
Object cols_value = resultSet.getObject(cols_name);
if (cols_value == null) {
cols_value = "";
}
map.put(cols_name, cols_value);
}
}
return map;
}
/**
* 查询返回多行记录
*
* @param sql
* @param params
* @return
* @throws SQLException
*/
public List<Map<String, Object>> findMoreResult(String sql,
List<Object> params) throws SQLException {
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();
ResultSetMetaData metaData = resultSet.getMetaData();
int cols_len = metaData.getColumnCount();
while (resultSet.next()) {
Map<String, Object> map = new HashMap<String, Object>();
for (int i = 0; i < cols_len; i++) {
String cols_name = metaData.getColumnName(i + 1);
Object cols_value = resultSet.getObject(cols_name);
if (cols_value == null) {
cols_value = "";
}
map.put(cols_name, cols_value);
}
list.add(map);
}
return list;
}
// jdbc的封装可以用反射机制来封装:
public <T> T findSimpleRefResult(String sql, List<Object> params,
Class<T> cls) throws Exception {
T resultObject = null;
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();
ResultSetMetaData metaData = resultSet.getMetaData();
int cols_len = metaData.getColumnCount();
while (resultSet.next()) {
// 通过反射机制创建实例
resultObject = cls.newInstance();
for (int i = 0; i < cols_len; i++) {
String cols_name = metaData.getColumnName(i + 1);
Object cols_value = resultSet.getObject(cols_name);
if (cols_value == null) {
cols_value = "";
}
Field field = cls.getDeclaredField(cols_name);
field.setAccessible(true);// 打开javabean的访问private权限
field.set(resultObject, cols_value);
}
}
return resultObject;
}
/**
* 通过反射机制访问数据库
*
* @param <T>
* @param sql
* @param params
* @param cls
* @return
* @throws Exception
*/
public <T> List<T> findMoreRefResult(String sql, List<Object> params,
Class<T> cls) throws Exception {
List<T> list = new ArrayList<T>();
int index = 1;
pstmt = connection.prepareStatement(sql);
if (params != null && !params.isEmpty()) {
for (int i = 0; i < params.size(); i++) {
pstmt.setObject(index++, params.get(i));
}
}
resultSet = pstmt.executeQuery();
ResultSetMetaData metaData = resultSet.getMetaData();
int cols_len = metaData.getColumnCount();
while (resultSet.next()) {
T resultObject = cls.newInstance();
for (int i = 0; i < cols_len; i++) {
String cols_name = metaData.getColumnName(i + 1);
Object cols_value = resultSet.getObject(cols_name);
if (cols_value == null) {
cols_value = "";
}
Field field = cls.getDeclaredField(cols_name);
field.setAccessible(true);
field.set(resultObject, cols_value);
}
list.add(resultObject);
}
return list;
}
public void releaseConn() {
if (resultSet != null) {
try {
resultSet.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (stmt != null) {
try {
stmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (pstmt != null) {
try {
pstmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (connection != null) {
try {
connection.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
基于Servlet、JSP、JDBC、MySQL的登录模块
共131个文件
jpg:55个
gif:35个
java:8个
5星 · 超过95%的资源 需积分: 9 274 下载量 156 浏览量
2014-06-04
23:59:33
上传
评论 7
收藏 1.74MB ZIP 举报
温馨提示
接前文的注册模块,本篇是登录模块。主要包括登录主界面,和登录相关编写的LoginAction、LoginDao和LoginService。以及配置的Filter。参见博客 http://blog.csdn.net/yanzi1225627/article/details/28489371
资源推荐
资源详情
资源评论
收起资源包目录
基于Servlet、JSP、JDBC、MySQL的登录模块 (131个子文件)
JdbcUtils.class 7KB
RegisterAction.class 3KB
LoginAction.class 3KB
MyFilter.class 2KB
LoginDao.class 1KB
RegisterDao.class 1KB
RegisterService.class 247B
LoginService.class 231B
.classpath 529B
org.eclipse.wst.common.component 471B
org.eclipse.wst.jsdt.ui.superType.container 49B
duan_1.css 3KB
zs.gif 8KB
jiantou.gif 2KB
dh-2.gif 2KB
dh.gif 2KB
zc-2.gif 1KB
dl-2.gif 1KB
复件 dhpd.gif 1KB
dhpd2.GIF 1KB
dhpd.gif 1KB
zc-1.gif 1KB
dh-1.gif 818B
a-left.gif 679B
a-right.gif 678B
dl-1.gif 664B
1825.gif 450B
2518.gif 411B
xh.gif 371B
xh1.gif 362B
a-middle.gif 283B
abj.gif 236B
abj2.gif 204B
sr.gif 200B
su.gif 194B
jiao.gif 165B
hdw.gif 73B
dhpddw.gif 73B
dhjt.gif 70B
L2.gif 66B
jt2.gif 66B
L1.gif 66B
hdw1.gif 60B
dw.gif 59B
jt.gif 58B
s-1.gif 50B
h-1.gif 50B
mysql-connector-java-5.1.26-bin.jar 836KB
JdbcUtils.java 7KB
RegisterAction.java 3KB
LoginAction.java 3KB
MyFilter.java 1KB
RegisterDao.java 921B
LoginDao.java 783B
RegisterService.java 160B
LoginService.java 145B
it.jpg 110KB
pioneer_4.jpg 109KB
pioneer_3.jpg 105KB
123.jpg 88KB
pioneer_2.jpg 54KB
pioneer_1.jpg 40KB
glmb.jpg 19KB
jxtj_2.jpg 18KB
bjzb_2.jpg 18KB
lxck_2.jpg 18KB
bjfj_2.jpg 17KB
sczb_2.jpg 17KB
wjsc_2.jpg 17KB
bjcy_2.jpg 17KB
bjrw_2.jpg 17KB
ck_2.jpg 16KB
ok_2.jpg 16KB
ttj_2.jpg 16KB
fh_2.jpg 16KB
jxtj_1.jpg 16KB
lxck_1.jpg 16KB
bjfj_1.jpg 16KB
qx_2.jpg 16KB
cx_2.jpg 16KB
sczb_1.jpg 16KB
tj_2.jpg 16KB
wjsc_1.jpg 16KB
sc_2.jpg 16KB
xg_2.jpg 16KB
jj_2.jpg 16KB
bjzb_1.jpg 16KB
bjcy_1.jpg 15KB
bjrw_1.jpg 15KB
666_3.jpg 15KB
666_2.JPG 15KB
ck_1.jpg 15KB
ok_1.jpg 15KB
ttj_1.jpg 15KB
fh_1.jpg 15KB
jj_1.jpg 15KB
hf_2.jpg 15KB
qx_1.jpg 15KB
rb_2.jpg 15KB
cx_1.jpg 15KB
共 131 条
- 1
- 2
yanzi1225627
- 粉丝: 7767
- 资源: 128
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
- 1
- 2
- 3
前往页