servlet实验报告.docx_第1页
servlet实验报告.docx_第2页
servlet实验报告.docx_第3页
servlet实验报告.docx_第4页
servlet实验报告.docx_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Servlet上机实验报告Servlet上机实验报告 班级:软 件 1 班 学号:3120608020姓名:张 波时间:2015. 3.30一、实验目的1.掌握Servlet来访问数据库。 2.了解servlet工作的流程,servlet的作用。3.掌握servlet的方法init(),destory(),doGet(),doPost();二、实验环境 Windows8.1 + Eclipse + MySQL数据库三、实验步骤1.创建一个动态网页的项目,名字为:Employeer,创建包com.employee,在包下新建Servlet,名为ShowEmployeeList.java,里面代码实现和MySQL数据库的连接,并将数据库的内容以表格的形式显示到页面。并将用于连接数据库的驱动jar包添加到JavaPath中。2.配置web.Xml,匹配访问页面的URL。3.创建数据库Employee,在里面新建表emp,并在表中添加字段ename(雇员姓名),job(职位),sal(工资),hiredate(入职时间),并插入若干条数据。添加的额数据如下:四、源代码1.Employeer.javapackage com.employee;import java.io.IOException;import java.io.PrintWriter;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import javax.servlet.ServletConfig;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class ShowEmployeeList extends HttpServlet private static final long serialVersionUID = 1L;private Connection cn = null;Overridepublic void init(ServletConfig config) throws ServletException super.init();String driver = config.getInitParameter(driver);String url = config.getInitParameter(url);String user = config.getInitParameter(user);String password = config.getInitParameter(password);try Class.forName(driver);cn = DriverManager.getConnection(url, user, password); catch (Exception e) System.out.println(Init error: + e.getMessage();public void destroy() super.destroy();try if (cn != null & (!cn.isClosed() cn.close();cn = null; catch (Exception e) System.out.println(Destroy Error: + e.getMessage();protected void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException response.setContentType(text/html);response.setCharacterEncoding(GBK);PrintWriter out = response.getWriter();out.print();out.println( A Servlet);out.print( );try String sql = select ename,job,sal,hiredate from emp;PreparedStatement ps = cn.prepareStatement(sql);ResultSet rs = ps.executeQuery();out.print(员工列表);out.print();out.print();out.print(姓名职位工资加入公司日期);out.print();while (rs.next() out.print();out.println( + rs.getString(ENAME) + );out.println( + rs.getString(JOB) + );out.println( + rs.getDouble(SAL) + );out.println( + rs.getString(HIREDATE) + );out.print();rs.close();ps.close();out.print(); catch (Exception e) out.println(处理请求发生错误:+ e.getMessage() + );out.print();out.print();out.flush();out.close();protected void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException doGet(request, response);2.web.xml ShowEmployeeListcom.employee.ShowEmployeeListdrivercom.mysql.jdbc.Driverurljdbc:mysql:/localhost:3306/employeeuserrootpassword930515 ShowEmployeeList /ShowEmployeeList 3.执行效果五、 Java反射机制什么是反射机制?反射机制是如何实现的?Java反射是Java被视为动态(或准动态)语言的一个关键性质。这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其modifiers(诸如public, static 等)、superclass(例如Object)、实现之interfaces(例如Cloneable),也包括fields和methods的所有信息,并可于运行时改变fields内容或唤起methods。Java反射机制容许程序在运行时加载、探知、使用编译期间完全未知的classes。换言之,Java可以加载一个运行时才得知名称的class,获得其完整结构。Java反射机制提供如下功能: 在运行时判断任意一个对象所属的类-getClass();使用.class语法;运用static method Class.forName();运用TYPE 语法) 在运行时构造任意一个类的对象-getFields(); 在运行时判段任意一个类所具有的成员变量和方法-getMethods(); 在运行时调用任一个对象的方法-Invoke(); 在运行时创建新类对象- newInstance();在使用Java的反射功能时,基本首先都要获取类的Class对象,再通过Class对象获取其他的对象。六、实验体会 总体来说,本次的实验相对简单,都是基础的知识的简单利用。但不得不说还是很重要的,因为在Java EE的开发过程中,经常要使用servlet结合其他的框架来实现一些具体的特定的功能。同时,数据库的使

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论