使用ant編譯打包、部署簡單的javaweb項目 --02

和上一次的並沒胡什麼不一樣,也就是多了一個使用ant初始化mysql數據庫 html


目錄結構:


D:\code\kongee\ant_web_three
λ tree /f
卷 軟件 的文件夾 PATH 列表
卷序列號爲 000D-CD8E
D:.
│  .classpath
│  .project
│  build.xml
│  studentbak.sql
│
├─.settings
│      .jsdtscope
│      org.eclipse.jdt.core.prefs
│      org.eclipse.wst.common.component
│      org.eclipse.wst.common.project.facet.core.xml
│      org.eclipse.wst.jsdt.ui.superType.container
│      org.eclipse.wst.jsdt.ui.superType.name
│
├─src
│  └─com
│      └─laolang
│          ├─dao
│          │      IStudentDao.java
│          │      StudetDao.java
│          │
│          ├─modle
│          │      Student.java
│          │
│          ├─servlet
│          │      HelloServlet.java
│          │      ShowServlet.java
│          │
│          └─util
│                  DButil.java
│                  student-sql.properties
│
└─WebContent
    │  hello.jsp
    │  index.jsp
    │  show.jsp
    │
    ├─META-INF
    │      MANIFEST.MF
    │
    └─WEB-INF
        │  web.xml
        │
        └─lib
                mysql-connector-java-5.1.28-bin.jar


D:\code\kongee\ant_web_three
λ

代碼:


modle

com.laolang.modle.Student


package com.laolang.modle;

public class Student {

	public Student() {
		super();
	}

	public Student(String name, int age, String sex) {
		super();
		this.name = name;
		this.age = age;
		this.sex = sex;
	}

	public Student(int id, String name, int age, String sex) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
		this.sex = sex;
	}

	@Override
	public String toString() {
		return "Student [id=" + id + ", name=" + name + ", age=" + age
				+ ", sex=" + sex + "]";
	}

	public int getId() {
		return id;
	}

	public void setId(int id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	public String getSex() {
		return sex;
	}

	public void setSex(String sex) {
		this.sex = sex;
	}

	private int id;
	private String name;
	private int age;
	private String sex;
}

dao


IStudentDao


package com.laolang.dao;

import java.util.List;

import com.laolang.modle.Student;

public interface IStudentDao {
	
	public List<Student> selectAll() ;
}

StudentDao



package com.laolang.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import com.laolang.modle.Student;
import com.laolang.util.DButil;

public class StudetDao implements IStudentDao {

	@Override
	public List<Student> selectAll() {
		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		
		List<Student> stus = new ArrayList<Student>();
		
		try {
			conn = DButil.getConnection();
			String sql = "select stuid,stuname,stuage,stusex from student";
			ps = conn.prepareStatement(sql);
			rs = ps.executeQuery();
			
			while( rs.next() ){
				Student stu = new Student();
				stu.setId(rs.getInt("stuid"));
				stu.setName(rs.getString("stuname"));
				stu.setAge(rs.getInt("stuage"));
				stu.setSex(rs.getString("stusex"));
				stus.add(stu);
			}
			
		} catch (SQLException e) {
			e.printStackTrace();
		}finally{
			DButil.close(rs);
			DButil.close(ps);
			DButil.close(conn);
		}
		
		return stus;
	}

}

util


student-sql.properties


jdbc.url=jdbc:mysql://localhost:3306/student
jdbc.username=root
jdbc.userpassword=root
jdbc.driver=com.mysql.jdbc.Driver




com.laolang.util.DButil


package com.laolang.util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ResourceBundle;

public class DButil {

	/** 數據庫鏈接地址 */
	private static String URL;

	/** 數據庫用戶名 */
	private static String USERNAME;

	/** 數據庫密碼 */
	private static String USERPASSWORD;

	/** mysql 驅動 */
	private static String DRIVER;

	/** The rb. */
	private static ResourceBundle rb = ResourceBundle
			.getBundle("com.laolang.util.student-sql");

