JSP程序设计实验指导书

合集下载

实验一指导手册

实验一指导手册

实验一:JSP页面与JSP标记指导手册实验目的:1、掌握怎样在JSP页面中使用成员变量,掌握使用Java程序片、Java表达式。

2、掌握怎样在JSP页面中使用page指令设置contentType的值,使用include指令在JSP页面中静态插入一个文本的内容。

3、让学生掌握怎样在JSP页面中使用include标记动态加载文件,使用forward动作标记实现页面的转向。

实验要求:1、编写两个JSP页面,名字分别是inputName.jsp和people.jsp。

1)inputName.jsp中输入自己的姓名并提交给people.jsp页面(提示:inputName.jsp中需要用到表单)。

相关知识点:Web页面设计中表单参考代码:<%@ page contentType="text/html;charset=GB2312" %><HTML><BODY bgcolor=cyan><FONT size=3><FORM action="people.jsp" method=get name=form>请输入姓名:<INPUT type="text" name="name"><BR> <INPUT TYPE="submit" value="送出" name=submit></FORM></BODY></HTML>2)people.jsp页面中显示所有提交者的姓名(提示:people.jsp中需要用到成员变量和成员方法的声明)。

相关知识点:成员变量的声明。

思考:成员变量与局部变量的差别。

参考代码:<%@ page contentType="text/html;charset=GB2312" %><HTML><BODY BGCOLOR=yellow><FONT Size=3><%! int count;StringBuffer personList;public void judge(){if(count==0)personList=new StringBuffer();}public void addPerson(String p){if(count==0)personList.append(p);elsepersonList.append(","+p);count++;}%><% String name=request.getParameter("name");byte bb[]=name.getBytes("iso‐8859‐1");name=new String(bb);if(name.length()==0||name.length()>10){%> <jsp:forward page="inputName.jsp" /><% }judge();addPerson(name);%><BR> 目前共有<%=count%>人浏览了该页面,他们的名字是:<BR> <%=personList%></FONT></BODY></HTML>2、编写三个JSP页面:first.jsp、second.jsp和third.jsp。

JSP 实验(三)指导书

JSP 实验(三)指导书

JSP web 开发技术实验指导书(三)实验三在JSP中使用数据库实验目的:●JSP中利用JavaBean操作数据库。

●JSP进行数据库增、查、改、删数据库记录。

●JSP页面分页显示数据库记录。

●JSP页面按不同查询条件对数据库进行搜索。

实验课时: 4~6学时实验要求:首先是使用书中的代码完成一个上述功能;其次重构系统简化系统设计删除所有不必要的冗余代码。

实验内容:增加图书(书名、ISBN(主键)、出版社、价格、作者)信息,并存入数据库中;在图书信息列表中,选择“修改”,修改图书信息,并保存在数据库中。

根据结果显示不同的页面。

1.在SQLServer或MySQL中新建数据库publishdb2.创建数据表book(name, isbn, publisher, price ,authers), 各字段的参考类型如下:name varchar(50) not null,isbn varchar(...) not null primary key,Publichser varchar(40) not null,price float,authors varchar(50)3.在表中至少增加10条记录。

添加代码参见page 152-153中的AddBean.java, add.jsp.4.分别实现按ISBN号和书名和价格查询图书,并在页面显示。

代码参见page143-145页ConditionBean.java 和condition.jsp。

5.实现分页显示,代码参见ShowRecordByPage.java 和showByPage.jsp6.查询结果中,选择“修改”,修改选定的图书的信息。

如果确有困难,网上有step by step 教程。

如果确有困难,网上有step by step 教程。

jsp应用技术实验指导书新(1)

jsp应用技术实验指导书新(1)

jsp应用技术实验指导书新(1)
软件工程系《JSP应用技术》实验指导书
专业班级:软件10-1、2
指导教师:刘瑞玲
实验一 JSP开发环境的搭建
一、实验目的
1.熟练掌握T omcat服务器的安装与配置,为后续实验做好准备工作;
2.掌握Web服务目录的设置;
3.熟练掌握Web服务目录下JSP页面的访问;
4.掌握Tomcat服务器端口号的修改。

二、实验环境与地点
PC机一台:JDK6.0+Tomcat6.0+编辑器
三、实验内容与步骤
1.Tomcat服务器的安装与配置;
(1)下载jdk6.0进行安装,同时配置系统变量PATH与CLASSPATH。

(2)下载Tomcat6.0,将其安装到硬盘的某个分区,如D:\\。

2.Web服务目录的设置;
(1)在D:\\下新建一个目录,名称为student,将student目录设置为Web服务目录,并为该Web 服务目录指定名字为friend的虚拟目录。

打开Tomcat目录中conf文件夹里的文件,找到出现。

jsp实验指导书

