一、实验目标:
1、了解并学会配置MyEclipse集成开发环境,学会在其环境下创建工程并发布运行一个JSP程序;
2、熟悉Tomcat服务器的目录,学习如何设置Web服务目录。并在其目录下运行一个简单的JSP页面;
3、熟悉和掌握HTML中表单的设计和提交。
二、实验内容:
(一)必做
1. 熟悉MyEclipse环境,在软件下绑定JDK和Tomcat,新建项目并运行;(必做)
2. 在MyEclipse环境下新建一个项目取名为Webtest+学号(必做)
a) 并在其下创建一个JSP程序,并在IE下运行;
代码:MyFirstJSPFile.jsp
运行结果:
b) 将课件第一章的例题input.jsp、receive.jsp内容拷入项目中。并运行访问该JSP页面;
input.jsp
<%@ page contentType="text/html;charset=utf-8" %>
<HTML><BODY bgcolor=cyan><Font size=8>
<FORM action="receive.jsp" method=get name=form>
<P>请输入下列信息:
<BR>输入您的姓名:<INPUT type="text" name="name" value="张三"></BR>
<BR>选择性别:<INPUT type="radio" name="R" value="男" checked="default">男
<INPUT type="radio" name="R" value="女">女
</BR>
<BR>选择您喜欢的歌手:
<input type="checkbox" name="superstar" value="张歌手" >张歌手
<input type="checkbox" name="superstar" value="李歌手" >李歌手
<input type="checkbox" name="superstar" value="刘歌手" >刘歌手
<input type="checkbox" name="superstar" value="王歌手" >王歌手
</BR>
<INPUT TYPE="hidden" value="这是隐藏信息" name="secret">
<INPUT TYPE="submit" value="提交" name="submit">
</FORM>
</FONT></BODY></HTML>
receive.jsp:
<%@ page contentType="text/html;charset=utf-8"%>
<%@ page import="java.net.*"%>
<HTML>
<BODY bgcolor=cyan>
<Font size=8> <a href="index.jsp">回到首页</a> <% request.setCharacterEncoding("utf-8");
// String yourName=new String((request.getParameter("name")).getBytes("iso-8859-1"),"utf-8"); // 获取text提交的值
String yourName=request.getParameter("name");
//String tt=URLEncoder.encode("林","utf-8");
//out.println("中文编码:"+tt);
//String yourName=URLDecoder.decode(request.getParameter("name"),"utf-8");
String yourSex=request.getParameter("R"); //获取radio提交的值
String secretMess=request.getParameter("secret"); //获取hidden提交的值
String personName[]=request.getParameterValues("superstar"); //获取checkbox提交的值
out.println("<P> 您的姓名:"+yourName+"</P>");
out.println("<P> 您的性别:"+yourSex+"</P>");
out.println("<P> 您喜欢的歌手:");
if(personName==null)
{ out.print("一个都不喜欢");
}
else
{ for(int k=0;k<personName.length;k++)
{ out.println(" "+personName[k]);
}
}
out.println("<P> hidden提交的值:"+secretMess);
%>
<p>姓名:${param.name}
<p>ttt${paramValues.superstar}
</FONT>
</BODY>
</HTML>
运行截图:
3. 预习第二章,编写并运行第P29页例题HelloServelt.java文件。
代码:HelloServelt.java
package ex01;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/HelloServelt")
public class HelloServelt extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
String name = request.getParameter("name");
PrintWriter out = response.getWriter();
out.print("<!DOCTYPE html>");
out.print("<html>");
out.print("<head>");
out.print("<title>Hello</title>");
out.print("</head>");
out.print("<body>");
out.printf("<h1>Hello! %s!%n</h1>",name);
out.print("</body>");
out.print("</html>");
}
}
运行截图:
(二)选做
4. 仿照test1文件夹下的input.jsp/receive.jsp,自己设计新建一个表单(登录网页,input文件中显示学号、姓名,表单设计还可参考第三章P57页 form-get.html文件),尝试用receive.jsp接收表单传回的信息。(选做)
代码:
input2.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>input2</title>
</head>
<body>
<form action="receive2.jsp" method=get name=form>
学号:<input type="text" name="id"/><br>
姓名:<input type="text" name="name"/><br>
<INPUT TYPE="submit" value="提交" name="submit">
</form>
</body>
</html>
receive2.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>receive2</title>
</head>
<body>
<%
request.setCharacterEncoding("utf-8");
String yourID=request.getParameter("id");
String yourName=request.getParameter("name");
out.println("<P> 您的学号:"+yourID+"</P>");
out.println("<P> 您的姓名:"+yourName+"</P>");
%>
</body>
</html>
运行截图: