本篇通过图文实例给大家详细讲述如何建立一个Servlet,配置好运行环境并成功连接到MYSQL的数据库,进行数据的查询展示。

1.项目创建:IDEA -> Create New Project

2.选择Project SDK(自己装的JDK版本,系统没提示的话自己选择JDK目录),下个界面自己选择工程存储目录和工程名,我起名为DemoServlet

3.了解了文件目录,我们继续往下配置,菜单栏 ->run -> Edit Configurations 下进行配置

4.进去后点击左上角+号(注意不要选择default),添加 tomcat  server->local ,配置 修改name,我这里改为了tomcat;然后Deployment里可以加个war包,点击OK

5.配置完成以后,选择菜单栏->file->project structure ,来添加一些我们需要的包

6.选择Modules-> Dependencies 点击下面+号 添加 如图所示的几个包,第一个(含jsp-api和servlet-api)可以在 tomcat的解压文件夹的\lib里导入,第二个大家可以去下载下,是连接mysql的包,附上下载地址:

http://download.csdn.net/detail/oyuntaolianwu/5822697

注意:一定要悬赏Export,不然可能会报错连接不上数据库

7.配置完成以后,新建我们的Servlet,选中Servlet文件夹-> 右键-> new ->Servlet,我的命名为:Servlet 和文件夹名保持一致。

8.IDEA里自带简单的数据库管理工具,在视图的最右边可以找到,Database,这里我们选择添加 Data Sourse -> MySQL

9.这里大家要去自己的MYSQL里建立Database和User,工具为MYSQL Workbench 或者Sequel Pro,建立了后可在IDEA里点Test Connection测试是否能够成功连接。 IDEA里可以连接了数据库以后实现建表和添加数据,点开IDEA里的控制界面执行建表以及数据插入语句:

CREATE TABLE `websites` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` char(20) NOT NULL DEFAULT '' COMMENT '站点名称',
`url` varchar(255) NOT NULL DEFAULT '',
`alexa` int(11) NOT NULL DEFAULT '' COMMENT 'Alexa 排名',
`country` char(10) NOT NULL DEFAULT '' COMMENT '国家',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
INSERT INTO `websites` VALUES ('', 'Google', 'https://www.google.cm/', '', 'USA'),
('', '淘宝', 'https://www.taobao.com/', '', 'CN'),
('', '微博', 'http://weibo.com/', '', 'CN'),
('', 'Facebook', 'https://www.facebook.com/', '', 'USA');

10.数据库的表和数据建好以后,我们编辑Servlet,写一个简单连接自己建立的mysql库里的一个表的例子,

package Servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.sql.*;
import java.io.*; /**
* Created by weber on 2017/4/20.
*/
@WebServlet("/Servlet")
public class Servlet extends HttpServlet {
private static final long serialVersionUID = 1L;
// JDBC 驱动名及数据库 URL
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL = "jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=false"; // 数据库的用户名与密码,需要根据自己的设置
static final String USER = "weber";
static final String PASS = "123456";
protected void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {
doGet(request, response);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { Connection conn = null;
Statement stmt = null;
// 设置响应内容类型
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
String title = "Servlet Mysql 测试";
String docType = "<!DOCTYPE html>\n";
out.println(docType +
"<html>\n" +
"<head><title>" + title + "</title></head>\n" +
"<body bgcolor=\"#f0f0f0\">\n" +
"<h1 align=\"center\">" + title + "</h1>\n"); try{
// 注册 JDBC 驱动器
Class.forName(JDBC_DRIVER); // 打开一个连接
conn = DriverManager.getConnection(DB_URL,USER,PASS); // 执行 SQL 查询
stmt = conn.createStatement();
String sql;
sql = "SELECT id, name, url FROM websites " ;
ResultSet rs = stmt.executeQuery(sql); // 展开结果集数据库
while(rs.next()){
// 通过字段检索
int id = rs.getInt("id");
String name = rs.getString("name");
String url = rs.getString("url"); // 输出数据
out.println("ID: " + id);
out.println(", 站点名称: " + name);
out.println(", 站点 URL: " + url);
out.println("<br />");
}
out.println("</body></html>"); // 完成后关闭
rs.close();
stmt.close();
conn.close();
} catch(SQLException se) {
// 处理 JDBC 错误
se.printStackTrace();
} catch(Exception e) {
// 处理 Class.forName 错误
e.printStackTrace();
}finally{
// 最后是用于关闭资源的块
try{
if(stmt!=null)
stmt.close();
}catch(SQLException se2){
}
try{
if(conn!=null)
conn.close();
}catch(SQLException se){
se.printStackTrace();
}
} }
}

代码附上

11.这里我们在web.xml里配置Servlet的mapping,就是配置Servlet的前端路径,这样我们可以在浏览器里输入 localhost:8080/test来访问查看

12.一个Servlet基本写完了,这里我们运行project,打开浏览器输入localhost:8080/test来查看是否Servlet建立成功,并且成功连接到数据库,输出结果如下。

至此,一个能成功连接到数据库的Servlet的Demo已经基本完成,下篇介绍如何将Servlet搭建到服务器上,实现和app/web的具体交互。

 

接下来比较忙,所以先简单提一下实现原理:我们已经学会了如何建立一个Servlet,当我们在阿里云/腾讯云上买一个服务器以后,在服务器上搭配和我们刚本地一样的配置环境,并且把生成的Servlet实例放到服务器上进行部署之后,那我们都开自己的手机/电脑就可以输入:123.456.7.8(服务器地址)/api/servlet/test (自己定义的Servlet匹配地址),和我们本地访问不同换了个ip地址而已。这样就放到服务器上啦,同样的数据库建立到服务器上,这样访问的输入一个上述的URL地址访问的就是服务器的数据。这样我们最想了解的后端连接前端的功能就已经实现啦。

至于具体使用Servlet来进行具体app/web的服务,实际上是通过JSON传输的,意思就是真正的doGet会获取一些数据(不像我们刚写的demo没写传来的数据),得到这些数据之后经过一系列处理(比如调用哪个数据库的哪些数据之类),获取要传输的数据,通过建立成JSON格式的数组,这样app端访问这个URL之后就会获取它需要的JSON数据(比如imgURL,imgNAME等等)用于app端/web端的操作使用。

闲了更。要忙一段时间。有问题留言

Servlet:从入门到实战学习(3)---Servlet实例【图文】的更多相关文章

  1. Servlet:从入门到实战学习(2)---Servlet生命周期

    一个Servlet的完整的生命周期(从创建到毁灭)包括:init()方法,service()方法,doGet()方法,doPost()方法,destroy()方法 init()方法用于 Servlet ...

  2. servlet:从入门到实战学习(1)---全·环境配置

    最近公司忙加班学习,学校忙助教工作,博客鸽了好久,后端学习工作过程中学了好多东西,趁着工作之余得空补补博客,算是整理下学习的东西. javaweb的后端研发需要学习的是tomcat+servlet+j ...

  3. 学习Vue 入门到实战——学习笔记

    闲聊: 自从进了现在的公司,小颖就再没怎么接触vue了,最近不太忙,所以想再学习下vue,就看了看vue相关视频,顺便做个笔记嘻嘻. 视频地址:Vue 入门到实战1.Vue 入门到实战2 学习内容: ...

  4. LoadRunner从入门到实战学习路线(持续更新中...)

    写在前面        我是一个测试工程师,从土木工程行业转行到互联网行业,目前是工作的第三年.平时主要做功能测试,性能测试接触比较少,虽然以前培训的时候学习过一些性能相关的知识,但都是入门初级的知识 ...

  5. 学习Vue 入门到实战——学习笔记(二)

    闲聊: 哈哈哈!过了好几天才更新博客啦,嘻嘻,马上过年了,大家最近是不是都开心的快飞起来了,小颖好几个朋友公司都已经放假了,可是我们公司要等到腊月29上完班才给放假,哎!心情不美气的很,用我之前大学舍 ...

  6. javaweb学习总结二十一(servlet开发入门、servlet生命周期以及调用过程)

    一:servlet开发入门 servlet是sun公司一门开发动态web资源的技术,下面编写一个servlet入门程序: 1:在tomcat服务器webapps目录下新建firstServlet目录, ...

  7. 《JavaWeb从入门到改行》那些年一起学习的Servlet

    目录 获取ServletContext : ServletContext接口中的一些方法 application域存取数据功能 代码演示: application域获取项目文件路径 代码演示: API ...

  8. Servlet快速入门:第一个Servlet程序

    Servlet是整个JavaWeb开发的核心,同时也是一套规范,即公共接口.用于处理客户端发来的请求并作出响应.通常情况下我们会发送不同的请求并交由不同的处理程序来处理,例如处理用户信息和处理订单信息 ...

  9. javaweb学习之Servlet开发(二)

    javaweb学习总结(六)--Servlet开发(二) 一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个< ...

随机推荐

  1. Docker 入门相关

    什么是Docker和容器 可能是把Docker的概念讲的最清楚的一篇文章 为什么要用Docker 相关网址 Window平台Docker下载 一些基本知识 Volume docker volume l ...

  2. vSphere通过Client创建Centos7主机

    准备: vSphere Client 客户端 Centos7官方镜像,本次采用的是CentOS-7-x86_64-Minimal-1511.iso 创建过程: 1.登录vSphere虚拟主机,输入账户 ...

  3. Linux 服务器开发常用命令操作

    1)查看网络端口 netstat -na --ip 2)查看特定应用程序进程 ps -ef | grep vsftp  or ps aux | grep xxx.exe 3)查看系统日志 vi /et ...

  4. Getway网关管理ZUUL

    1.ZUUL微服务网关 微服务架构体系中,通常一个业务系统会有很多的微服务,比如:OrderService.ProductService.UserService...,为了让调用更简单,一般会在这些服 ...

  5. springMVC与Struts2区别

    1.拦截级别 Struts2是类级别的拦截,一个类对应一个request上下文 SpringMVC是方法级别的拦截,一个方法对应一个request上下文,而方法同时又跟一个url对应 所以说从架构本身 ...

  6. 执行Hive时出现org.apache.hadoop.util.RunJar.main(RunJar.java:136) Caused by: java.lang.NumberFormatException: For input string: "1s"错误的解决办法(图文详解)

    不多说,直接上干货 问题详情 [kfk@bigdata-pro01 apache-hive--bin]$ bin/hive Logging initialized -bin/conf/hive-log ...

  7. linux mint 19安装 kvm 软件包

    1 我的处理器是2700x 首先安装cpu检测 sudo apt-get install cpu-checker 2 查看cpu内核 egrep -c '(vmx|svm)' /proc/cpuinf ...

  8. Redis之hiredis API (String)

    String // // Created by zhangrongxiang on 2018/3/7 13:48 // File string2 // #include <hiredis/hir ...

  9. Java reflect 反射 3 Class.forname

    Class.forName("xxx.xx.xx") 1 作用:加载类文件Class.forName(xxx.xx.xx) 返回的是一个类 而非对象 作用就是把对象的模板加载到内存 ...

  10. Debian9安装SSH并允许root用户SSH登录

    安装SSH # apt install openssh-server openssh-client 启动SSH服务 # /etc/init.d/ssh start 添加SSH开机启动 # update ...