jsp实验指导书
if(isLogin==null){
isLogin=false;
}
String name=req.getParameter("username");//获取表单上的用户名
String password=req.getParameter("password");//获取表单上的密码
if(isLogin==true){
import javax.servlet.http.HttpSession;
public class LoginServlet extends HttpServlet{
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
实验步骤:
1.创建一个Web工程,名称为login。
2.在工程的sunyang包下创建一个Servlet类LoginServlet.java,该类用来输出登录页面和欢迎用户登录的信息。类LoginServlet的代码如下:
import java.io.IOException;
import java.io.PrintWriter;
name=(String)session.getAttribute("name");
out.println("<center><h2>欢迎"+name+"登录</h2></center>");
}else if(name!=null&&password!=null){
session.setAttribute("name", name);//把用户名保存在HttpSession中

《JSP程序设计》实验指导书

《JSP程序设计》实验指导书

软件工程系《JSP程序设计》实验指导书专业班级:电商10指导教师:朱亚玲实验一熟悉Java运行环境一、实验目的1.熟悉java的运行环境,并配置环境变量;2.熟悉java程序的编译、解释执行过程;3.初步了解编译过程中的出错信息,改正错误;4.初步掌握Java的编程规则;5.了解并熟悉java的基本数据类型及其操作;6.初步掌握编程结构的特点;了解并熟悉循环结构的设计方法。

二、实验环境与地点PC机一台:JDK6.0+Tomcat6.0+编辑器三、实验内容与步骤1.查看JDK的安装路径、系统变量path的值,并进行记录。

(1)JDK的安装目录是:(2)path的值:2.利用写字板编写一个java源文件,输出以下信息。

中国科学院院士北京大学计算机科学技术系教授杨芙清把源程序保存到目录D:\dianshang10下,并进行编译和运行,得到正确结果。

(1)源程序:public class First { public static void main (String args[]) {System.out.println("中国科学院院士");System.out.println("北京大学计算机科学技术系教授");System.out.println("杨芙清");(2)} }(3)运行步骤及结果:3.在D:\dianshang10目录下有一个Java源文件Area.java,用来求圆的面积。

源文件内容如下:public class area{ //main():程序入口public static void main(String[] args){ //定义常量π,并用标识符VALUE_PAI表示final double VALUE_PAI=3.14;//设置半径double radius=2.5;//进行计算double area=VALUE_PAI*radius*radius;//显示结果System.out.println("The radius is: "+radius);System.out.println("The area of thiscircle is:"+" "+area);}}编译情况如右图所示:根据错误提示,找出错误原因并改正,运行出正确结果并记录。

JSP程序设计实验指导new

JSP程序设计实验指导new

JSP程序设计实验指导书适用专业:计算机科学与技术制定人:梁晟教研室:计算机专业教研室贵阳学院计算机科学系2007年9月实验一 Netbeans下 Jsp编程【实验目的】(1)熟悉Jsp的语法(2)掌握Jsp开发步骤(3)熟练掌握Netbeans开发环境(4)开发简单的登录模块【实验内容:】实现简单的用户登陆功能,不要求连接数据库。

【参考代码:】输入以下代码:Index.jsp<%@page contentType="text/html; charset=GBK"%><html><head><title>login</title></head><body bgcolor="#ffffff"><form action="check.jsp" method="POST"><table><tr><td>用户名:</td><td><input type="text" name="name"/></td></tr><tr><td>密码:</td><td><input type="password" name="pass"/></td></tr><tr><td> </td><td><input type="submit" value="Submit"/></td></tr></table></form></body>Check.jsp<%@ page contentType="text/html; charset=GBK" %> <html><head><title>check</title></head><body bgcolor="#ffffff"><%String name=request.getParameter("name");String pass=request.getParameter("pass");if(name==null)name="";if(pass==null)pass="";if(name.equals("jkx")&&pass.equals("jkx")){%><jsp:forward page="welcome.jsp"/><%}else{%><jsp:forward page="error.jsp"/><%}%></body></html>Welcome.jsp<%@ page contentType="text/html; charset=GBK" %> <html><head><title>welcome</title></head><body bgcolor="#ffffff"><h1>Welcome to China!</body></html>Error.jsp<%@ page contentType="text/html; charset=GBK" %><html><head><title>error</title></head><body bgcolor="#ffffff"><h1>name or password error! <a href="login.jsp">Return to login</a> </h1></body></html>实验二 JDBC 编程【实验目的】(1)熟悉Sqlserver2000常见操作(2)熟悉使用JDBC操作数据库【实验要求】进行JDBC编程,实现数据查询功能。

《JSP程序设计》实验指导

《JSP程序设计》实验指导

实验一: JSP开发环境的配置一.实验目的1.掌握Tomcat5.0的安装2.熟悉Tomcat5.0的设置3.熟悉第一个JSP文件的编写、发布二.实验内容1.安装Tomcat5.02.发布第一个JSP页面三.实验软件JDK5.0、Tomcat5.0四.实验步骤1.将JDK5.0和Tocmat5.0拷贝到本机2.安装JDK5.03.安装Tomcat5.0注:采用默认安装设置,端口号为80804.测试Tomcat5.0(1)启动Tomcat5.0(2)在IE浏览器中输入如果出现欢迎界面,则表示Tomcat安装成功。

5.编写发布第一个JSP文件(1)在Tomcat的安装目录下webapps/Root新建1.jsp文件<%@ page langugage=”java” import=”java.util.*” %> <HTML><BODY>当前时间为:<%= new Date()%></BODY></HTML>(2)测试1.jsp文件在IE浏览器中输入 http://127.0.0.1:8080/1.jsp实验二: 静态注册页面的编写一.实验目的1.掌握HTML常见标记2.熟悉JavaScript脚本二.实验内容1.编写一个含有文本输入框、密码框、下拉框、单选框、多选框、提交按钮的用户注册页面2.当提交的时候,进行数据检测,如果用户名为空,则提示错误。

三.实验软件JDK5.0、Tomcat5.0四.实验步骤1.在Tomcat的Webapps/root下新建如下reg.html文件<html><head><title>表单输入验证示例</title><script type="text/javascript">function validate(){var userName=document.forms[0].userName.value;if(userName.length<=0) alert("用户名不能为空!");else{alert("验证通过,表单可以提交!");document.forms[0].submit();}}</script></head><body><form action="" method="post">用户名:<input type="text" name="userName"></input><br>密码:<input type="password" name="password"></input><br> 重新输入密码:<input type="password" name="rePassword"></input><br>性别:<input type="radio" name="sex" value="男">男<input type="radio" name="sex" value="女">女<br>出生日期:<select name="birth"><option value="0">-请选择-</option><option value="1981">1981</option><option value="1982">1982</option><option value="1983">1983</option><option value="1984">1984</option><option value="1985">1985</option><option value="1986">1986</option></select>年<br>兴趣:<input name="habit" type="checkbox" value="1">音乐</input><input name="habit" type="checkbox" value="2">动漫</input> <input name="habit" type="checkbox" value="3">电影</input><br><input type="button" value="提交" onClick="validate()"/> <input type="reset" value="取消" /></form></body></html>2.测试reg.htm文件在IE浏览器中输入 http://127.0.0.1:8080/reg.html实验三: JSP语法基础一.实验目的1.掌握表单的提交2.掌握JSP内置对象request、response、out的使用二.实验内容1.编写一个含有文本输入框、密码框的登陆页面login.html2.编写一个登陆验证页面logincheck.jsp,如果用户输入的用户名为admin,密码为123,则转到index.jsp文件,否则,提示登陆失败。

《JSP应用技术》实验指导书

《JSP应用技术》实验指导书

实验四利用request和response对象进行设计一、实验目的1.理解内置对象的概念;2.熟练掌握request对象如何获取客户端信息;3.熟练掌握response对象的动态响应功能和重定向功能;4.熟练编写简单的JSP实用程序。

二、实验环境与地点:PC机一台:JDK6.0+Tomcat6.0+编辑器三、实验内容与步骤:在webapps目录下新建一个Web服务目录:chapter4。

将以下编写的JSP页面保存到chapter4中。

1.编写一个简单的用户注册页面register.jsp,页面中包括用户名、密码、年龄、性别、爱好等信息。

要求:(1)密码不能少于6位,年龄必须在10到100岁之间,性别采用单选按钮实现,爱好采用复选框实现;(2)在result.jsp页面获取输入的信息,若有信息不符合条件,response对象将用户重新定向到注册页面使其重新输入信息;若符合条件,则将信息显示出来。

(3)完成以下任务:①画出register.jsp页面的运行效果图。

②给出result.jsp页面中获取register.jsp页面提交的用户信息的代码。

③如果register.jsp表单提交的信息中有汉字,result.jsp页面应怎样处理?④给出result.jsp页面中判断用户信息是否符合条件并作出相应处理的代码。

2. 制作如下图所示的JSP程序inputNumber.jsp。

要求:(1)select下拉列表中有加、减、乘、除四个选项;(2)用户点击“提交”按钮后提交到inputNumber.jsp页面完成数据的处理,并将结果显示在JSP页面。

(3)写出inputNumber.jsp的代码。

四、实验总结与分析1.2.实验五利用session和application对象进行设计一、实验目的1.理解session对象的会话功能;2.理解application对象的应用程序级变量;3.能够掌握出session和application二者的区别;4.熟练掌握session对象如何存储与用户有关的数据;5.熟练掌握application对象如何存储与web服务有关的数据。

JSP课程设计指导书(11计通)

JSP课程设计指导书(11计通)

JSP课程设计指导书(11计通)预览说明:预览图片所展示的格式为文档的源格式展示,下载源文件没有水印,内容可编辑和复制2012-2013学年第二学期课程设计指导书课程名称:JSP程序设计适用班级:11计通、09大3设计时间:一周开始日期:2013.6.24山东信息职业技术学院计算机工程系指导教师:崔学鹏课程设计指导书一、设计目的本学期的《JSP程序设计》以JSP动态网站的设计为主,将理论学习与实践锻炼的知识进行综合应用。

在课程设计周,完成一个站点的设计与制作,从而达到以下目的:1.练习站点的规划及网页设计。

掌握借助Dreamwaver等工具进行站点规划与页面开发的方法。

2.加深对JSP技术的理解与应用。

3.熟练掌握使用MyEclipse 进行代码开发与调试4.掌握JSP页面编码与调试的基本方法,增加网站建设与代码调试的实际经验。

5.选取较好的作品参加系网页设计大赛,并在系网站上展出二、设计过程要求1)纪律:上机过程中遵守纪律及有关上机规定,不得浏览无关网站,课程设计过程的成绩,将计入本课程的期末测试成绩。

2)内容:网站内容以JSP实现动态网站为主(参考后面给定的选题或自定义专题性站点)。

3)保存:设计结果及有关素材需在硬盘或优盘上保存。

建议同学们用优盘等保存自己的站点信息等作品材料,便于每次上机调试。

4)要求:所设计的网站要求具有实用性和较好的创意,并尽可能将所学知识应用其中。

通过个人对资料的查阅,力所能及地利用一些好的脚本程序。

5)考核:由指导教师根据学生完成任务的情况、课程设计报告的质量和课程设计过程中的工作态度等综合打分。

