您的位置:首页 > 编程语言 > Java开发

Java Web开发-简单的Java Web项目(含访问本地MySQL)-应用例程

2016-08-05 15:39 471 查看
一、例程简介

    本例程可配合Android例程MyApplication测试使用,包含一个TestServlet,用于接收POST请求,访问本地MySQL数据并返回对应消息。

    Android例程的开发请看:http://blog.csdn.net/sinat_30685475/article/details/52126549。

    搭建 Java Web 开发环境(包含Eclipse、Tomcat和MySQL的安装配置)的步骤请看:http://blog.csdn.net/sinat_30685475/article/details/52117384。

二、新建项目

    打开 Eclipse , [File] - [New] - [Dynamic Web Project] ,输入项目名称, [Next] 到最后一页,勾选 “Generate web.xml deployment descriptor”。

三、创建服务器项目主页

    为了在测试Web项目的时候能在浏览器上看到点东西,我们在项目中加入一个 index.html 文件作为访问的默认主页。

    1、展开项目目录,在 WebContent 文件夹下 [New] 一个 [HTML File],命名为 index.html,根据需要输入标题和内容,例如:

<html>
<head>
<meta charset="UTF-8">
<title>MyWebProject</title>
</head>
<body>
<h2>Hello World!</h2>
</body>
</html>
    2、然后,还要在 WebContent/WEB-INF 文件夹下的 web.xml 里添加一些内容,这个文件就像一个目录,将程序和地址关联起来。项目要执行 Servlet 和 html 等都要在这里正确声明,否则会报 404 错误。现在将web.xml 修改成以下这样:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<display-name>MyWebProject</display-name>

<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>

</web-app>
    3、现在,右键项目, [Run as] - [Run on Server] ,运行到本地 Tomcat 服务器后可看到 “http://localhost/MyWebProject/”地址显示出 index.html 对应的页面。注意 Tomcat服务器的默认端口号为8080,这里设为了80,设置方法:找到对应 Tomcat Server 目录下的 server.xml,找到:

<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
    “8080”改为“80”。

四、创建Servlet

    1、在工程目录 Java Resources/src 文件夹下 [New] - [Servlet] ,命名为 TestServlet ,内容如下:

package com.example.z.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.example.z.service.TestService;

//@WebServlet("/TestServlet")
public class TestServlet extends HttpServlet {
private static final long serialVersionUID = 1L;

public TestServlet() {
super();
}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doPost(request, response);
}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 返回字符串
String responseMsg="FAIL";
// 输出流
PrintWriter out = response.getWriter();
// 设置编码形式
request.setCharacterEncoding("utf-8");
// 获取传入数据
String str = request.getParameter("str");

// 访问数据库
int value = TestService.testSelect(str);
if(value == 11) {
responseMsg = "SUCCESS";
}
out.print(responseMsg);
}

}
        当提示无法import javax.servlet,需要在项目导入对应的 .jar 包。右键项目, [Properties] - [Java Build Path] ,选中 [Libraries] 选项卡,点击 [Add External JARs...],选中 Tomcat 安装目录下 lib 文件夹下的 servlet-api.jar 。

        Servlet 的作用主要是读取POST消息中的数据,访问 MySQL 等操作通过调用自定义的 TestService 类中的方法实现。

        注意由于我们已经添加了 web.xml 文件,所以要去掉自动生成的 “@WebServlet("/TestServlet")” 。现在继续修改 web.xml ,加入关于 TestServlet 的信息:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<display-name>MyWebProject</display-name>

<servlet>
<servlet-name>TestServlet</servlet-name>
<servlet-class>
com.example.z.servlet.TestServlet
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>TestServlet</servlet-name>
<url-pattern>/TestServlet</url-pattern>
</servlet-mapping>

<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>

</web-app>


五、TestService类

package com.example.z.service;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import com.example.z.manager.DBManager;

public class TestService {
static PreparedStatement pstmt = null;
static ResultSet rs = null;

public static int testSelect(String str) {
int key = 0;
// 执行 SQL 查询语句
String sql = "select * from t_test where name='" + str +"'";
try {
Connection con = DBManager.getConnection();
pstmt = con.prepareStatement(sql);
try{
rs = pstmt.executeQuery();
// 查询结果
if(rs.next()){
key = rs.getInt("key");
}
pstmt.close();
con.close();
}catch(Exception e){
e.printStackTrace();
}
}catch(Exception e){
e.printStackTrace();
}
return key;
}
}
        自定义类 DBManager 用于连接数据库。该过程需要在 Tomcat 安装目录 lib 文件夹下放入用于连接 MySQL 的 .jar包 “mysql-connector-java-5.1.39-bin.jar” 。我已经在本地 MySQL 中创建了对应的数据库和表格,并插入的数据。执行的 SQL 语句为:

create database db_test;

use db_test;

create table `t_test`(
`id` int not null auto_increment,
`name` varchar(100) default '',
`key` int default 0,
primary key(`id`)
)ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

insert into t_test(`name`,`key`) values ('hello',22);


六、DBManager类
package com.example.z.manager;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DBManager {
// 加载的驱动
private static final String DRIVER_CLASS = "com.mysql.jdbc.Driver";
// 数据库URL
private static final String DATABASE_URL = "jdbc:mysql://localhost:3306/db_test?useUnicode=true&characterEncoding=utf8";
// 数据库连接用户名
private static final String DATABASE_USERNAME = "Admin";
// 数据库连接密码
private static final
4000
String DATEBASE_PASSWORD = "123456";
public static Connection getConnection() throws SQLException {
try {
Class.forName(DRIVER_CLASS);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
Connection con = DriverManager.getConnection(DATABASE_URL,DATABASE_USERNAME, DATEBASE_PASSWORD);
return con;
}
}


七、项目结构

        经过以上步骤,本次Java Web项目已经完成。下面提供工程目录作为参考:



八、代码下载

    CSDN CODE:https://code.csdn.net/sinat_30685475/mywebproject/tree/master。

    CSDN 下载:http://download.csdn.net/detail/sinat_30685475/9596363。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息