ImageVerifierCode 换一换
格式:DOC , 页数:13 ,大小:733KB ,
资源ID:12026238      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/12026238.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(实验三DBCP数据库连接池配置的应用.doc)为本站上传会员【仙人****88】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

实验三DBCP数据库连接池配置的应用.doc

1、实验三DBCP数据库连接池配置的应用 实验内容和要求: 总所周知建立数据库连接是一个非常耗时耗资源的行为,因此现代的Web中间件,无论是开源的Tomcat、Jboss还是商业的websphere、weblogic都提供了数据库连接池功能,可以毫不夸张的说,数据库连接池性能的好坏,不同厂商对连接池有着不同的实现。本实验要求掌握数据库连接池的配置和使用。 项目运行如下图: 实验步骤如下: 1.准备需要访问的数据库 n 下载并安装MySQL5.0 n Copy MySQL5.0驱动mysql-connector-java-5.0.8-bin.jar到%TOMCAT%\lib文件

2、夹下 n 创建数据库及表: 数据库的设计如下表: 数据库采用MySQL5.0,数据库名:rj12,表名:usertab(用户表) 数据库表usertab中数据如下: 2. 配置tomcat,将apache-tomcat-6.0.20.zip压缩文件解压缩,在MyEclipse中配置tomcat6,如图所示: 在windows-〉Preferences-〉MyEclipse-〉Servers-〉Tomcat-〉Tomcat 6.x 配置好以后在Server面板中出现: 3. 驱动mysql-connector-java-5.0.8-bin.jar拷贝到%T

3、OMCAT%\lib文件夹下,在%TOMCAT%\config文件夹下,找到server.xml文件,修改此文件,在之间添加如下代码: 4. 在%TOMCAT%\conf文件夹下编辑web.xml文件,在之间添加如下代码: jdbc/mysqls javax.sql.DataSource Container 5. 在Tomcat安装目录

5、下的\conf\Catalina\localhost文件夹下,找到要配置的Web应用的xml文件,例如web应用为empproject,既是empproject.xml 在之间添加如下代码: 若没有这句,就可能出现 “Cannot c

6、reate JDBC driver of class for connect URL ‘null’ “的错误. 6. 开发过程如下: Step1:在com.pojo包中创建JavaBean: User.java,内容如下: package com.pojo; public class User { private int id; private String username; private String password; public int getId() { return id; } public void setId(int id) {

7、 this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } } Step2:在

8、com.util包中创建访问数据库的工具类—JdbcUti.java,内容如下: package com.util; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import javax.naming.Context; import javax.naming.InitialContext; import javax.sql.DataSource; public class JdbcUti