成绩评定标准:I遵守上机纪律,认真完成设计题目,且页面美观大方,能实现所选课题所要求的各项功能,课程设计报告项目齐全,能够说明课题的实现思路与步骤。

电子文档齐全。

95—100分II遵守上机纪律,认真完成设计题目,且页面美观大方,网站总体运行良好(有个别不足),作品材料齐全,课程设计报告论述详实,表达准确。

实验三——指导手册

实验三——指导手册

inputNumber.jsp 参考代码: <%@ page contentType="text/html;charset=GB2312" %> <%@ taglib tagdir="/WEB-INF/tags" prefix="computer"%> <HTML> <BODY bgcolor=yellow> <Font size=5> <FORM action="" method=post name=form> 输入运算数、选择运算符号:<br>
济南大学《JSP 应用程序设计》实验指导手册
实验三:request 对象和 response 对象 指导手册 实验目的:
1、掌握在 JSP 中使用内置对象 request 2、掌握在 JSP 中使用内置对象 response
实验要求:
1、编写一个计算器,inputNumber.jsp 页面提供一个表单,输入两个数字和计算符号,并将 表单提交的数字和计算符号传递给 Co验:
JSP 中文问题:运行以下程序并思考:接收页面为什么会产生中文问题?如何解决? inputChinese.jsp: <%@ page contentType="text/html;charset=GB2312" pageEncoding="GB2312"%> <HTML><BODY bgcolor=cyan><FONT size=3> <FORM action="ok.jsp?action=你好" method=post name=form> 请输入你的中文姓名:<INPUT type="text" name="username"> <INPUT TYPE="submit" value="提交" name="submit"> </FORM> </FONT> </BODY> </HTML> ok.jsp: <%@ page contentType="text/html;charset=GB2312" pageEncoding="GB2312"%>

JSP实验指导

JSP实验指导

实验一JSP运行环境安装与配置实验时间:3月7日实验目的:1、掌握JSP运行环境的安装与配置。

2、熟悉Tomcat服务器的安装与配置。

3、掌握JSP文件的建立与使用。

4、熟悉JSP开发环境实验内容:1、安装J2SDK并设置相关环境变量。

2、安装与启动Tomcat服务器3、设置Web服务目录4、编写测试JSP页面实验步骤(过程):参照教材实验二JSP页面实验时间:3月21日实验目的:1、掌握JSP页面的基本结构及运行原理。

2、掌握怎样声明JSP页面的成员变量和方法3、掌握怎样使用Java程序片和Java表达式。

4、掌握在JSP页面中使用HTML标记。

实验内容:1、编写一个JSP页面,计算出100以内的素数。

2、设计两个JSP页面a.jsp和b.jsp,a.jsp页面使用表单提交数据给b.jsp页面,要求a.jsp通过text方式提交一个字符串给b.jsp,b.jsp页面获取a.jsp提交的字符串,并使用Java表达式显示这个字符串及其长度。

3、请编写JSP页面inputNumber.jsp和getNumber.jsp。

inputNumber.jsp页面使用表单通过text方式提交一个数字给getNumber.jsp页面,getNumber.jsp计算并显示这个数的平方和立方。

实验过程:实验题目1:<%@ page contentType="text/html;charset=GB2312" %><HTML><BODY bgcolor=yellow><P> 100以内的素数有:<BR>int i,j;for( i=1;i<=100;i++){ for( j=2;j<i;j++){ if(i%j==0)break;}if(j==i)out.println("<BR>素数:"+i);}%></BODY> </HTML>实验题目二:a.jsp<%@ page contentType="text/html;Charset=GB2312" %><HTML><BODY bgcolor=cyan><Font size=3><FORM action="b.jsp" method=post name=form><BR>请输入一个字符串:<INPUT type="text" name="name" ></BR><INPUT TYPE="submit" value="提交" name="submit"> </FORM></FONT></BODY></HTML>b.jsp<%@ page contentType="text/html;Charset=GB2312" %><HTML><BODY bgcolor=cyan><Font size=3><% String str=request.getParameter("name");%><P> 您输入的字符串是:<%=str %><P> 字符串的长度为:<%=str.length() %></FONT></BODY></HTML>实验题目3:inputNumber.jsp<%@ page contentType="text/html;Charset=GB2312" %><HTML><BODY bgcolor=cyan><Font size=3><FORM action="getNumber.jsp" method=post name=form><BR>请输入一个数字:<INPUT type="text" name="number" ></BR><INPUT TYPE="submit" value="提交" name="submit"> </FORM></FONT></BODY></HTML>getNumber.jsp<%@ page contentType="text/html;Charset=GB2312" %><HTML><BODY bgcolor=cyan><Font size=3><% String str=request.getParameter("number");double d=Double.parseDouble(str);out.println(d+"的平方为:"+d*d);out.println("<BR>"+d+"的立方为:"+d*d*d);}catch(NumberFormatException exp){out.println("<BR>"+exp);}%></FONT></BODY></HTML>实验三JSP标记实验时间:4月4日实验目的:1、掌握JSP指令标记、动作标记和自定义标记的使用2、掌握Tag文件设计、保存及调用方法。

JSP技术实验指导书

JSP技术实验指导书

JSP技术实验指导书目录实验一动态网页设计基础 (1)实验二、JSP的开发和运行环境搭建 (3)实验三JSP语法 (8)实验四JSP内置对象 (12)实验五JavaBean与表单处理 (16)实验六JSP中的文件操作 (18)试验七、数据库操作 (20)实验八Servlet应用 (22)实验一动态网页设计基础实验目的:1、掌握HTML的常用标签2、掌握HTML设计基本网页3、掌握HTML设计网络中常用的表单4、了解JavaScript的简单应用,实验环境:操作系统Windows XP或更高版本实验内容:1、编写一个简单的学生信息注册页面,包括学号、姓名、密码、专业,其中学号、姓名用单行文本框、密码使用密码框、专业使用下拉菜单;2、使用框架将一个页面均分为四个区域,每个区域显示不同的网页;3、在文本框输入任意一个整数,求该整数的阶乘。

通过按钮的单击事件,并将结果显示在结果文本框中。

实验步骤:1、编写一个简单的学生信息注册页面,包括学号、姓名、密码、专业,其中学号、姓名用单行文本框、密码使用密码框、专业使用下拉菜单;如下图所示(要求:使用表格布局)。

2、使用框架将一个页面均分为四个区域,每个区域显示不同的网页3、在文本框输入任意一个整数,求该整数的阶乘。

通过按钮的单击事件,并将结果显示在结果文本框中。

注意事项1、认真填写实验报告2、遵守实验室各项制度,服从实验指导教师的安排3、按规定的时间完成实验说明:1、实验性质:验证性2、建议学时:3学时实验二、JSP的开发和运行环境搭建实验目的:1、了解JSP开发环境安装与配置;2、了解JSP开发的一般步骤;3、熟悉简单JSP页面的开发实验环境:操作系统Windows XP或更高版本实验内容:1、环境配置;2、编写一个JSP页面,计算出100以内的素数。

实验步骤:1、环境配置JSP编程使用的Java语言,所以运行JSP程序必须要有JVM的支持,还必须要有Java程序编辑、编译程序(JDK)的支持。

JSP实训指导书

JSP实训指导书

JSP实训指导书—简单论坛制作一、需求分析与功能模块设计1.学生自行参考教材相关内容完成需求分析2.学生自行参考教材进行概要设计(功能模块划分)二、创建数据库1.设计数据库学生根据前一阶段分析与设计,完成数据库的设计,要求在报告中绘制数据库信息表以及采用E R图表述数据信息。

2.完成数据库创建按照要求实现数据库并使用相关软件创建数据库。

