deviceInfos.jsp

<%@page import="java.io.BufferedReader"%>
<%@page import="java.io.FileReader"%>
<%@page import="java.io.*"%>
<%@ page import="java.sql.*" %>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="utf-8" %>
<html>
    <head>
        <title>jsp作业3</title>
        <meta charset="utf-8">
        <script src="js/jquery-1.9.1.min.js" type="text/javascript"></script>
        <link rel="stylesheet" type="text/css" href="my_css.css">
        	<script type="text/javascript">
        	var nowChangingRow;
            function deleteRow(r)
            {
            	
       			if(confirm("您确定需要删除吗?"))
       			{
       				var nowChangingRow = r.parentNode.parentNode.rowIndex;
                    var table=document.getElementById("equipmentTable");
                    var nowRow=table.rows[nowChangingRow].cells;
       				location.href="${pageContext.request.contextPath}/EquipmentDeleteServlet?deviceCode="+nowRow[2].innerHTML;
       			}
            }
            function isRightTime(installationTime)
            {
                var i;
                if(installationTime.length<19)
                {
                    alert("输入的时间字符串过短!");
                    return 0;
                }
                /*下面是判断是否是数字*/
                for(i=0;i<=3;++i)if(installationTime[i]<'0'||installationTime[i]>'9')return 0;
                if(installationTime[4]!='-')return 0;
                for(i=5;i<=6;++i)if(installationTime[i]<'0'||installationTime[i]>'9')return 0;
                if(installationTime[7]!='-')return 0;
                for(i=8;i<=9;++i)if(installationTime[i]<'0'||installationTime[i]>'9')return 0;
                if(installationTime[10]!=' ')return 0;
                for(i=11;i<=12;++i)if(installationTime[i]<'0'||installationTime[i]>'9')return 0;
                if(installationTime[13]!=':')return 0;
                for(i=14;i<=15;++i)if(installationTime[i]<'0'||installationTime[i]>'9')return 0;
                if(installationTime[16]!=':')return 0;
                for(i=17;i<=18;++i)if(installationTime[i]<'0'||installationTime[i]>'9')return 0;
                if(installationTime.length>19)
                {
                    alert("输入的时间字符串过长!");
                    return 0;
                }
                
                var nian=0,yue=0,ri=0,shi=0,fen=0,miao=0;
                for(i=0;i<=3;++i)nian=nian*10+(installationTime[i]-'0');
                for(i=5;i<=6;++i)yue=yue*10+(installationTime[i]-'0');
                for(i=8;i<=9;++i)ri=ri*10+(installationTime[i]-'0');
                for(i=11;i<=12;++i)shi=shi*10+(installationTime[i]-'0');
                for(i=14;i<=15;++i)fen=fen*10+(installationTime[i]-'0');
                for(i=17;i<=18;++i)miao=miao*10+(installationTime[i]-'0');
                if(yue>12)
                {
                    alert("月份不能超过12!");
                    return 0;
                }
                if((yue==1||yue==3||yue==5||yue==7||yue==8||yue==10||yue==12)&&ri>31)
                {
                    alert("该月份日期不能超过31!");
                    return 0;
                }
                if((yue==4||yue==6||yue==9||yue==11)&&ri>30)
                {
                    alert("该月份日期不能超过30!");
                    return 0;
                }
                if(yue==2)
                {
                    if((nian%100!=0&&nian%4==0)||(nian%100==0&&nian%400==0))//闰年
                    {
                        if(ri>29)
                        {
                            alert("这一年2月日期不能超过29!");
                            return 0;
                        }
                    }
                    else
                    {
                        if(ri>28)
                        {
                            alert("这一年2月日期不能超过28!");
                            return 0;
                        }
                    }
                }
                if(shi>23)
                {
                    alert("小时不能超过23!");
                    return 0;
                }
                if(fen>59)
                {
                    alert("分钟不能超过59!");
                    return 0;
                }
                if(miao>59)
                {
                    alert("秒数不能超过59!");
                    return 0;
                }
                return 1;
            }
            function isExisting(str)
            {
            	var table=document.getElementById("equipmentTable");
            	var i,totRow=table.rows.length;
                for(i=1;i<totRow;++i)
               	{
                    nowRow=table.rows[i].cells;
                    if(i!=nowChangingRow&&str===nowRow[2].innerHTML)return true;
               	}
            	return false;
            }
            function confirmInput1() 
            {
                if ( $("#equipmentName1").val() == null || $("#equipmentName1").val() == "" ) 
                {
                    alert("设备名称不能为空!");
                    $("#equipmentName1").focus();
                    return false;
                } 
                if ( $("#equipmentCode1").val() == null || $("#equipmentCode1").val() == "" ) 
                {
                    alert("设备编码不能为空!");
                    $("#equipmentCode1").focus();
                    return false;
                } 
                if (isExisting($("#equipmentCode1").val())) 
                {
                    alert("设备编码不能重复!");
                    $("#equipmentCode1").focus();
                    return false;
                } 
                if ( $("#installationTime1").val() == null || $("#installationTime1").val() == "" ) 
                {
                    alert("安装时间不能为空!");
                    $("#installationTime1").focus();
                    return false;
                } 
                if ( isRightTime( $("#installationTime1").val() )==0) 
                {
                    alert("安装时间格式必须是yyyy-MM-dd HH:mm:ss");
                    $("#installationTime1").focus();
                    return false;
                } 
                if ( $("#file1").val() == null || $("#file1").val() == "" ) 
	            {
	                alert("设备图片不能为空!");
	                return false;
	            } 
                if(confirm("您确定需要新增吗?"))
       			{
                    return true;
       			}
                return false;
            }
            function changeDispaly(r)
            {
                nowChangingRow = r.parentNode.parentNode.rowIndex;
                var table=document.getElementById("equipmentTable");
                var nowRow=table.rows[nowChangingRow].cells;
                //$("#changeTable").toggle();
                $("#changeTable").show();
                
                
                $("#siteName2").val(nowRow[0].innerHTML);
                $("#equipmentName2").val(nowRow[1].innerHTML);
                $("#equipmentCode2").val(nowRow[2].innerHTML);
                $("#equipmentCategory2").val(nowRow[3].innerHTML);
                $("#equipmentType2").val(nowRow[4].innerHTML);
                $("#installationTime2").val(nowRow[5].innerHTML);
                $("#equipmentStatus2").val(nowRow[6].innerHTML);
            }
            
            function confirmInput2() 
            {
                if ( $("#equipmentName2").val() == null || $("#equipmentName2").val() == "" ) 
                {
                    alert("设备名称不能为空!");
                    $("#equipmentName2").focus();
                    return false;
                } 
                if ( $("#equipmentCode2").val() == null || $("#equipmentCode2").val() == "" ) 
                {
                    alert("设备编码不能为空!");
                    $("#equipmentCode2").focus();
                    return false;
                } 
                if (isExisting($("#equipmentCode2").val())) 
                {
                    alert("设备编码不能重复!");
                    $("#equipmentCode2").focus();
                    return false;
                } 
                if ( $("#installationTime2").val() == null || $("#installationTime2").val() == "" ) 
                {
                    alert("安装时间不能为空!");
                    $("#installationTime2").focus();
                    return false;
                } 
                if ( isRightTime( $("#installationTime2").val() )==0) 
                {
                    alert("安装时间格式必须是yyyy-MM-dd HH:mm:ss");
                    $("#installationTime2").focus();
                    return false;
                } 
                
                if ( $("#file2").val() == null || $("#file2").val() == "" ) 
	            {
	                alert("设备图片不能为空!");
	                return false;
	            } 
                if(confirm("您确定需要修改吗?"))
       			{
                	
                    var table=document.getElementById("equipmentTable");
                    var nowRow=table.rows[nowChangingRow].cells;
                    
                    $("#oldEquipmentCategory").val(nowRow[2].innerHTML);
                    nowChangingRow=-1;
                    return true;
       			}
                $("#changeTable").hide();
                return true;
            }
			function findInformation()
			{
				
				var table=document.getElementById("equipmentTable");
				var i,totRow=table.rows.length;
				for(i=1;i<totRow;++i)
				{
					var nowRow=table.rows[i].cells;
					if(nowRow[0].innerHTML != $("#findSiteName").val()&& nowRow[1].innerHTML != $("#findEquipmentName").val())
					{
						
						table.deleteRow(i);
						i=i-1;totRow=totRow-1;
					}
				}
			}

            $(function() //初始化
            {
                $("#changeTable").toggle();
            });

            
            </script>
        </link>

    </head>

    <body>
		
	    <form method="POST" id="findTable">
	            <fieldset>
	            <legend>查询条件</legend>

	            站点名称(*):<input type="text" value="" id="findSiteName"><br /> 
	            设备名称(*):<input type="text" value="" id="findEquipmentName"><br />

	                <input type="button" id="findButton" value="查询" onclick="findInformation();"  />
	                
	                 <form action="">
					<button onclick="">返回</button>
					</form>
	            </fieldset>
	            
	           
	    </form>
	    
        <table id="equipmentTable" border="1">
            <caption>设备信息</caption>
            <thead>
                <tr>
                    <th>站点名称</th><th>设备名称</th><th>设备编码</th><th>设备分类</th><th>设备类型</th><th>安装时间</th><th>设备状态</th><th>操作</th>
                </tr>
					<% Connection con;
					    Statement sql; 
					    ResultSet rs;
					    try
					    {  
					    	Class.forName("com.mysql.jdbc.Driver");
					    }
					    catch(Exception e)
					    {
					       out.println("忘记把MySQL数据库的JDBC-数据库驱动程序复制到JDK的扩展目录中");
					    }
						try 
						{ 
							String uri= "jdbc:mysql://localhost:3306/deviceinfo";
					          String user="test";
					          String password="123456";
						con=DriverManager.getConnection(uri,user,password);
					          sql=con.createStatement();
					          rs=sql.executeQuery("SELECT * FROM Deviceinfo ");
					          while(rs.next())
					          { 
									out.print("<tr>");
									out.print("<td>"+rs.getString("siteName")+"</td>");
									out.print("<td>"+rs.getString("deviceName")+"</td>");
									out.print("<td>"+rs.getString("deviceCode")+"</td>");
									out.print("<td>"+rs.getString("deviceCategory")+"</td>");
									out.print("<td>"+rs.getString("deviceType")+"</td>");
									out.print("<td>"+rs.getString("installTime")+"</td>");
									out.print("<td >"+rs.getString("deviceState")+"</td>");
									out.print("</td><td><a href='#' onclick='changeDispaly(this);'>修改</a> <a href='#' onclick='deleteRow(this);'>删除</a></td></tr>");
									out.print("</tr>") ; 
					          }
					          out.print("</table>");
					          con.close();
					    }
					    catch(SQLException e)
						{ 
					          out.print(e);
					    }
					 %> 	
            </thead>
        </table>


        <form method="post" id="addTable" enctype="multipart/form-data" action="EquipmentAddServlet">
            <fieldset>
            <legend>新增</legend>
            站点名称(*):
                    <select id="siteName1" name="siteName1">  
                    <option value="昌都生态监测站">昌都生态监测站</option>
                    <option value="申扎生态监测站">申扎生态监测站</option>
                    <option value="日喀则生态监测站">日喀则生态监测站</option>
                    </select>
                    <br />  
            设备名称(*):<input type="text" value="" id="equipmentName1" name="equipmentName1"><br /> 
            设备编码(*):<input type="text" value="" id="equipmentCode1" name="equipmentCode1"><br />
            设备分类(*):
                    <select id="equipmentCategory1" name="equipmentCategory1">  
                    <option value="土壤">土壤</option>
                    <%
                    	for(int i=1;i<=10;++i)out.print("<option value="+i+">"+i+"</option>");
					%> 
                    </select>
                    <br /> 
            设备类型(*):
                    <select id="equipmentType1" name="equipmentType1">  
                    <option value="冻土检测">冻土检测</option>
                    <%
                    	for(int i=1;i<=10;++i)out.print("<option value="+i+">"+i+"</option>");
					%> 
                    </select>
                    <br /> 
            安装时间(*):<input type="text" value="" id="installationTime1" name="installationTime1"><br /><br /> 
            设备状态(*)
                    <select id="equipmentStatus1" name="equipmentStatus1">  
                    <option value="正常">正常</option>
                    <option value="异常">异常</option>
                    </select>
                    <br /> 
            <img id="img1" src=""/>
            设备图片(*)<input type="file" value="" id="file1" name="file1"><br /> 
                <input type="submit" id="button1" value="确定" onclick="return confirmInput1();" />
            </fieldset>
        </form>
        
        
        <script>
			document.getElementById("file1").onchange=function()
			{
				var reader=new FileReader();
				var tmpfile=document.getElementById("file1").files;
				reader.readAsDataURL(tmpfile[0]);
				reader.onload=function(){document.getElementById("img1").src=reader.result;};
			};
		</script>
       
        
        
		<form method="POST" id="changeTable" enctype="multipart/form-data" action="EquipmentEditServlet">
            <fieldset>
            <legend>修改</legend>
            站点名称(*):
                    <select id="siteName2" name="siteName2">  
                    <option value="昌都生态监测站">昌都生态监测站</option>
                    <option value="申扎生态监测站">申扎生态监测站</option>
                    <option value="日喀则生态监测站">日喀则生态监测站</option>
                    </select>
                    <br />  
            设备名称(*):<input type="text" value="" id="equipmentName2" name="equipmentName2"><br /> 
            设备编码(*):<input type="text" value="" id="equipmentCode2" name="equipmentCode2"><br />
            		    <input type="text" value="" id="oldEquipmentCategory"  name="oldEquipmentCategory" hidden>
            设备分类(*):
                    <select id="equipmentCategory2" name="equipmentCategory2">  
                    <option value="土壤">土壤</option>
                    <%
                    	for(int i=1;i<=10;++i)out.print("<option value="+i+">"+i+"</option>");
					%> 
                    </select>
                    <br /> 
            设备类型(*):
                    <select id="equipmentType2" name="equipmentType2">  
                    <option value="冻土检测">冻土检测</option>
                    <%
                    	for(int i=1;i<=10;++i)out.print("<option value="+i+">"+i+"</option>");
					%> 
                    </select>
                    <br /> 
            安装时间(*):<input type="text" value="" id="installationTime2" name="installationTime2"><br /><br /> 
            设备状态(*)
                    <select id="equipmentStatus2" name="equipmentStatus2">  
                    <option value="正常">正常</option>
                    <option value="异常">异常</option>
                    </select>
                    <br /> 
            <img id="img2" src=""/>
            设备图片(*)<input type="file" value="" id="file2" name="file2"><br /> 
                <input type="submit" id="button2" value="确定" onclick="return confirmInput2();" />
            </fieldset>
        </form>
		<script>
			document.getElementById("file2").onchange=function()
			{
				var reader=new FileReader();
				var tmpfile=document.getElementById("file2").files;
				reader.readAsDataURL(tmpfile[0]);
				reader.onload=function(){document.getElementById("img2").src=reader.result;};
			};
		</script>

    </body>

