如何用servle和c3p0-DBUtils实现用户登录功能

DBUtils工具简介

ResultSetHandler接口:
用于处理ResultSet结果集,将结果集的的数据转换成不同形式。该接口的实现类有很多:
ArrayHandler 将结果集中的第一条记录封装到一个Object[]数组中,数组中的每一个元素就是这条记录中的每一个字段的值。
ArrayListHandler 将结果集中的每一条记录都封装到一个Object[]数组中,将这些数组在封装到List集合中。
BeanHandler 将结果集中第一条记录封装到一个指定的javaBean中。
BeanListHandler 将结果集中每一条记录封装到指定的javaBean中,将这些javaBean在封装到List集合中。
ColumnListHandler 将结果集中指定的列的字段值,封装到一个List集合中。
ScalarHandler 它是用于单列数据查询。例如:select count(*) from users 操作。
MapHandler 将结果集中第一条记录封装到Map集合中,Key代表列名, Value代表该列数据。
MapListHandler 将结果集中每一条记录封装到Map集合中,Key代表列名, Value代表该列数据,Map集合再存储到List集合

javaBean

JavaBean是使用Java语言开发的一个可重用的组件,在JSP的开发中可以使用JavaBean减少重复代码,使整个JSP代码的开发更简洁。简单来讲就是实体类,用来支持业务逻辑的协助类,在JDBC操作中一般一个实体类会对应数据库中的一张表,实体类中的属性会与表中的列一一对应。
JavaBean的设计原则:
(1)类必须公有,即使用public修饰
(2)类中属性必须私有,即使用private修饰
(3)必须为每个属性封装get/set方法
(4)类中必须有无参构造
**

用户登录代码

  1. 导入对应的jar包
  2. 书写c3p0.properties文件
  3. 书写代码

实体类

package com.login.entity;

public class Admin {
private String username;
private int pwd;
public String getUsername() {
	return username;
}
public void setUsername(String username) {
	this.username = username;
}
public int getPwd() {
	return pwd;
}
public void setPwd(int pwd) {
	this.pwd = pwd;
}
}

**
查询数据库

package com.login.dao;

import java.sql.SQLException;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;

import com.login.entity.Admin;
import com.mchange.v2.c3p0.ComboPooledDataSource;

public class AdminDao {
	QueryRunner q=new QueryRunner(new ComboPooledDataSource());
	public Admin login(String username,String pwd) {
		Admin admin=null;
		String sql="select * from admin where username=? and pwd=?";
		try {
			admin=q.query(sql, new BeanHandler<Admin>(Admin.class), username,pwd);
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return admin;
	}
	

}

servlet 类

package com.login.servlet;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.login.dao.AdminDao;
import com.login.entity.Admin;

public class servletLogin  extends HttpServlet{
	@Override
	protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		req.setCharacterEncoding("utf-8");
		resp.setContentType("text/html;charset=utf-8");
		String username = req.getParameter("username");
		String pwd = req.getParameter("pwd");
		AdminDao admin = new AdminDao();
		PrintWriter writer = resp.getWriter();
		Admin login = admin.login(username, pwd);
		if (login != null) {
			writer.print("登录成功");
		} else {
			writer.print("登录失败");
		}
	}
}

注意:如果出现了404的问题并且自己的代码都没有报错请看看自己放的文件是否错误

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值