提供以下参考脚本/*论坛项目所使用的数据库b bs的建库脚本*/CREATE DATABASE `bbs` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ;USE `bbs`;/*Table structure for table `users`用户信息表*/DROP TABLE IF EXISTS `users`;CREATE TABLE `users` (`uid` int(11) NOT NULL AUTO_INCREMENT,`uname` varchar(20) NOT NULL,`upw` varchar(12) NOT NULL,`usex` char(2) DEFAULT '密',`udate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,`uemail` varchar(50) DEFAULT NULL,`ulevel` smallint(6) DEFAULT '1',`ulogo` varchar(50) DEFAULT NULL,PRIMARY KEY (`uid`),UNIQUE KEY `uname` (`uname`),KEY `name` (`uname`)) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;/*Table structure for table `posts`主题帖表*/DROP TABLE IF EXISTS `posts`;CREATE TABLE `posts` (`pid` bigint(20) NOT NULL AUTO_INCREMENT,`pTitle` varchar(50) NOT NULL,`pContent` varchar(500) NOT NULL,`pAuthor` varchar(16) NOT NULL,`pDate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,`pReplies` int(11) NOT NULL DEFAULT '0',`pClicks` int(11) NOT NULL DEFAULT '0',`pLastUpdate` char(20) DEFAULT NULL,`pLastAuthor` varchar(16) DEFAULT NULL,PRIMARY KEY (`pid`),KEY `author` (`pAuthor`),CONSTRAINT `author` FOREIGN KEY (`pAuthor`) REFERENCES `users` (`uname`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;/*Table structure for table `reply`回复帖表*/DROP TABLE IF EXISTS `reply`;CREATE TABLE `reply` (`rId` int(11) NOT NULL AUTO_INCREMENT,`pid` bigint(20) NOT NULL,`rTitle` varchar(50) DEFAULT NULL,`rContent` varchar(500) NOT NULL,`rAuthor` varchar(20) NOT NULL,`rDate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,PRIMARY KEY (`rId`),KEY `pid` (`pid`),KEY `rAuthor` (`rAuthor`),CONSTRAINT `reply_ibfk_1` FOREIGN KEY (`pid`) REFERENCES `posts` (`pid`) ON DELETE CASCADE ON UPDATE CASCADE,CONSTRAINT `reply_ibfk_2` FOREIGN KEY (`rAuthor`) REFERENCES `users` (`uname`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;/*创建视图`p ost_user`和r eply_user,在显示帖子详情时使用到视图*/CREATE VIEW `reply_user`AS SELECT * FROM users AS u,reply AS r WHERE r.rAuthor=u.uname;CREATEVIEW `post_user`AS(SELECT * FROM users AS u,posts AS p WHERE p.pAuthor=u.uname);/*Table structure for table `section`版块信息表,如果添加板块信息才使用下面内容*/ DROP TABLE IF EXISTS `section`;CREATE TABLE `section` (`sno` int(11) NOT NULL AUTO_INCREMENT,`sname` varchar(30) COLLATE utf8_unicode_ci NOT NULL,`uname` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,`sdate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`sno`)) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;三、创建通用类访问数据库1.创建属性文件属性文件d bconn.properties(文件路径:src目录),文件内容参照如下driver = com.mysql.jdbc.Driverurl = jdbc:mysql://localhost:3306/bbs?useUnicode=true&characterEncoding=utf8username = rootpassword =1234562.创建通用类Conn.java参考内容如下:package dbUtil;import java.io.InputStream;import java.sql.*;import java.util.Properties;import dbUtil.Conn;public class Conn {private Connection con;private Statement st;//构造函数,在创建Conn类的对象时自动调用public Conn() throws Exception {Properties pros = new Properties();InputStream in;in=Conn.class.getResourceAsStream("/dbconn.properties"); //加载属性文件,该文件应存放于项目的源包下(src/java)pros.load(in);in.close();String driver = pros.getProperty("driver");String url = pros.getProperty("url");String username = pros.getProperty("username");String password = pros.getProperty("password");Class.forName(driver);con =DriverManager.getConnection(url,username,password);st =con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);}//executeQuery--执行查询语句public ResultSet executeQuery(String sql) {ResultSet rs = null;try {rs = st.executeQuery(sql);} catch (Exception e) {e.printStackTrace(System.err);}return rs;}//executeUpdate方法--执行对数据库的更新的SQL语句public int executeUpdate(String sql) {try {return st.executeUpdate(sql);} catch (Exception e) {e.printStackTrace(System.err);return 0;}}//创建预编译对象的方法public PreparedStatement prepareStatement(String sql) { try {return con.prepareStatement(sql);} catch (SQLException e) {e.printStackTrace(System.err);return null;}}/***关闭各项资源的方法*/public void close() {try {if (st!=null) st.close();} catch (Exception e) {e.printStackTrace(System.err);}try {if (con!=null) con.close();} catch (Exception e) {e.printStackTrace(System.err);}}}四、各功能模块1用户注册模块1)设计并完成相关B ean的制作Users.java/*** Document : Users.java* Created on : 2010-6-9, 0:19:28* Author : sunny*/package bean;public class Users {private String uname,upw,upw2,usex,udate,uemail,ulogo; private int ulevel;public String getUname() {return uname;}public void setUname(String uname) {this.uname = uname;}public String getUpw2() {return upw2;}public void setUpw2(String upw2) {this.upw2 = upw2;}public String getUdate() {return udate;}public void setUdate(String udate) {this.udate = udate;}public String getUemail() {return uemail;}public void setUemail(String uemail) {this.uemail = uemail;}public int getUlevel() {return ulevel;}public void setUlevel(int ulevel) {this.ulevel = ulevel;}public String getUlogo() {return ulogo;}public void setUlogo(String ulogo) { this.ulogo = ulogo;}public String getUpw() {return upw;}public void setUpw(String upw) {this.upw = upw;}public String getUsex() {return usex;}public void setUsex(String usex) {ex = usex;}}UserBean.javapackage bean;import dbUtil.Conn;import java.sql.PreparedStatement; import java.sql.ResultSet;import java.sql.SQLException;public class UsersBean {private Users user;public Users getUser() {return user;}public void setUser(Users u) {er = u;}public String basicCheck() {String uname, upw, upw2;uname = user.getUname();upw = user.getUpw();upw2 = user.getUpw2();String msg = "";if (uname == null || uname.equals("") || upw == null || upw.equals("")) {msg = "请填写用户名和密码.";} else if (!upw.equals(upw2)) {msg = "两次输入的密码不一致!";}return msg;}public String uniqueName() {String uname = user.getUname();Conn conn = null;ResultSet rs = null;String msg = "";try {conn = new Conn();String sql = "select * from users where uname='" + uname + "'";rs = conn.executeQuery(sql);if (rs != null)if (rs.next())msg = "用户名<b> " + uname + " </b>已被使用,请改用其它名字.";} catch (Exception ex) {ex.printStackTrace(System.err);} finally {try {if (rs != null)rs.close();} catch (SQLException ex) {ex.printStackTrace(System.err);}conn.close();}return msg;}public boolean insert() {boolean success = false;Conn conn = null;PreparedStatement pt = null;if (user==null) return false;try {conn = new Conn();String sql = "insert intousers(uname,upw,usex,uemail,ulogo) values(?,?,?,?,?)";pt = conn.prepareStatement(sql);pt.setString(1, user.getUname());pt.setString(2, user.getUpw());pt.setString(3, user.getUsex());pt.setString(4, user.getUemail());pt.setString(5, user.getUlogo());success = pt.executeUpdate() > 0;} catch (Exception ex) {ex.printStackTrace(System.err);} finally {try {if (pt != null)pt.close();} catch (SQLException ex) {ex.printStackTrace(System.err);}conn.close();}return success;}}2)界面制作与前端验证程序在j s目录里确认有以下j s文件用于进行前段验证:以下是注册页面参考代码reg.jsp<%--Document : reg.jsp用户注册页面Created on : 2015-04-19, 16:31:45Author : sunnyDescription:通过jQuery库实现的Ajax用户名检测--%><%@page contentType="text/html" pageEncoding="UTF-8" import="java.util.Vector"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01Transitional//EN""/TR/html4/loose.dtd"><%//先退出登录状态Vectorvisitors=(Vector)application.getAttribute("namelist");if(visitors!=null&&session.getAttribute("username")!=null) visitors.remove(session.getAttribute("username")); session.removeAttribute("username");//从检测到填写错误的页面转回时,先恢复上一次填写的内容String msg = "", uname = "", uemail = "", ulogo = "";if (request.getParameter("msg") != null) {msg = request.getParameter("msg");uname = request.getParameter("uname");uemail = request.getParameter("uemail");ulogo = request.getParameter("ulogo");}%><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>学习论坛--注册</title><style type="text/css"><!--@import url("css/common.css");-->img{cursor:hand;}</style><!--common.js中包含常用的Javascript代码--><script src="js/common.js"></script><!--reg.js中包含本页面使用的JS检测函数--><script src="js/reg.js"></script><!--添加对jQuery库的引用--><script src="js/jquery-1.11.0.min.js"></script> <script>var jq = $.noConflict(); //使用jq代替默认的$符号jq(function(){jq('#uname').blur(function(){var uname=jq('#uname').val();//if (uname == null || uname == "") {alert("请输入用户名.");jq("#uname").focus();return;}jq.get('chkUniqueName.jsp?uname='+encodeURI(uname),null, function(data){if (data != "OK") { //若在服务器端检测后用户名重复,则返回的结果信息不为OKjq("#unameinfo").html('<imgsrc="images/check_error.gif" width="13" height="13">&nbsp; 已被使用');jq("#uname").focus(); //光标重新定位在用户名输入框} else {jq("#unameinfo").html('<imgsrc="images/check_right.gif" width="13" height="13">可用');}}); //end of jq.get});});</script></head><body id="reg"onload="$('uname').focus()"> <!--页面加载时,光标自动定位到用户名输入框--><div id="container"><div id="logo"></div><div id="nav"><div id="welcome">欢迎进入JSP学习论坛</div><ul><li><a href="index.jsp">首页</a></li><li><a href="login.jsp">登录</a></li><li><a href="reg.jsp">注册</a></li><li><a href="mailto:neujspbook@">与我联系</a></li></ul></div><!--下面是内容层,主要显示一个表单--><div id="content"><div class="warning" ><%=msg%></div><form action="chkReg.jsp" method="post"onsubmit="return check()"><!--表单的各项内容用表格排列整齐--><table><tbody><tr><td colspan="2" id="title">请填写注册信息</td></tr><tr><td class="ltd">用户名* </td><td><input type="text"name="uname"id="uname" value="<%=uname%>" size="40" maxlength="20" /><span id="unameinfo"></span></td></tr><tr><td class="ltd">密码* </td><td><input type="password"name="upw"id="upw" size="40" maxlength="20" /></td></tr><tr><td class="ltd">确认密码* </td><td><input type="password" name="upw2"id="upw2" size="40" maxlength="20" /></td></tr><tr><td class="ltd">性别</td><td><input type="radio" name="usex"value="男"/> 男<input type="radio"name="usex"value="女"/>女<input type="radio" name="usex" value="密" checked />密</td></tr><tr><td class="ltd">Email</td><td><input type="text"name="uemail"size="40" value="<%=uemail%>" id="uemail"></td></tr><tr><td class="ltd">选择头像</td><td style="vertical-align:middle"><input type="hidden"name="ulogo"id="ulogo" value="<%=ulogo%>"/><img src="<%= ulogo.equals("") ?"images/head/space_noface.gif" : ulogo%>" id="hlogo" name="hlogo" /><br><input type="radio" name="s1"onclick="selectImg()"/>选择<input type="radio" name="s1"onclick="uploadImg()"/>上传</td></tr><tr><td class="regBottom">&nbsp;</td><td class="regBottom" align="center"><input type="submit" value="确定" />&nbsp;&nbsp;<input type="reset" value="重置" /></td></tr></tbody></table></form></div><div id="footer"><span>学习案例---《JSP实用教程》编写组</span> </div></div> <!--end of container--></body></html>chkReg.jsp<%--Document : chkReg.jspCreated on : 2015-10-23, 22:25:11Author : sunny说明:使用JavaBeabn完成注册处理--%><%@page contentType="text/html" pageEncoding="UTF-8" import="java.sql.*,dbUtil.Conn,ersBean"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01Transitional//EN""/TR/html4/loose.dtd"><html><head><meta http-equiv="content-Type" content="text/html; charset=UTF-8"><title>保存注册信息</title></head><body><%request.setCharacterEncoding("utf-8");%><jsp:useBean class="ers" id="newuser" /><jsp:setProperty property="*" name="newuser" /> <%UsersBean ub=new UsersBean();ub.setUser(newuser);String msg = ub.basicCheck();if (msg.equals("")) msg=ub.uniqueName();if (msg.equals("")) {if (!ub.insert()) {msg = "Sorry,注册失败.";}}if (msg.equals("")) {out.println("恭喜!注册成功!");response.setHeader("refresh", "3;url=index.jsp"); } else {%><jsp:forward page="reg.jsp"><jsp:param name="msg" value="<%=msg%>" /></jsp:forward><%}%></body></html>2.用户登录模块● login_head.jsp<%@page contentType="text/html" pageEncoding="UTF-8"%><div id="logo"></div><div id="nav"><div id="welcome">欢迎进入JSP学习论坛</div><ul><li><a href="index.jsp">首页</a></li><li><a href="login.jsp">登录</a></li><li><a href="reg.jsp">注册</a></li><li><a href="mailto:neujspbook@">与我联系</a></li></ul></div>foot.jsp<%@page pageEncoding="utf-8" %><div id="footer"><jsp:include page="namelist.jsp" /><span>学习案例---《JSP实用教程》编写组</span></div>● exit.jsp<%--Document : exit.jspCreated on : 2010-5-15, 15:45:54Author : sunny--%><%@page contentType="text/html" pageEncoding="UTF-8"import="java.util.*"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01Transitional//EN""/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>JSP学习论坛--退出登录</title></head><body><%Vectorvisitors=(Vector)application.getAttribute("namelist");if(visitors!=null&&session.getAttribute("username")!=null) visitors.remove(session.getAttribute("username"));session.removeAttribute("username");response.sendRedirect("login.jsp");%></body></html>namelist.jsp<%@page contentType="text/html" pageEncoding="UTF-8"%><%@page import="java.util.*" %><%String name = null, namelist = "";Vector visitors = (Vector)application.getAttribute("namelist");if (visitors != null) {Iterator it = visitors.iterator();while (it.hasNext()) {name = (String) it.next();namelist += name + " ";}if (!namelist.equals("")) {out.println("<p>在线会员:" + namelist+"</p>");}}%>login.jsp<%@page contentType="text/html"%><%@page pageEncoding="UTF-8"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01Transitional//EN""/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>登录</title><link href="css/common.css" rel="stylesheet"type="text/css" /><style type="text/css">@import url("css/login.css");</style><script src="js/common.js"></script><script src="js/loginChk.js"></script></head><body onload="$('uname').focus()"><div id="container"><%@include file="login_head.jsp" %><!--下面是内容层,主要显示一个表单--><div id="content"><form action="chkLogin.jsp" method="post"onsubmit="return chkLogin()"><!--表单的各项内容用表格排列整齐--><table><tr><th colspan="2">&nbsp;&nbsp;请登录</th><th>&nbsp;</th></tr><tr style="padding-top:20px;"><td class="ltd">用户名<span class="warning">*</span></td><td> <inputtype="text" name="uname" size="20" onblur="chkName()"/></td><td class="gray"> &nbsp;长度要求为3-20个字符.</td></tr><tr><td class="ltd">密码<spanclass="warning">*</span></td><td><input type="password"name="upw" size="20" onblur="chkPw()"/> </td><tdclass="gray">&nbsp;密码只能由数字或字母构成.</td></tr><tr><td>保存期限</td><td><input type="radio" name="limit" value="0" checked="checked">不保存<input type="radio" name="limit" value="30" /> 一个月<input type="radio" name="limit" value="180" /> 半年</td><td class="gray">&nbsp;在指定的期限内可自动登录</td></tr><tr><td class="bottom">&nbsp;</td><td class="bottom" align="center"><input type="submit" value="确定"/>&nbsp;<input type="reset" value="重置" /></td></tr><tr><td>&nbsp;</td></tr><tr><td id="nameinfo" class="login_info"colspan="2"></td></tr><tr><td id="pwinfo" class="login_info"colspan="2"></td></tr></table></form></div> <!--end of content--><%@include file="foot.jsp" %></div> <!--end of container--></body></html>chkLogin.jsp<%@page contentType="text/html"import="java.sql.*,java.util.*,dbUtil.Conn"%><%@page pageEncoding="UTF-8"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01Transitional//EN""/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>登录中...</title><link href="css/common.css" rel="stylesheet"type="text/css" /><script src="js/common.js"></script></head><body><%String uname, upw;request.setCharacterEncoding("utf-8");uname = request.getParameter("uname");upw = request.getParameter("upw");if (uname == null || uname.equals("")) {out.println("请输入用户名.");response.setHeader("refresh", "3;url=login.jsp");return;}if (upw == null || upw.equals("")) {out.println("请输入密码.");response.setHeader("refresh", "3;url=login.jsp");return;}boolean valid = false; //表示验证是否通过的标志Conn con = null;ResultSet rs = null;try {String sql = "select * from users where uname='" + uname + "'";con=new Conn();rs = con.executeQuery(sql);if (rs != null) {if (rs.next()) {valid = upw.equals(rs.getString("upw"));}}} catch (SQLException e) {e.printStackTrace(System.err);} finally {try {if (rs != null) {rs.close();}} catch (Exception e) {e.printStackTrace(System.err);}try {if (con != null) {con.close();}} catch (Exception e) {e.printStackTrace(System.err);}}if (valid) {session.setAttribute("username", uname);/*------开始:在线名单处理------*/Vector visitors = (Vector)application.getAttribute("namelist");if (visitors == null) {visitors = new Vector();application.setAttribute("namelist", visitors);}boolean unique = true;for (int i = 0; i < visitors.size(); i++) {if (((String) visitors.get(i)).equals(uname)) {unique = false;break;}}if (unique) {visitors.add(uname);}/*------结束:在线名单处理------*//*------开始:自动登录Cookie处理----*/int limit =Integer.parseInt(request.getParameter("limit"));Cookie c = new Cookie("username",.URLEncoder.encode(request.getParameter("uname"), "UTF-8"));c.setMaxAge(limit * 24 * 60 * 60);response.addCookie(c);/*------结束:自动登录Cookie处理----*/out.println("<br/>登录成功!正在自动转向网站首页...");response.setHeader("refresh", "3;url=index.jsp");} else {out.println("<br/>用户名或密码错误.");response.setHeader("refresh", "3;url=login.jsp");}%></body></html>3.帖子浏览模块head.jsp<%@page pageEncoding="UTF-8"%><!--link href="css/common.css" rel="stylesheet"type="text/css" /--><% String uname="游客";String pageName=request.getRequestURI();pageName=pageName.substring(stIndexOf("/")+1);if (!pageName.equals("login.jsp")) {uname= (String) session.getAttribute("username");if (uname == null) {Cookie ck[] = request.getCookies();if (ck != null) {for (int i = 0; i < ck.length; i++) {if (ck[i].getName().equals("username")) {uname =.URLDecoder.decode(ck[i].getValue(),"UTF-8");session.setAttribute("username", uname);break;}}}}if (uname == null) {response.sendRedirect(request.getContextPath()+"/login.js p");return;}}%><div id="logo"></div><div id="nav"><div id="welcome"><%=uname%>,欢迎进入JSP学习论坛</div><ul><li><a href="index.jsp">首页</a></li><% if (session.getAttribute("username") == null) { %><li><a href="login.jsp">登录</a></li><%} else {%><li><a href="exit.jsp">退出</a></li><%}%><li><a href="reg.jsp">注册</a></li><li><a href="mailto:neujspbook@">与我联系</a></li></ul></div><div style="display:none;" id="errorMsg"></div>index.jsp<%--Document : index.jspCreated on : 2015-5-22, 23:01:39Author : sunny--%><%@page contentType="text/html" pageEncoding="UTF-8" import="dbUtil.*,java.sql.*"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01Transitional//EN""/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>JSP学习论坛---首页</title><link rel="stylesheet" href="css/common.css" /></head><body><% //确定搜索条件String searchStr = "",linkStr="";if (request.getParameter("keyValue") !=null&&!request.getParameter("keyValue").equals("")) { StringkeyField=request.getParameter("keyField");String keyValue = newString(request.getParameter("keyValue").getBytes("iso8859 -1"), "utf-8");searchStr="where"+keyField+"like'%"+keyValue+ "%'";linkStr="&keyValue="+keyValue+"&keyField="+keyField;}//获取页号String spageno = request.getParameter("pageno");if (spageno==null) spageno="1";int pageno = 1; //默认页号为1try {pageno = Integer.parseInt(spageno);} catch (Exception e) {e.printStackTrace(System.err);}//创建数据库连接Conn con=null;ResultSet rs = null;try {con=new Conn();} catch (Exception e) {e.printStackTrace(System.err);out.println("抱歉,网站出错,暂时无法提供服务.");return;}//计算页号导航int allpage = 0, allrec=0,pagesize = 10; //每页显示10条记录rs = con.executeQuery("select count(*) as total from posts " + searchStr);if (rs != null && rs.next()) {allrec = rs.getInt(1);}allpage=allrec%pagesize==0?allrec/pagesize:allrec/pagesiz e+1;int firstp = 1, lastp = allpage;if (pageno - 3 > 1) {firstp = pageno - 3;}if (pageno + 3 < lastp) {lastp = pageno + 3;}%><div id="container"><%@ include file="/head.jsp" %><div id="content"><div id="postlist"><div id="newPostLink"><a href="newPost.jsp"><img。

JSP应用开发(Java方向)实验指导书

JSP应用开发(Java方向)实验指导书

JSP应用开发(Java方向)实验指导书Java课程组姓名:班级:学号:淮安信息职业技术学院计算机与通信工程学院目录实验一Web项目的创建 (1)实验二房屋交易系统的原型设计 (8)实验三 JSP基本语法 (12)实验四系统中用户注册的实现 (13)实验五JSP隐式对象 (14)实验六个人房屋信息管理的实现 (15)实验七使用Servlet实现BBS论坛登录 (17)实验八使用Servlet实现论坛版块显示 (19)实验九使用Servlet实现论坛主题帖显示 (20)实验十使用Servlet实现论坛主题帖发表 (21)实验十一使用EL表达式实现页面欢迎语 (22)实验十二使用EL表达式重构主题帖页面 (23)实验十三分页的实现 (24)实验十四过滤器的使用 (25)实验一Web项目的创建【实验目的】1、熟悉WEB项目的目录结构;2、熟悉WEB应用程序的部署运行;3、熟悉Eclipse和Tomcat的部署运行;【实验准备】一、复习配套教材相关章节的内容;二、预习本次实验;【实验内容】1、熟悉Web项目的环境配置(推荐采用MyEclipse作为开发环境)。

1)在配置WEB开发环境之前,首先确保你的机器上安装有JDK(1.6及以上和Tomcat6.0及以上)。