	/**
	 * 使用靜態代碼塊加載驅動
	 */
	static {
		URL = rb.getString("jdbc.url");
		USERNAME = rb.getString("jdbc.username");
		USERPASSWORD = rb.getString("jdbc.userpassword");
		DRIVER = rb.getString("jdbc.driver");

		try {
			Class.forName(DRIVER);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
	}

	public static Connection getConnection() throws SQLException {
		Connection con = null;
		con = DriverManager.getConnection(URL, USERNAME, USERPASSWORD);
		return con;
	}

	public static void close(Connection con) {
		try {
			if (con != null)
				con.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

	public static void close(PreparedStatement ps) {
		try {
			if (ps != null)
				ps.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

	public static void close(ResultSet rs) {
		try {
			if (rs != null)
				rs.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
}

servlet


com.laolang.servlet.HelloServlet


package com.laolang.servlet;

import java.io.IOException;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class HelloServlet
 */
public class HelloServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public HelloServlet() {
        super();
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doPost(request, response);
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		request.setAttribute("hello", "world");
		RequestDispatcher dis = request.getRequestDispatcher("hello.jsp");
		dis.forward(request, response);
	}

}

com.laolang.servlet.ShowServlet



package com.laolang.servlet;

import java.io.IOException;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.laolang.dao.IStudentDao;
import com.laolang.dao.StudetDao;
import com.laolang.modle.Student;

/**
 * Servlet implementation class ShowServlet
 */
public class ShowServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public ShowServlet() {
        super();
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doPost(request, response);
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		IStudentDao dao = new StudetDao();
		
		List<Student> stus = dao.selectAll();
		
		for( Student stu : stus ){
			System.out.println(stu);
		}
		
		request.setAttribute("stus", stus);
		
		request.getRequestDispatcher("show.jsp").forward(request, response);
		
	}

}

jsp


index.jsp


<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
This is a jsp page!
<br />
<a href="hello.do">hello</a>
<br />
<a href="show.do">show</a>

</body>
</html>

hello.jsp



<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>Hello:${hello }</h1>

</body>
</html>

show.jsp



<%@page import="java.util.List"%>
<%@page import="com.laolang.modle.Student"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<table border="1">
	<tr>
		<th>學號</th>
		<th>姓名</th>
		<th>年齡</th>
		<th>性別</th>
	</tr>
	<%
		//@SuppressWarnings("unchecked")
		List<Student> stus = (List<Student>)request.getAttribute("stus");
		for( Student stu : stus){
	%>
		<tr>
			<td><%=stu.getId() %></td>
			<td><%=stu.getName() %></td>
			<td><%=stu.getAge() %></td>
			<td><%=stu.getSex() %></td>
		</tr>
	<%
		}
	%>
</table>
</body>
</html>

sql


studentbak.sql


/*
SQLyog Ultimate v11.11 (64 bit)
MySQL - 5.5.38 : Database - student
*********************************************************************
*/


/*!40101 SET NAMES utf8 */;

/*!40101 SET SQL_MODE=''*/;

/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
CREATE DATABASE /*!32312 IF NOT EXISTS*/`student` /*!40100 DEFAULT CHARACTER SET utf8 */;

USE `student`;

/*Table structure for table `student` */

DROP TABLE IF EXISTS `student`;

CREATE TABLE `student` (
  `stuid` int(11) NOT NULL AUTO_INCREMENT,
  `stuname` varchar(20) DEFAULT NULL,
  `stuage` int(11) DEFAULT NULL,
  `stusex` varchar(2) DEFAULT NULL,
  PRIMARY KEY (`stuid`)
) ENGINE=InnoDB AUTO_INCREMENT=1006 DEFAULT CHARSET=utf8;

/*Data for the table `student` */

insert  into `student`(`stuid`,`stuname`,`stuage`,`stusex`) values (1001,'xiaodaima',24,'男'),(1002,'小葉子',25,'女'),(1003,'老狼',34,'男'),(1004,'龍女',43,'女'),(1005,'天涯',18,'男');
/*insert  into `student`(`stuid`,`stuname`,`stuage`,`stusex`) values (1001,'小代碼',24,'男'),(1002,'小葉子',25,'女'),(1003,'老狼',34,'男'),(1004,'龍女',43,'女'),(1005,'天涯',18,'男');*/

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

build.xml



<?xml version="1.0" encoding="UTF-8"?>
<project name="ant_web_hello">
	<!-- java源代碼目錄 -->
	<property name="src.dir" location="src" />
	<!-- 構建目錄 -->
	<property name="build.dir" location="build" />
	<!-- class文件目錄 -->
	<property name="build.classes" location="${build.dir}/classes" />
	<!-- 打包目錄 -->
	<property name="build.war" location="${build.dir}/war" />

	<!-- tomcat根目錄 -->
	<property name="tomcat.home" location="D:\program\program\java\tomcat\tomcat" />
	<!-- <property name="tomcat.lib" location="${tomcat.home}/lib" /> -->
	<!-- web 應用的名字,也是打包後war的名字 -->
	<property name="web.name" value="anthello2" />
	<!-- web 根目錄 -->
	<property name="web.root" value="webContent" />
	<property name="web.WEB-INF" location="${web.root}/WEB-INF" />
	<property name="web.lib" location="${web.WEB-INF}/lib" />
	<property name="mysqldriver" location="${web.lib}/mysql-connector-java-5.1.28-bin.jar" />
	<!-- 加載環境變量 -->
	<property environment="env" />

	<!-- 定義編譯時的classpath -->
	<path id="compile.path">
		<fileset dir="${web.lib}" includes="*.lib">
		</fileset>
		<fileset dir="${env.tomcat_home}/lib">
			<include name="*.jar" />
		</fileset>
	</path>

	<target name="init" description="初始化">
		<mkdir dir="${build.dir}" />
		<mkdir dir="${build.classes}" />
		<mkdir dir="${build.war}" />
		<echo>初始化工做結束!</echo>
	</target>

	<target name="compile" depends="init" description="編譯">
		<javac destdir="build/classes" srcdir="src" includeantruntime="false" fork="true">
			<compilerarg line="-encoding UTF-8 " />
			<classpath refid="compile.path" />
		</javac>
		<echo message="編譯完成!" />
	</target>


	<target name="war" depends="compile" description="打包war文件">
		<war destfile="${build.war}/${web.name}.war">
			<fileset dir="${web.root}" includes="**/*.*" />
			<lib dir="${web.lib}" />
			<webinf dir="${web.WEB-INF}" />
			<classes dir="${build.classes}" />
		</war>
		<echo>打包完成!</echo>
	</target>

	<!-- 
	此處有問題,若是使用classpath refid="compile.path" 會提示
	Class Not Found: JDBC driver com.mysql.jdbc.Driver could not be loaded
	<presetdef name="sql-admin">
		<sql userid="root" password="root" url="jdbc:mysql://localhost:3306/mysql?useUnicode=true&amp;characterEncoding=utf-8" driver="com.mysql.jdbc.Driver">
			<classpath refid="compile.path">
			</classpath>
		</sql>
	</presetdef>
	-->

	<presetdef name="mysql-admin">
		<sql userid="root" password="root" url="jdbc:mysql://localhost:3306/mysql?useUnicode=true&amp;characterEncoding=utf-8" driver="com.mysql.jdbc.Driver" classpath="${mysqldriver}" print="true" encoding="utf-8">
		</sql>
	</presetdef>

	<target name="mysql-init" description="初始化數據庫">
		<mysql-admin>
			<transaction src="studentbak.sql" />
		</mysql-admin>
		<echo>數據庫初始化完成!</echo>
	</target>

	<target name="mysql-test" depends="mysql-init" description="數據庫測試">
		<mysql-admin>
			<transaction>
				use student;
				select database();
				show tables;
				select * from student;
			</transaction>
		</mysql-admin>
		<echo>數據庫測試完成!</echo>
	</target>

	<target name="testenv" description="測試環境變量">
		<echo>JAVA_HOME:${env.JAVA_HOME}</echo>
		<echo>CLASSPATH:${env.CLASSPATH}</echo>
		<echo>tomcat_home:${env.tomcat_home}</echo>
		<echo>${web.lib}</echo>
		<echo>${mysqldriver}</echo>
	</target>

	<target name="deploy" depends="mysql-test,war" description="發佈">
		<copy todir="${env.tomcat_home}/webapps">
			<fileset dir="${build.war}" includes="*.war" />
		</copy>
		<echo>已發佈到Tomcat!</echo>
	</target>

	<target name="clean" description="清理">
		<delete dir="${build.dir}" />
		<delete dir="${env.tomcat_home}/webapps/${web.name}" />
		<delete file="${env.tomcat_home}/webapps/${web.name}.war" />
		<echo>清理完成!</echo>
	</target>


</project>

執行過程:


D:\code\kongee\ant_web_two>ant deploy
Buildfile: D:\code\kongee\ant_web_two\build.xml

mysql-init:
[mysql-admin] Executing resource: D:\code\kongee\ant_web_two\studentbak.sql
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 1 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 5 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 0 rows affected
[mysql-admin] 15 of 15 SQL statements executed successfully
     [echo] 數據庫初始化完成!

mysql-test:
[mysql-admin] Executing commands
[mysql-admin] 0 rows affected
[mysql-admin] database()
[mysql-admin] student
[mysql-admin]
[mysql-admin] 0 rows affected
[mysql-admin] TABLE_NAME
[mysql-admin] student
[mysql-admin]
[mysql-admin] 0 rows affected
[mysql-admin] stuid,stuname,stuage,stusex
[mysql-admin] 1001,xiaodaima,24,男
[mysql-admin] 1002,小葉子,25,女
[mysql-admin] 1003,老狼,34,男
[mysql-admin] 1004,龍女,43,女
[mysql-admin] 1005,天涯,18,男
[mysql-admin]
[mysql-admin] 0 rows affected
[mysql-admin] 4 of 4 SQL statements executed successfully
     [echo] 數據庫測試完成!

init:
    [mkdir] Created dir: D:\code\kongee\ant_web_two\build
    [mkdir] Created dir: D:\code\kongee\ant_web_two\build\classes
    [mkdir] Created dir: D:\code\kongee\ant_web_two\build\war
     [echo] 初始化工做結束!

compile:
    [javac] Compiling 6 source files to D:\code\kongee\ant_web_two\build\classes
     [echo] 編譯完成!

war:
      [war] Building war: D:\code\kongee\ant_web_two\build\war\anthello.war
     [echo] 打包完成!

deploy:
     [copy] Copying 1 file to D:\program\program\java\tomcat\tomcat\webapps
     [echo] 已發佈到Tomcat!

BUILD SUCCESSFUL
Total time: 6 seconds

D:\code\kongee\ant_web_two>

在firefox中的運行效果:


index.jsp java

hello.do mysql

show.do web

修改studentbak.sql將xiaodaima修改成小代碼 sql

問題:

一、關於ant的構建目錄和eclipse class的存放目錄

因爲使用ant時構建目錄在build,而eclipse的class存放目錄也是在build,因此每次使用ant進行部署時,必須在eclipse中進行project->clean操做才能夠,不然出現下面的錯誤 shell

我不理解這究竟是爲何,若是說是因爲eclipse自動編譯的class文件的問題,那麼爲何HelloServlet就沒有問題? 數據庫

PS:這裏說的clean是指:在進行ant deploy以前,必需要clean,且clean後不能在eclipse中進行任何操做,不然要再次clean,否則仍是會出現上圖中的錯誤,我修改了ant的構建目錄後,依然不行,這個問題讓我很不解,有哪一個高手指點下? tomcat

二、關於ant 中的sql

使用ant進行mysql操做的時候,不能使用path定義的classpath,也就是說在sql中不能使用classpathref,而應該使用property指向mysql的jar包的相對路徑,再在sql中使用classpath引用 這個property,不然會出現Class Not Found: JDBC driver com.mysql.jdbc.Driver could not be loaded app

若是想要顯示sql的執行結果,能夠將print指定爲true eclipse

相關文章
相關標籤/搜索