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{@Overrideprotected 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的问题并且自己的代码都没有报错请看看自己放的文件是否错误

如何用servle和c3p0-DBUtils实现用户登录功能相关推荐

  1. mysql flask-login_Flask框架通过Flask_login实现用户登录功能示例

    本文实例讲述了Flask框架通过Flask_login实现用户登录功能.分享给大家供大家参考,具体如下: 通过Flask_Login实现用户验证登录,并通过login_required装饰器来判断用户 ...

  2. java 记录用户_JavaWeb学习记录(六)——用户登录功能

    使用JDBC.spring框架.servlet实现一个简单的用户登录功能. 一.mySql数据库 SET FOREIGN_KEY_CHECKS=0; -- ---------------------- ...

  3. php mysql用户登录_php mysql实现用户登录功能的代码示例

    接着上次的php mysql添加用户的功能代码,今天来学习下php实现用户登录与注销的功能,通过跟踪session会话来保存用户的登陆状态. 1,登录页面 login.php 用户登录_www.# 用 ...

  4. Apache Shiro实现用户登录功能

    apache shiro实现用户登录功能 配置shiro的Filter实现URL级别权限控制 配置web.xml <!-- shiro的过滤器 --> <filter>< ...

  5. PHP用户登录功能实现

    PHP用户登录功能实现 设计数据库连接,简单查询,表单提交,直接上代码,大家很容易明白. 我建了一个很简单的数据库,表单包括用户名,ID,密码. 用户登录界面 <html><head ...

  6. 如何设计安全的用户登录功能

    用户登录功能是Web应用系统具备的最基本的功能,关系到用户数据和应用系统数据的安全,设计一个安全的用户登录功能,涉及到以下几个方面的内容. (一) 老生常谈--口令 1. 口令长度与复杂度限制 限制用 ...

  7. Vue + Spring Boot 学习笔记02:引入数据库实现用户登录功能

    Vue + Spring Boot 学习笔记02:引入数据库实现用户登录功能 在学习笔记01里,我们利用跨域打通了前端的Vue与后端的Spring Boot,实现了用户登录功能,但是后台的登录控制器在 ...

  8. Vue + Spring Boot 学习笔记01:实现用户登录功能

    Vue + Spring Boot 学习笔记01:实现用户登录功能 一.创建后端Spring Boot项目Book Management 二.创建前端Vue项目bm-vue 三.修改后端项目Book ...

  9. ssm当用户登录成功显示用户名_从零到企业级SSM电商项目实战教程(十八)用户登录功能开发...

    用户模块功能介绍 1.登录 2.用户名验证 3.注册 4.忘记密码 5.提交问题答案 6.重置密码 7.获取用户信息 8.更新用户信息 9.退出登录 学习目标 1.理解横向越权.纵向越权安全漏洞 2. ...

  10. [转]你会做Web上的用户登录功能吗?

    Web上的用户登录功能应该是最基本的功能了,可是在我看过一些站点的用户登录功能后,我觉得很有必要写一篇文章教大家怎么来做用户登录功能.下面的文章告诉大家这个功能可能并没有你所想像的那么简单,这是一个关 ...

最新文章

  1. Bioinformatics|基于知识图谱嵌入的药物靶标发现
  2. 机器学习业务实践之路-李博-专题视频课程
  3. mysql根据注释搜索表
  4. 前端学习(975):bootstrap轮播图
  5. SSL/TLS捕包分析
  6. Linux内存管理之基本概念介绍(一)
  7. linux下重装mysql_Linux下安装mysql
  8. java界面ATM机取款后的余额_java_ATM机银行存取款系统的设计与实现本科毕业论文...
  9. bio nio aio区别_什么是BIO、NIO和AIO?
  10. 【ffmpeg】不带透明通道的视频overlay
  11. linux xps 13 wifi,戴尔XPS 13无线网卡替换教程和教程 | MOS86
  12. Prism初研究之使用Prism 5.0开发模块化应用
  13. MoosejawXRAY:让穿冬装的美女瞬间换上比基尼
  14. 时频分析 matlab 例程,《Matlab时频分析及其应用》的详细代码
  15. 信息系统项目管理师(2022年) —— 第 11 章 项目风险管理
  16. 为什么要学计算机演讲稿,我们为什么要学习科学演讲稿
  17. 51单片机控制蜂鸣器播放《梧桐树》
  18. LabVIEW:自动化引用方法下Excel报表生成与存储子VI创建
  19. Kivy App开发之手势控制
  20. Windows 系统重装 - Mac 制作 Win10 启动盘

热门文章

  1. 深度学习——行数据的分拆及如何“喂”给训练过程
  2. RTT的IPC机制篇——邮箱
  3. 图论——最长路(洛谷 P1807)
  4. 9076什么意思_(9076)《人力资源开发与管理》网上作业题及答案
  5. 华为云苏光牛:生态建设是数据库产业发展非常重要的一环
  6. 26日直播预告丨 经典知识库:ASM元数据简介及案例分享
  7. 实战演练:MySQL手动注册binlog文件造成主从同步异常
  8. Java有了synchronized,为什么还要提供Lock
  9. 云小课 | 守护网络安全不是问题,iptables的四表五链为你开启“八卦阵”
  10. 从定义到AST及其遍历方式,一文带你搞懂Antlr4