打开MyEclipse,进入windows菜单,选preferences选项进入如下界面。

2)打开MyEclipse选项后,再打开Server选项,接着打开Tomcat选项。

点击Tomcat 6.x选项。

指定你的Tomcat的安装路径。

3)点开Tomcat 6.x后,点击JDK选项,配置JDK。

4)点击ADD按钮。

进入JDK配置界面,指定JDK安装路径,完成JDK 配置。

5)完成配置后,MyEclipse工栏的Tomcat工栏出现你所配置的Tomcat 菜单项。

6)点击start后,启动Tomcat,在控制台输出如下信息,则表明Tomcat 正常启动。

jsp实验指导书

jsp实验指导书

实验一使用HTML进行在线调查问卷设计一、实验目的:1.复习使用记事本编辑网页的方法。

2.熟悉不同表单控件类型的应用。

3.练习使用记事本在网页中添加表单与表单元素。

二、实验内容:根据提供的素材设计在线调查问卷。

三、实验要求:1.熟练掌握使用记事本进行简单网页编辑的方法。

2.能够区分不同表单元素的应用场景。

3.掌握表单与表单元素的元素名和属性对。

四、实验学时:4学时五、实验步骤:0.实验准备:(1)在硬盘上为本实验建立文件夹(以下称为“实验文件夹”)。

