使用 servlet 连接数据库

1.项目工程 web.xml 配置

 1 <servlet>
2 <description>This is the description of my J2EE component</description>
3 <display-name>This is the display name of my J2EE component</display-name>
4 <servlet-name>DBServlet</servlet-name>
5 <servlet-class>org.olive.DBServlet</servlet-class>
6 <init-param>
7 <param-name>driverName</param-name>
8 <param-value>com.microsoft.jdbc.sqlserver.SQLServerDriver</param-value>
9 </init-param>
10 <init-param>
11 <param-name>username</param-name>
12 <param-value>sa</param-value>
13 </init-param>
14 <init-param>
15 <param-name>password</param-name>
16 <param-value></param-value>
17 </init-param>
18 <init-param>
19 <param-name>dbName</param-name>
20 <param-value>pubs</param-value>
21 </init-param>
22
23 </servlet>
1 <servlet-mapping>
2 <servlet-name>DBServlet</servlet-name>
3 <url-pattern>/servlet/DBServlet</url-pattern>
4 </servlet-mapping>

2.servlet  java文件

DBServlet.java
 1 package org.olive;
2
3 import java.io.*; //导入java.io包
4 import java.util.*;
5 import java.sql.*;
6 import javax.servlet.*;
7 import javax.servlet.http.*;
8 public class DBServlet extends HttpServlet{ //定义一个继承HttpServlet的公有类
9 ServletConfig config=null; //定义一个ServletConfig对象
10 private String driverName=""; //定义私有字符串常量并初始化
11 private String username=""; //定义的数据库用户名
12 private String password=""; //定义的数据库连接密码
13 private String dbName=""; //定义的数据库名
14 private Connection conn; //初始化连接
15 private Statement stmt; //初始化数据库操作
16 ResultSet rs=null; //初始化结果集
17 public void init(ServletConfig config)throws ServletException{
18 super.init(config); //继承父类的init()方法
19 this.config=config; //获取配置信息
20 driverName=config.getInitParameter("driverName");//从配置文件中获取JDBC驱动名
21 username=config.getInitParameter("username"); //获取数据库用户名
22 password=config.getInitParameter("password"); //获取数据库连接密码
23 dbName=config.getInitParameter("dbName"); //获取要连接的数据库
24 }
25 public void doGet(HttpServletRequest req,HttpServletResponse resp)throws IOException,ServletException{
26
27 resp.setContentType("text/html;charset=GBK"); //设置字符编码格式
28 PrintWriter out=resp.getWriter(); //实例化对象,用于页面输出
29 out.println("<html>"); //实现生成静态Html
30 out.println("<head>");
31 out.println("<meta http-equiv=\"Content-Type\"content=\"text/html;charset=GBK\">");
32 out.println("<title>DataBase Connection</title>");
33 out.println("</head>");
34 out.println("<body bgcolor=\"white\">");
35 out.println("<center>");
36 String url="jdbc:microsoft:sqlserver://localhost:1433; DatabaseName=pubs";
37 try{
38 Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
39 conn=DriverManager.getConnection(url,username,password);
40 stmt=conn.createStatement();
41 String sql="use pubs select * from publishers";
42 rs=stmt.executeQuery(sql);
43 out.println("Servlet访问数据库成功");
44 out.println("<table border=1 bordercolorlight=#000000>");
45 out.println("<tr><td width=40>序号</td>");
46 out.println("<td>书名</td>");
47 out.println("<td>城市</td>");
48 out.println("<td>州</td>");
49 out.println("<td>国</td></tr>");
50 while(rs.next()){
51 out.println("<tr><td>"+rs.getString(1)+"</td>");
52 out.println("<td>"+rs.getString(2)+"</td>");
53 out.println("<td>"+rs.getString(3)+"</td>");
54 out.println("<td>"+rs.getString(4)+"</td>");
55 out.println("<td>"+rs.getString(5)+"</td>");
56 out.println("<tr>");
57 }
58 out.println("</table>");
59 rs.close();
60 stmt.close();
61 conn.close();
62
63 }catch(Exception e){
64 e.printStackTrace();
65 out.println(e.toString());
66 }
67 out.println("</center>");
68 out.println("</body>");
69 out.println("</html>");
70 }
71 public void doPost(HttpServletRequest req,HttpServletResponse resp)throws IOException,ServletException{
72 this.doGet(req,resp);
73 }
74 public void destory(){
75 config=null;
76 driverName=null;
77 username=null;
78 password=null;
79 dbName=null;
80 conn=null;
81 stmt=null;
82 rs=null;
83 }
84 }