9、l { private static final String DSNAME = "java:comp/env/jdbc/mysqls"; private static JdbcUtil instance = new JdbcUtil(); private JdbcUtil() { } public static JdbcUtil getInstance() { return instance; } private static Context ctx=null; private static DataSource ds=nul

10、l; // 加载驱动 static { try { //Class.forName(DIVER); ctx=new InitialContext(); ds=(DataSource)ctx.lookup(DSNAME); } catch (Exception e) { // TODO Auto-generated catch block // e.printStackTrace(); System.out.println("数据库驱动加载失败!"); } } // 创建连接 public Connecti

11、on getConn() { Connection conn = null; try { conn=ds.getConnection(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); System.out.println("连接数据库失败!"); } return conn; } // 关闭资源 public void free(Connection conn, Statement

12、stmt, ResultSet rs) { try { if (rs != null) { rs.close(); } else if (stmt != null) { stmt.close(); } else if (conn != null) { conn.close(); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } Step3:采用DAO设计模式

13、 在com.dao包下创建UserDao接口,代码如下: package com.dao; import java.util.List; import com.pojo.User; public interface UserDao { //查询全部信息 List findAll(); //登录 User findOne(String username,String password); //通过Id查一个数据 User findOne(int id); //注册 int insertOne(User user

14、); } 在com.dao.impl包下创建UserDao接口的实现类UserDaoImpl.java,代码如下: package com.dao.impl; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.List; impor

15、t com.dao.UserDao; import com.pojo.User; import com.util.JdbcUtil; public class UserDaoImpl implements UserDao{ public List findAll() { Connection conn=JdbcUtil.getInstance().getConn(); String sql="select * from usertab"; List list=new ArrayList(); Statement st

16、mt=null; ResultSet rs=null; try { stmt=conn.createStatement(); rs=stmt.executeQuery(sql); while(rs.next()){ User user=new User(); user.setId(rs.getInt("id")); user.setUsername(rs.getString("username")); user.setPassword(rs.getString("password")); list.

17、add(user); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ JdbcUtil.getInstance().free(conn, stmt, rs); } return list; } //登录 public User findOne(String username, String password) { Connection conn=JdbcUtil.getInstan

18、ce().getConn(); String sql="select * from usertab where username=? and password=?"; PreparedStatement pstmt=null; ResultSet rs=null; User user=null; try { pstmt=conn.prepareStatement(sql); pstmt.setString(1, username); pstmt.setString(2, password); rs=pstmt.execut

19、eQuery(); if(rs.next()){ user=new User(); user.setId(rs.getInt("id")); user.setUsername(rs.getString("username")); user.setPassword(rs.getString("password")); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{

20、 JdbcUtil.getInstance().free(conn, pstmt, rs); } return user; } public User findOne(int id) { // TODO Auto-generated method stub return null; } public int insertOne(User user) { // TODO Auto-generated method stub return 0; } } Step4:根据MVC设计模式,在com.serv

21、ice包下创建UserService.java 接口,代码如下: package com.service; import java.util.List; import com.pojo.User; public interface UserService { List findAll(); } 在com.service.impl包下创建实现了UserService接口的实现类UserServiceImpl.java,代码如下: package com.service.impl; import java.util.List; import

22、 com.dao.UserDao; import com.dao.impl.UserDaoImpl; import com.pojo.User; import com.service.UserService; public class UserServiceImpl implements UserService{ private UserDao ud=new UserDaoImpl(); public List findAll() { // TODO Auto-generated method stub return ud.findAll();

23、} } Step5:修改在WebRoot下的index.jsp页面。代码如下: 查看所有用户信息 其中flag是在UserServlet中接收的一个标志参数,flag=1时所实现的功能是到数据库中查询全部信息。 Step6:在com.servlet包下创建一个Servlet,UserServlet.java代码如下: package servlet; import java.io.IOException; import java.util.List; imp

24、ort javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.pojo.User; import com.service.UserService; import com.service.impl.UserServiceImpl; public class UserServlet e

25、xtends HttpServlet { private UserService us=new UserServiceImpl(); public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } public void doPost(HttpServletRequest request, HttpServletResponse

26、response) throws ServletException, IOException { response.setContentType("text/html;charset=utf-8"); request.setCharacterEncoding("utf-8"); response.setCharacterEncoding("utf-8"); String flag=request.getParameter("flag"); int select=0; if(flag!=null){ select=Integer.p

27、arseInt(flag); } switch (select) { case 1: findAll(request,response); break; default: break; } } //查询全部用户信息 public void findAll(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { List list=us.findAll()

28、 request.setAttribute("list", list); request.getRequestDispatcher("list.jsp").forward(request, response); } } 注意:在servlet中只能调用service层中的方法,遵循MVC设计原则。 Step6:在WebRoot下增加list.jsp页面,显示从数据库中查到的所有数据。代码如下: <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib prefix

29、"c" uri=" My JSP 'list.jsp' starting page 显示用户信息

用户ID 用户名 用户密码

30、

${u.id } ${u.username} ${u.password}
总结:本实验要求对MVC设计模式的各个层深刻理解,要求会写连接数据库的工具类JdbcUtil类。

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服