1.根据提供的素材设计在线调查问卷:(1)从开始菜单启动记事本;(2)在记事本中,录入一个最简合法HTML文档;(3)设置该文档最终在浏览器中显示的标题为“企业电子商务调查问卷”;(4)打开本实验提供的WORD文档questionnaire.doc,这个调查问卷比较长,浏览该调查问卷的内容。

由于该调查问卷比较长,选取并标示该调查问卷中具有代表性的问题(更改一下文本背景),准备将它们在网页中进行实现,保存该WORD文档;(5)在记事本中添加表单;(6)在表单中插入表单元素,用于在网页中显示步骤(4)中标示的问题及答案;(7)为表单添加提交和重置按钮;(8)保存网页为questionaire.htm。

提示:本实验没有标准答案,但是在将WORD文档中的调查问题及答案移植到网页中时,要尽可能多地使用到讲过的表单元素(如文本框、单选按钮、复选按钮、下拉菜单/列表、框架等)。

另外,网页上调查问卷的答案的表现形式与并不一定要与WORD中的一致,而是应该选择使用更符合需要的表单元素,例如对于答案选项比较多的问题来说,应该优先选用下拉菜单/列表,单选使用下拉菜单,多选使用列表。

六、实验代码:实验二生成简单动态网页一、实验目的1、掌握tomcat配置及使用方法;2、进一步熟悉HTML基本语法;3、熟悉JSP基本语法;4、掌握HTML与JSP指令、动作元素结合来设计web页面。