</html>


EquipmentAddServlet

package myServlet;
import java.io.*;
import java.sql.*;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import javax.servlet.http.Part;
@WebServlet("/EquipmentAddServlet")
@MultipartConfig
public class EquipmentAddServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	private String getFileName(Part part) 
	{
		String header = part.getHeader("Content-Disposition");
		System.out.println("header:" + header);
		int begin=header.indexOf("filename=\"")+"filename=\"".length();
		int end=header.lastIndexOf("\"");
		String fileName=header.substring(begin,end);
		return fileName;
	}
    public EquipmentAddServlet() 
    {
        super();
    }
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
	{
		request.setCharacterEncoding("utf-8");
		Part part=request.getPart("file1");
		String fileName=this.getFileName(part);
		String filePath=request.getServletContext().getRealPath("/upload")+ File.separator +fileName;
		part.write(filePath);
		
		Connection con = null;
	    Statement sql; 
	    ResultSet rs;
	    try
	    {  
	    	Class.forName("com.mysql.jdbc.Driver");
	    }
	    catch(Exception e)
	    {
	    	
	    }
		try 
		{ 
			String uri= "jdbc:mysql://localhost:3306/deviceinfo";
		    String user="test";
		    String password="123456";
			con=DriverManager.getConnection(uri,user,password);
		    sql=con.createStatement();
			

			String addOperate = "insert into deviceinfo(siteName,deviceName,deviceCode,deviceCategory,deviceType,installTime,deviceState) values (?,?,?,?,?,?,?)";
	        PreparedStatement preparedStatement = con.prepareStatement(addOperate);
	        preparedStatement.setString(1, request.getParameter("siteName1"));
	        preparedStatement.setString(2, request.getParameter("equipmentName1"));
	        preparedStatement.setString(3, request.getParameter("equipmentCode1"));
	        preparedStatement.setString(4, request.getParameter("equipmentCategory1"));
	        preparedStatement.setString(5, request.getParameter("equipmentType1"));
	        preparedStatement.setString(6, request.getParameter("installationTime1"));
	        preparedStatement.setString(7, request.getParameter("equipmentStatus1"));
	        preparedStatement.executeUpdate();
	        
		}
	    catch(SQLException e)
		{ 
	         
	    }

		try {
			con.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
		response.sendRedirect(request.getHeader("referer"));
	}
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}