本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/464042.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

我用涂鸦模块做的报警系统

在上次发的涂鸦的文章之后涂鸦的这套宠物SDK设计&#xff0c;真香最近刚好有一个朋友需要做一个DEMO&#xff0c;这个DEMO是和图像识别相关的&#xff0c;我这个朋友在一个烟火报警的设备&#xff0c;大家都知道我们住的小区里面都会有一个监控系统吧&#xff0c;监控系统里面是…

二叉树的非递归操作

这里涉及到二叉树的非递归操作有&#xff1a;先序遍历、中序遍历、后序遍历数据结构树结点&#xff1a;structNode { chardata; Node *left; Node *right; };标志&#xff1a;enumTag{goLeft, goRight, goBack };goLeft指示访问左子树goLeft指示访问右子树&#xf…

建立公司

最近标哥说有创业的想法&#xff0c;然后我帮忙搜了下关于创办公司的一些文章&#xff0c;晓宇的这篇文章把创业的过程写了个大概&#xff0c;也分享给大家&#xff0c;如果有创业想法的&#xff0c;按照这样的思路去寻找自己的合伙人。 自从17年4月份开始辞职创业&#xff0c;…

第五节 CImage和CBmp(二)

由于这个库主要用于VC MFC下开发应用&#xff0c;因此目前可以下载到版本只支持MFC开发。如果您需要标准Win32的库&#xff0c;可以在回复时留下您的邮箱&#xff0c;或跟我联系。Email&#xff1a;wuchunlei163.comQQ&#xff1a;819543772EasyAnalysis图像分析库测试版以及源…

Linux 新系统易用性向 Windows 看齐

大家好&#xff0c;今天是一年一度的高考&#xff0c;不知道各位在多年以前有没有后悔选择电子专业&#xff0c;如果再给你一次机会&#xff0c;你会选择其他专业吗&#xff1f;以下是内容正文&#xff0c;由黄工整理&#xff01;来源 | 网络嵌入式开发&#xff0c;很多工程师都…

深度剖析SOC高性能实时事件关联分析引擎

【引言】安全管理平台&#xff08;SOC&#xff09; 的一项关键技术就是事件关联分析。借助实时的事件关联分析引擎&#xff0c;安全管理平台能够发掘出复杂的海量安全日志和事件背后隐藏的信息&#xff0c;引导安全管理人员发现外 部***和内部违规行为。作为本系列的第五篇文章…

靠,嘉立创打板又降价

说个题外话&#xff0c;我前段时间和同事聊天&#xff0c;我同事是一个项目经理&#xff0c;我跟他说我有朋友在嘉立创&#xff0c;然后随口说了句&#xff0c;我们这个行业应该没有不知道嘉立创的吧&#xff0c;我同事回了一句&#xff0c;什么是嘉立创&#xff0c;然后我愣了…

拆解一个比亚迪的车钥匙,这个黑黑的元器件是什么?

今天抽屉突然找到一个比亚迪的车钥匙&#xff0c;寻思着没事拆开看看用什么方案做的。正面照&#xff0c;哪款车型的&#xff0c;不知道了背面照&#xff0c;很简洁&#xff0c;只有一个BYD的Logo接下来就是撬开了&#xff0c;过程非常顺利&#xff0c;之前撬开一个宝马车的钥匙…

分布式事物(同样适用于dubbo事务等分布式事务)

转载于:https://www.cnblogs.com/tian1993/p/10081901.html

一些web开发中常用的、做成cs文件的js代码 - 搜刮来的

using System;using System.Web;using System.Web.UI;namespace COCOWO.COMP{ /// <summary> /// 一些常用的Js调用 /// 创建时间&#xff1a;2006-8-3 /// 创建者&#xff1a;马先光 /// </summary> public class Jscript { …

库里扛起了勇士对凯尔特人的第四场

最近临近毕业季&#xff0c;有朋友这样说「我一定是要支持勇士的&#xff0c;毕竟库里和詹姆斯陪了整个大学四年啊」。昨晚上加班到11点半&#xff0c;到家洗完澡已经是凌晨1点了&#xff0c;那时候是想得很清楚的&#xff0c;明天是不想被其他事情打扰我看球赛的。这场比赛&am…

Nginx应用案例分享:压力测试

2019独角兽企业重金招聘Python工程师标准>>> 在运维工作中&#xff0c;压力测试是一项非常重要的工作。比如在一个网站上线之前&#xff0c;能承受多大访问量、在大访问量情况下性能怎样&#xff0c;这些数据指标好坏将会直接影响用户体验。 但是&#xff0c;在压力…

声音是什么?

转自博客园《【秒懂音视频开发】02_重识声音》&#xff0c;https://www.cnblogs.com/mjios/p/14466418.html#5035688#!comments声音的产生声音&#xff08;Sound&#xff09;&#xff0c;是由物体的振动产生的。一切正在发声的物体都在振动。我们说话的时候&#xff0c;是声带在…

[源码和文档分享]基于C语言的语法高亮设计与实现

一 需求分析 在所需高亮的关键字或字符串前后加上class标签&#xff0c;在css定义颜色。 二 程序设计 2.1 设计思路 把.html文件和.css文件中的内容存在两个字符数组中&#xff0c;在.cpp用文件操作写入。 2.2 文件组织架构 Syntax highlighting.exe所在目录为根目录 源代码命…

我愿为这二极管奉献我的一生

简 介&#xff1a; 利用二极管完成对信号的整流&#xff0c;求取绝对值等具有很多的应用。然而在小信号下&#xff0c;二极管的前向导通电压以及相应的杂散电容会对信号整流带来严重的影响。本文从“马场清太郎”所著的“运算放大器应用电路设计”中摘取了一些典型应用电路&…

【毕业设计】履带四足复合机器人

1.项目简介本项目中&#xff0c;履足式复合机器人拥有两种行进模式&#xff1a;四足行进模式、履带行进模式&#xff0c;应对不同场景及地形时能够切换形态。四足形态下整体总共拥有8个自由度DOF&#xff0c;单腿各具备2个自由度DOF&#xff0c;足端结构融入了履带机构&#xf…

c#: 任务栏进度显示(TaskbarManager)

Win7及以上系统支持任务栏进度条&#xff0c;为有进度类应用显示进度于任务栏&#xff0c;甚为方便。 以c#之WinForm实现其&#xff0c;大多采用Windows API Code Pack这个方案&#xff0c;加多引用&#xff0c;比较繁琐&#xff0c;而我总也打不开了其页面。 鄙人不喜欢多引用…

今天,过了27年后,IE浏览器停用了

前言随着Windows的官宣&#xff0c;ie浏览器将于6月16日正式退役。https://www.microsoft.com/zh-cn/download/internet-explorer.aspx那个曾几何时的浏览器之王&#xff0c;经历一次又一次操作系统的迭代&#xff0c;直至新兴浏览器的出现后沦为浏览器鄙视链的最后一层&#x…

boost库学习入门篇

学习及使用Boost库已经有一段时间了&#xff0c;Boost为我的日常开发中带来了极大的方便&#xff0c;也使得我越来越依赖于boost库了。但boost功能太多&#xff0c;每次使用还是得翻看以前的 资料&#xff0c;所以为了以后可以更方便的使用&#xff0c;在此对常用的功能作一个…

开源 STM32 USB-CAN项目

照理来说&#xff0c;USB-CAN这种东西应该已经被做的烂大街的工具&#xff0c;国内居然没有一个拿得出手的开源方案。某立功和PCAN动辄2000的价格也是离谱。淘宝上各种虚拟串口方案、替换dll兼容某立功软件的各种方案....价格都倒是便宜&#xff0c;性能和可靠性嘛.......就不多…