【精品文档】jsp实验指导书-实用word文档 (15页)

【精品文档】jsp实验指导书-实用word文档 (15页)

本文部分内容来自网络整理,本司不为其真实性负责,如有异议或侵权请及时联系,本司将立即删除!== 本文为word格式,下载后可方便编辑和修改! ==jsp实验指导书篇一:JSP实验指导书试验一:熟悉JSP开发环境一实验目的:1. 熟悉JSP开发环境。

二实验内容:安装JDK,Tomcat,MyEclipse/Eclipse,并建立一个简单Web应用且发布测试。

三实验步骤:1. 安装JDK;2. 安装Tomcat;3. 安装MyEclipse或Eclipse;4. 建立一个Web应用,在index.jsp中显示“您好,这是我的第一个JSP站点。

”;5. 发布测试。

四主要代码:1. index.jsp页面代码:? <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>? <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">? <html>?<head>? <title>My JSP 'index.jsp' starting page</title>? </head>??<body>? 您好,这是我的第一个JSP站点。

<br>?</body>? </html>试验二:熟悉JSP开发环境一实验目的:1. 熟悉基本web工程的创建以及基本的jsp页面的建立和代码的编写。

二实验内容:建立一个Web应用,在主页面实现登录见面,在其中输入用户名,密码,发送到登录验证页面,登录成功,显示成功提示,登录失败,显示失败页面。

三实验步骤:1. 设计登录见面;2. 编写登录处理代码;3. 编写成功提示页面;4. 编写失败提示页面。

JSP实验指导书

JSP实验指导书

软件与信息服务《JSP程序设计》实验指导书山外信息与控制工程学院2019年春季学期实验目录实验一Java开发环境设置 (1)实验二Java基本数据类型 (7)实验三数组 (16)实验四面向对象基础编程 (20)实验五类的继承性和多态性 (24)实验六包、接口抽象类 (30)实验七字符串 (35)实验八 Java中的Object、Math和System类 (38)实验九异常处理 (42)实验十集合框架编程 (50)实验一 JSP制作表单、输出表格一、实验目的掌握HTML中的各种标记掌握request.getParameter( )方法掌握使用表达式形式进行网页输出,使HTML标记与Scriptlet有效分离二、实验要求1.编写表单页面,并设置行数、列数表单控件2.完成表单提交,在目标页面生成表格三、实验内容要求:根据用户输入行数与列数进行表格的输出。

表单网页代码如下图:处理表单的JSP页面代码如下图:【实验结果数据及分析】(结果)记录程序执行的结果,并对它进行分析。

实验二 JSP指令和动作实现登录功能一、实验目的1.掌握HTML语言编写表单2.掌握各种forward指令的使用3.掌握String类的equals( )方法二、实验要求1. 编写登录界面jsp文件2. 通过jsp动作发送请求到处理页面3.处理页面进行登录逻辑判断,并根据情况跳转三、实验内容login.jsp代码如下:login_conf.jsp代码如下:login_success.jsp代码如下:login_failure.jsp代码如下:【实验结果数据及分析】(结果)记录程序执行的结果,并对它进行分析。

实验三JSP连接数据库案例一、实验目的掌握JDBC技术连接数据库的代码写法掌握Connection、PreparedStatement、ResultSet对象的使用二、实验要求1.实现JDBC技术连接数据库的配置并对数据库进行操作2.实现增加实体和查询实体两个功能三、实验内容编写一个表单与JSP网页,可以对数据库进行插入、更新与删除操作编写一个JSP网页,可以对数据库进行查询操作insert.htm代码如下:insert.jsp代码如下:query.jsp代码如下:【实验结果数据及分析】(结果)记录程序执行的结果,并对它进行分析。

JSP程序设计实验指导书

JSP程序设计实验指导书
一个数如果恰好等于除它本身外的因子之和,这个数就称为"完数",也叫“完美数”。例如6=1+2+3.(6的因子是1,2,3),因此,6就是一个完数。
<%@ page contentType="text/html;charset=GB2312" %>
<html>
<body>
从1到1000的完美数是:
<%int i,j,sum;
<%@ include file="head.txt" %>
<HTML><BODY>
<FORM action="" method=getname=form>请输入1到100数字:
<INPUT
type="text"name="number"><BR><INPUT TYPE="submit"value="送出"number=submit>
</BODY></HTML>
图4contentType的值是application/vnd.ms-powerpoint
third.jsp(效果如图5所示)<%@ page contentType="text/html; charset=GB2312" %&g<title></title>
<% String num=request.getParameter("number");
if(num==null)
num="0";

JSP实验指导

JSP实验指导

(六)编写Applet 应用小程序
1.创建一个Applet 应用程序LX3_1.java 文件。 (1)程序功能:建立一个Applet 小程序,使其可以进行简单的加法运 算。该程序要包含类、接 口、属性、方法、事件等面向对象的基本元素。 (2)程序源代码如下。 import java.awt.*; import java.awt.event.*; import java.applet.Applet; public class LX3_1 extends Applet implements ActionListener {
实验1 Java语言程序设计基础
一、实验目的
1、 了解Java 的数据类型 2、 掌握各种变量的声明方式。 3、 理解运算符的优先级。 4、 掌握Java 基本数据类型、运算符与表达式、数组的使用方法。 5、 理解Java 程序语法结构,掌握顺序结构、选择结构和循环结构语 法的程序设计方法。 6、 了解Java面向对象的编程思想及图形化界面的设计方法。 7、 通过以上内容,掌握Java 语言的编程规则。
System.out.println(" "+c+"℃ 正合适。出去玩吧。"); case 3: System.out.println(" "+c+"℃ 有点热。"); default: System.out.println(" "+c+"℃ 太热了!开空调。"); } } } (3)编译运行程序。
(七) 使用图形类Graphics
在Java 中基本图形包括点、线、圆、矩形等,是构成复杂图形的 基础。绘制基本图形要使用AWT包中的Graphics 类,它提供了各种基本 图形的绘制方法,可以直接引用这些方法画点、线、圆、矩形等。 1.创建在Applet 上画出不同的图形的程序
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《JSP编程》教学及实验大纲《JSP编程》课程实验指导书说明与约定一、编写原则编写本指导书的指导原则是:以适应市场经济对计算机专业人才的需要和学生就业需求为宗旨,以学生的实践动手能力培养为重点,突出学生学习的主体地位,给定题目及要求,以学生为主,独立或小组协作完成;鼓励学生创新;实验过程中和课余的其他时间,教师应以辅导、指导、引导为主要教学手段;加强考核,以实践能力考核为指挥棒,促使学生重视程序设计能力的提高。