EquipmentDeleteServlet

package myServlet;

import java.io.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.servlet.ServletContext;
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 javax.servlet.http.HttpSession;
@WebServlet("/EquipmentDeleteServlet")
public class EquipmentDeleteServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
    public EquipmentDeleteServlet() 
    {
        super();
    }
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
	{
		
		request.setCharacterEncoding("utf-8");
		
		String deviceCode=request.getParameter("deviceCode");
		
		Connection con = null;
	    Statement sql; 
	    ResultSet rs;
	    try
	    {  
	    	Class.forName("com.mysql.jdbc.Driver");
	    }
	    catch(Exception e)
	    {
	    	
	    }
		try 
		{ 
			String uri= "jdbc:mysql://localhost:3306/deviceinfo";
		    String user="test";
		    String password="123456";
			con=DriverManager.getConnection(uri,user,password);
		    sql=con.createStatement();
			request.setCharacterEncoding("utf-8");
			
			
			String deleteOperate = "delete from deviceinfo where deviceCode =?";
	        PreparedStatement preparedStatement = con.prepareStatement(deleteOperate);
	        preparedStatement.setString(1,deviceCode);
	        preparedStatement.executeUpdate();
		}
	    catch(SQLException e)
		{ 
	         
	    }
		try {
			con.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
		response.sendRedirect(request.getHeader("referer"));
	}
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}