二、总体要求实验课之前要写出实验预习报告(重点:实验名称、源代码)。

体现Java编程风格(源代码缩进Tab4,块花括号在类、方法名同行,等等),每个类、每个方法都要有功能说明,其说明用文档注释方式表示/*……*/。

实验一JSP页面与JSP标记(4学时)一、实验目的1.掌握JDK的安装配置2.熟悉Tomcat的配置3.测试JSP的运行环境4.掌握JSP的页面的基本结构5.掌握JSP的指令标记和动作标记二、实验要求1.实验课之前,下载最新版本的JDK和Tomcat,并在自备微机上安装配置。

2.实践内容:根据实验任务1~任务3要求,编写程序,调试运行。

3.该实验共有3个任务。

要求在webapps目录下新建一个Web服务目录:test1。

除特别要求外,本章实验中涉及的JSP页面均保存在test1中。

任务1JSP页面的基本结构1.相关知识点一个JSP页面可由普通的HTML标记、JSP标记、成员变量和方法的声明、Java 程序片以及Java表达式组成。

JSP引擎把JSP页面中的HTML标记交给用户的浏览器执行显示;JSP引擎负责处理JSP标记、变量和方法声明;JSP引擎负责运行Java程序片、计算Java 表达式,并将需要显示的结果发送给用户的浏览器。

JSP页面中的成员变量是被所有用户共享的变量。

Java 程序片可以操作成员变量,任何一个用户对JSP页面成员变量操作的结果,都会影响到其他用户。

如果多个用户访问一个JSP页面,那么该页面中的Java程序片就会被执行多次,分别运行在不同的线程中,即运行在不同的时间片内。

运行在不同线程中的Java程序片的局部变量互不干扰,即一个用户改变Java程序片中的局部变量的值不会影响其他用户的Java程序片中的局部变量。

2.实验目的本实验的目的是让学生掌握怎样在JSP页面中使用成员变量,怎样使用Java程序片、Java表达式。

3.实验要求编写两个JSP页面,分别为inputName.jsp和people.jsp。

(1)inputName.jsp的具体要求该页面有一个表单,用户通过该表单输入自己的姓名并提交给people.jsp页面。

(2)people.jsp的具体要求该页面有名字为person、类型是StringBuffer以及名字是count、类型为int的成员变量。

该页面有public void judge ()方法。

该方法负责创建person对象,当count的值是0时,judge ()方法创建person对象。

该页面有public void addPerson(String p)方法,该方法将参数p指定的字符串添加到成员变量person末尾,同时将count作自增运算。

该页面在程序片中获取inputName.jsp页面提交的姓名,然后调用judge()创建person对象、调用addPerson方法将用户的姓名添加到成员变量person末尾。

如果inputName.jsp页面没有提交姓名,或姓名含有的字符个数大于10,就使用<jsp:forward page="要转向的页面"/>标记将用户转到inputName.jsp页面。

通过Java表达式输出person和count的值。

4.JSP页面效果示例inputName.jsp(效果如图1-1所示)图1-1 输入姓名people.jsp(效果如图1-2所示)图1-2 显示姓名和人数5.参考代码代码仅供参考,学生可按照实验要求,参考本代码编写代码。

JSP页面参考代码inputName.jsp<%@ page contentType="text/html;charset=GB2312" %><HTML><BODY bgcolor=cyan><FONT size=3><FORM action="people.jsp" method=get name=form>请输入姓名:<INPUT type="text" name="name"><BR> <INPUT TYPE="submit" value="送出" name=submit></FORM></BODY></HTML>people.jsp<%@ page contentType="text/html;charset=GB2312" %><HTML><BODY BGCOLOR=yellow><FONT Size=3><%!int count;StringBuffer person;public void judge(){if(count==0)person=new StringBuffer();}public void addPerson(String p){if(count==0){person.append(p);}else{person.append(","+p);}count++;}%><%String name=request.getParameter("name");byte bb[]=name.getBytes("iso-8859-1");name=new String(bb);if(name.length()==0||name.length()>10){%> <jsp:forward page="inputName.jsp" /><% }judge();addPerson(name);%><BR> 目前共有<%=count%>人浏览了该页面,他们的名字是:<BR> <%=person%></FONT></BODY></HTML>任务2JSP指令标记1.相关知识点page 指令<%@ page 属性1="属性1的值" 属性2= "属性2的值" …%>用来定义整个JSP页面的一些属性和这些属性的值。

比较常用的两个属性是contentType和import。

page指令只能为contentType指定一个值,但可以为import属性指定多个值。

include指令标记<%@ include file= "文件的URL " %>的作用是在JSP页面出现该指令的位置处,静态插入一个文件。

被插入的文件必须是可访问和可使用的,如果该文件和当前JSP页面在同一Web服务目录中,那么“文件的URL”就是文件的名字;如果该文件在JSP 页面所在的Web服务目录的一个子目录中,比如fileDir子目录中,那么“文件的URL”就是“fileDir/文件的名字”。

include指令标记在编译阶段就处理所需要的文件,被处理的文件在逻辑和语法上依赖于当前JSP页面,其优点是页面的执行速度快。

2.实验目的本实验的目的是让学生掌握怎样在JSP页面中使用page指令设置contentType的值;使用include指令在JSP页面中静态插入一个文件的内容。

3.实验要求编写三个JSP 页面:first.jsp 、second.jsp和third.jsp。

另外,要求用“记事本”编写一个TXT文件hello.txt。

hello.txt的每行有若干个英文单词,单词之间用空格分隔,每行之间用“<BR>”分隔,如下所示:hello.txtpackage apple void back public<BR>private throw class hello welcome(1)first.jsp的具体要求first.jsp使用page指令设置contentType属性的值是text/plain,使用include指令静态插入hello.txt文件。

(2)second.jsp的具体要求second.jsp使用page指令设置contentType属性的值是application/vnd.ms-powerpoint,使用include指令静态插入hello.txt文件。

(3)third.jsp的具体要求third.jsp使用page指令设置contentType属性的值是application/msword,使用include 指令静态插入hello.txt文件。

4.JSP页面效果示例first.jsp(效果如图1-3所示)图1-3 contentType的值是text/plainsecond.jsp(效果如图1-4所示)图1-4 contentType的值是application/vnd.ms-powerpoint third.jsp(效果如图1-5所示)图1-5 contentType的值是application/msword 5.参考代码代码仅供参考,学生可按照实验要求,参考本代码编写代码。

JSP页面参考代码first.jsp<%@ page contentType="text/plain" %><HTML><BODY ><FONT size=4 color=blule><%@include file="hello.txt" %></FONT></BODY></HTML>second.jsp<%@ page contentType="application/vnd.ms-powerpoint" %> <HTML><BODY ><FONT size=2 color=blule><%@include file="hello.txt" %></FONT></BODY></HTML>third.jsp<%@ page contentType="application/msword" %><HTML><BODY ><FONT size=4 color=blule><%@include file="hello.txt" %></FONT></BODY></HTML>任务3JSP动作标记1.相关知识点include 动作标记<jsp:include page="文件的URL"/>是在JSP页面运行时才处理加载的文件,被加载的文件在逻辑和语法上独立于当前JSP页面。

相关文档
最新文档