EquipmentEditServlet

package myServlet;
import java.io.*;
import java.sql.*;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import javax.servlet.http.Part;
@WebServlet("/EquipmentEditServlet")
@MultipartConfig
public class EquipmentEditServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	private String getFileName(Part part) 
	{
		String header = part.getHeader("Content-Disposition");
		System.out.println("header:" + header);
		int begin=header.indexOf("filename=\"")+"filename=\"".length();
		int end=header.lastIndexOf("\"");
		String fileName=header.substring(begin,end);
		return fileName;
	}
    public EquipmentEditServlet() 
    {
        super();
    }
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
	{
		request.setCharacterEncoding("utf-8");
		Part part=request.getPart("file2");
		String fileName=this.getFileName(part);
		String filePath=request.getServletContext().getRealPath("/upload")+ File.separator +fileName;
		part.write(filePath);
			
		Connection con = null;
	    Statement sql; 
	    ResultSet rs;
	    try
	    {  
	    	Class.forName("com.mysql.jdbc.Driver");
	    }
	    catch(Exception e)
	    {
	    	
	    }
		try 
		{ 
			String uri= "jdbc:mysql://localhost:3306/deviceinfo";
		    String user="test";
		    String password="123456";
			con=DriverManager.getConnection(uri,user,password);
		    sql=con.createStatement();
			request.setCharacterEncoding("utf-8");
			
	        
	        String changeOperate = "update deviceinfo set siteName = ? ,deviceName = ?,deviceCode=?,deviceCategory=?,deviceType=?,installTime=?,deviceState=? WHERE deviceCode =?";
	        PreparedStatement preparedStatement = con.prepareStatement(changeOperate);
	        preparedStatement.setString(1, request.getParameter("siteName2"));
	        preparedStatement.setString(2, request.getParameter("equipmentName2"));
	        preparedStatement.setString(3, request.getParameter("equipmentCode2"));
	        preparedStatement.setString(4, request.getParameter("equipmentCategory2"));
	        preparedStatement.setString(5, request.getParameter("equipmentType2"));
	        preparedStatement.setString(6, request.getParameter("installationTime2"));
	        preparedStatement.setString(7, request.getParameter("equipmentStatus2"));
	        preparedStatement.setString(8,request.getParameter("oldEquipmentCategory"));
	        preparedStatement.executeUpdate();
		}
	    catch(SQLException e)
		{ 
	         
	    }
		try {
			con.close();
		} catch (SQLException e) {
			e.printStackTrace();
		}
		response.sendRedirect(request.getHeader("referer"));
	}
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}