Day-48接昨天和什么是jsp

  1. 常用请求头的说明

Accept: 表示客户端可以接收的数据类型

Accpet-Languege: 表示客户端可以接收的语言类型

User-Agent: 表示客户端浏览器的信息

Host: 表示请求时的服务器 ip 和端口号

  1. 哪些是 GET 请求,哪些是 POST 请求

GET 请求有哪些:

1form 标签 method=get

2a 标签

3link 标签引入 css

4Script 标签引入 js 文件

5img 标签引入图片

6iframe 引入 html 页面

7、在浏览器地址栏中输入地址后敲回车

POST 请求有哪些:

  1. form 标签 method=post

响应的 HTTP 协议格式

1、响应行

(1) 响应的协议和版本号

(2) 响应状态码

(3) 响应状态描述符

2、响应头

(1) key : value

不同的响应头,有其不同含义

空行

3、响应体

---->>> 就是回传给客户端的数据

3.常用的响应码说明

200 表示请求成功

302 表示请求重定向(明天讲)

404 表示请求服务器已经收到了,但是你要的数据不存在(请求地址错误)

500 表示服务器已经收到请求,但是服务器内部错误(代码错误)

4.MIME类型说明

MIME HTTP 协议中数据类型。

MIME 的英文全称是"Multipurpose Internet Mail Extensions" 多功能 Internet 邮件扩充服务。MIME 类型的格式是“大类型/小类型”,并与某一种文件的扩展名相对应。

常见的 MIME 类型:

谷歌浏览器如何查看 HTTP 协议

 

3.6 Request&Response

1. HttpServletRequest类的作用

每次只要有请求进入 Tomcat 服务器,Tomcat 服务器就会把请求过来的 HTTP 协议信息解析好封装到 Request 对象中。然后传递到 service 方法(doGetdoPost)中给我们使用。我们可以通过 HttpServletRequest对象,获取到所有请求的信息。

2. HttpServletRequest的常用方法

i. getRequestURI()  获取请求的资源路径

ii. getRequestURL() 获取请求的统一资源定位符(绝对路径)

iii. getRemoteHost() 获取客户端的 ip 地址

iv. getHeader() 获取请求头

v. getParameter() 获取请求的参数

vi.  getParameterValues() 获取请求的参数(多个值的时候使用)

vii. getMethod() 获取请求的方式 GET POST

viii. setAttribute(key, value); 设置域数据

ix. getAttribute(key); 获取域数据

x. getRequestDispatcher() 获取请求转发对象

常用 API 示例代码:

public class RequestAPIServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

//

i.getRequestURI()

获取请求的资源路径

System.out.println("URI => " + req.getRequestURI());

//

ii.getRequestURL()

获取请求的统一资源定位符(绝对路径)

System.out.println("URL => " + req.getRequestURL());//

iii.getRemoteHost()

获取客户端的 ip 地址

/**

* IDEA 中,使用 localhost 访问时,得到的客户端 ip 地址是 ===>>> 127.0.0.1<br/>

* IDEA 中,使用 127.0.0.1 访问时,得到的客户端 ip 地址是 ===>>> 127.0.0.1<br/>

* IDEA 中,使用 真实 ip 访问时,得到的客户端 ip 地址是 ===>>> 真实的客户端 ip 地址<br/>

*/

System.out.println("客户端 ip 地址 => " + req.getRemoteHost());

//

iv.getHeader()

获取请求头

System.out.println("请求头 User-Agent ==>> " + req.getHeader("User-Agent"));

//

vii.getMethod()

获取请求的方式 GET POST

System.out.println( "请求的方式 ==>> " + req.getMethod() );

}

}

3. 如何获取请求参数

表单:

<body>

<form action="http://localhost:8080/07_servlet/parameterServlet" method="get">

用户名:<input type="text" name="username"><br/>

密码:<input type="password" name="password"><br/>

兴趣爱好:<input type="checkbox" name="hobby" value="cpp">C++

<input type="checkbox" name="hobby" value="java">Java

<input type="checkbox" name="hobby" value="js">JavaScript<br/>

<input type="submit">

</form>

</body>

Java 代码:

public class ParameterServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

// 获取请求参数

String username = req.getParameter("username");

String password = req.getParameter("password");

String[] hobby = req.getParameterValues("hobby");

System.out.println("用户名:" + username);

System.out.println("密码:" + password);

System.out.println("兴趣爱好:" + Arrays.asList(hobby));}

}

4. 乱码解决

  1、doGet乱码

   // 获取请求参数

String username = req.getParameter("username");

//1 先以 iso8859-1 进行编码

//2 再以 utf-8 进行解码

username = new String(username.getBytes("iso-8859-1"), "UTF-8");

  2、doPost乱码

@Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

// 设置请求体的字符集为 UTF-8,从而解决 post 请求的中文乱码问题

req.setCharacterEncoding("UTF-8");

System.out.println("-------------doPost------------");

// 获取请求参数

String username = req.getParameter("username");

String password = req.getParameter("password");

String[] hobby = req.getParameterValues("hobby");

System.out.println("用户名:" + username);

System.out.println("密码:" + password);

System.out.println("兴趣爱好:" + Arrays.asList(hobby));

}

  1. 请求转发

什么是请求的转发?

请求转发是指,服务器收到请求后,从一次资源跳转到另一个资源的操作叫请求转发。

Servlet1 代码:

public class Servlet1 extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

// 获取请求的参数(办事的材料)查看

String username = req.getParameter("username");

System.out.println("Servlet1(柜台 1)中查看参数(材料):" + username);

// 给材料 盖一个章,并传递到 Servlet2(柜台 2)去查看

req.setAttribute("key1","柜台 1 的章");

// 问路:Servlet2(柜台 2)怎么走

/**

* 请求转发必须要以斜杠打头,/ 斜杠表示地址为:http://ip:port/工程名/ , 映射到 IDEA 代码的 web 目录

<br/>

*

*/

RequestDispatcher requestDispatcher = req.getRequestDispatcher("/servlet2");

//

RequestDispatcher requestDispatcher = req.getRequestDispatcher("http://www.baidu.com");

// 走向 Sevlet2(柜台 2

requestDispatcher.forward(req,resp);}

}

Servlet2 代码:

public class Servlet2 extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

// 获取请求的参数(办事的材料)查看

String username = req.getParameter("username");

System.out.println("Servlet2(柜台 2)中查看参数(材料):" + username);

// 查看 柜台 1 是否有盖章

Object key1 = req.getAttribute("key1");

System.out.println("柜台 1 是否有章:" + key1);

// 处理自己的业务

System.out.println("Servlet2 处理自己的业务 ");

}

}

  1. WEB中的路径

javaWeb 中,路径分为相对路径和绝对路径两种:

相对路径是:

. 表示当前目录

.. 表示上一级目录

资源名 表示当前目录/资源名

绝对路径:

http://ip:port/工程路径/资源路径

在实际开发中,路径都使用绝对路径,而不简单的使用相对路径。

  1. WEB中“/”斜杠的不同含义

web / 斜杠 是一种绝对路径。

/ 斜杠 如果被浏览器解析,得到的地址是:http://ip:port/

<a href="/">斜杠</a>

/ 斜杠 如果被服务器解析,得到的地址是:http://ip:port/工程路径

1<url-pattern>/servlet1</url-pattern>

2servletContext.getRealPath(“/”);

3request.getRequestDispatcher(“/”);

特殊情况: response.sendRediect(“/”);

把斜杠发送给浏览器解析。得到 http://ip:port/

8. HttpServletResponse类的作用

HttpServletResponse 类和 HttpServletRequest 类一样。每次请求进来,Tomcat 服务器都会创建一个 Response 对象传递给 Servlet 程序去使用。HttpServletRequest 表示请求过来的信息,HttpServletResponse 表示所有响应的信息,我们如果需要设置返回给客户端的信息,都可以通过 HttpServletResponse 对象来进行设置.

9. 两个输出流的说明

字节流 getOutputStream(); 常用于下载(传递二进制数据)

字符流 getWriter(); 常用于回传字符串(常用)

两个流同时只能使用一个。

使用了字节流,就不能再使用字符流,反之亦然,否则就会报错 

10. 如何往客户端回传数据

要求 : 往客户端回传 字符串 数据。

public class ResponseIOServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

//

要求 : 往客户端回传 字符串 数据。

PrintWriter writer = resp.getWriter();

writer.write("response's content!!!");

}

}

11. 响应的乱码解决

// 设置服务器字符集为 UTF-8

resp.setCharacterEncoding("UTF-8");

// 通过响应头,设置浏览器也使用 UTF-8 字符集

resp.setHeader("Content-Type", "text/html; charset=UTF-8");

// 它会同时设置服务器和客户端都使用 UTF-8 字符集,还设置了响应头

// 此方法一定要在获取流对象之前调用才有效

resp.setContentType("text/html; charset=UTF-8");

12. 请求重定向

请求重定向,是指客户端给服务器发请求,然后服务器告诉客户端说。我给你一些地址。你去新地址访问。叫请求重定向(因为之前的地址可能已经被废弃)。

请求重定向的第一种方案:

// 设置响应状态码 302 ,表示重定向,(已搬迁)

resp.setStatus(302);

// 设置响应头,说明 新的地址在哪里

resp.setHeader("Location", "http://localhost:8080");

请求重定向的第二种方案(推荐使用):

resp.sendRedirect("http://localhost:8080");

1.什么是 jsp,它有什么用?

jsp 的全称是 java server pagesJava 的服务器页面。

jsp 的主要作用是代替 Servlet 程序回传 html 页面的数据。

因为 Servlet 程序回传 html 页面数据是一件非常繁锁的事情。开发成本和维护成本都极高。

Servlet 回传 html 页面数据的代码:

public class PringHtml extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

// 通过响应的回传流回传 html 页面数据

resp.setContentType("text/html; charset=UTF-8");

PrintWriter writer = resp.getWriter();

writer.write("<!DOCTYPE html>\r\n");

writer.write(" <html lang=\"en\">\r\n");

writer.write(" <head>\r\n");

writer.write("

<meta charset=\"UTF-8\">\r\n");

writer.write("

<title>Title</title>\r\n");

writer.write(" </head>\r\n");

writer.write(" <body>\r\n");

writer.write("

这是 html 页面数据 \r\n");

writer.write(" </body>\r\n");

writer.write("</html>\r\n");

writer.write("\r\n");

}

}

jsp 回传一个简单 html 页面的代码:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html>

<head>

<title>Title</title>

</head>

<body>

这是 html 页面数据

</body>

</html>

jsp 的小结:

1、如何创建 jsp 的页面?

输入文件名敲回车即可!!

2jsp 如何访问:

jsp 页面和 html 页面一样,都是存放在 web 目录下。访问也跟访问 html 页面一样。

比如:

web 目录下有如下的文件:

web 目录

a.html 页面

访问地址是 =======>>>>>> http://ip:port/工程路径/a.html

b.jsp 页面

访问地址是 =======>>>>>> http://ip:port/工程路径/b.jsp

2.jsp 的本质是什么。

jsp 页面本质上是一个 Servlet 程序。

当我们第一次访问 jsp 页面的时候。Tomcat 服务器会帮我们把 jsp 页面翻译成为一个 java 源文件。并且对它进行编译成 为.class 字节码程序。我们打开 java 源文件不难发现其里面的内容是:

我们跟踪原代码发现,HttpJspBase 类。它直接地继承了 HttpServlet 类。也就是说。jsp 翻译出来的 java 类,它间接了继承了 HttpServlet 类。也就是说,翻译出来的是一个 Servlet 程序

 

总结:通过翻译的 java 源代码我们就可以得到结果:jsp 就是 Servlet 程序。

大家也可以去观察翻译出来的 Servlet 程序的源代码,不难发现。其底层实现,也是通过输出流。把 html 页面数据回传给客户端。

public void _jspService(final javax.servlet.http.HttpServletRequest request, final

javax.servlet.http.HttpServletResponse response)

throws java.io.IOException, javax.servlet.ServletException {

final java.lang.String _jspx_method = request.getMethod();

if (!"GET".equals(_jspx_method) && !"POST".equals(_jspx_method) && !"HEAD".equals(_jspx_method)

&& !javax.servlet.DispatcherType.ERROR.equals(request.getDispatcherType())) {response.sendError(HttpServletResponse.SC_METHOD_NOT_ALLOWED, "JSPs only permit GET POST or

HEAD");

return;

}

final javax.servlet.jsp.PageContext pageContext;

javax.servlet.http.HttpSession session = null;

final javax.servlet.ServletContext application;

final javax.servlet.ServletConfig config;

javax.servlet.jsp.JspWriter out = null;

final java.lang.Object page = this;

javax.servlet.jsp.JspWriter _jspx_out = null;

javax.servlet.jsp.PageContext _jspx_page_context = null;

try {

response.setContentType("text/html;charset=UTF-8");

pageContext = _jspxFactory.getPageContext(this, request, response,

null, true, 8192, true);

_jspx_page_context = pageContext;

application = pageContext.getServletContext();

config = pageContext.getServletConfig();

session = pageContext.getSession();

out = pageContext.getOut();

_jspx_out = out;

out.write("\r\n");

out.write("\r\n");

out.write("<html>\r\n");

out.write("<head>\r\n");

out.write("

<title>Title</title>\r\n");

out.write("</head>\r\n");

out.write("<body>\r\n");

out.write("

a.jsp 页面\r\n");

out.write("</body>\r\n");

out.write("</html>\r\n");

} catch (java.lang.Throwable t) {

if (!(t instanceof javax.servlet.jsp.SkipPageException)){

out = _jspx_out;

if (out != null && out.getBufferSize() != 0)

try {

if (response.isCommitted()) {

out.flush();

} else {

out.clearBuffer();

}

} catch (java.io.IOException e) {}

if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);

else throw new ServletException(t);}

} finally {

_jspxFactory.releasePageContext(_jspx_page_context);

}

}

3.jsp 的三种语法

a)jsp 头部的 page 指令

jsp page 指令可以修改 jsp 页面中一些重要的属性,或者行为。

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

i. language 属性 表示 jsp 翻译后是什么语言文件。暂时只支持 java

ii. contentType 属性 表示 jsp 返回的数据类型是什么。也是源码中 response.setContentType()参数值

iii. pageEncoding 属性 表示当前 jsp 页面文件本身的字符集。

iv. import 属性 跟 java 源代码中一样。用于导包,导类。

=====================两个属性是给 out 输出流使用======================

v. autoFlush 属性 设置当 out 输出流缓冲区满了之后,是否自动刷新冲区。默认值是 true

vi. buffer 属性 设置 out 缓冲区的大小。默认是 8kb

缓冲区溢出错误:

=====================两个属性是给 out 输出流使用======================

vii. errorPage 属性 设置当 jsp 页面运行时出错,自动跳转去的错误页面路径。

<!--

errorPage 表示错误后自动跳转去的路径 <br/>

这个路径一般都是以斜杠打头,它表示请求地址为 http://ip:port/工程路径/映射到代码的 Web 目录

-->

viii. isErrorPage 属性 设置当前 jsp 页面是否是错误信息页面。默认是 false。如果是 true 可以获取异常信息。

ix. session 属性 设置访问当前 jsp 页面,是否会创建 HttpSession 对象。默认是 true

x. extends 属性 设置 jsp 翻译出来的 java 类默认继承谁。

b)jsp 中的常用脚本

i. 声明脚本(极少使用)

声明脚本的格式是: <%! 声明 java 代码 %>

作用:可以给 jsp 翻译出来的 java 类定义属性和方法甚至是静态代码块。内部类等。

练习:

1、声明类属性

2、声明 static 静态代码块

3、声明类方法

4、声明内部类

代码示例:

<%--1、声明类属性--%>

<%!

private Integer id;

private String name;

private static Map<String,Object> map;

%>

<%--2、声明 static 静态代码块--%>

<%!

static {

map = new HashMap<String,Object>();

map.put("key1", "value1");

map.put("key2", "value2");

map.put("key3", "value3");

}

%>

<%--3、声明类方法--%>

<%!

public int abc(){

return 12;

}

%><%--4、声明内部类--%>

<%!

public static class A {

private Integer id = 12;

private String abc = "abc";

}

%>

声明脚本代码翻译对照:

ii. 表达式脚本(常用)

表达式脚本的格式是:<%=表达式%>

表达式脚本的作用是:在jsp 页面上输出数据。

表达式脚本的特点:

1、所有的表达式脚本都会被翻译到_jspService() 方法中

2、表达式脚本都会被翻译成为 out.print()输出到页面上

3、由于表达式脚本翻译的内容都在_jspService() 方法中,所以_jspService()方法中的对象都可以直接使用。

4、表达式脚本中的表达式不能以分号结束。

练习:

1. 输出整型

2. 输出浮点型

3. 输出字符串

4. 输出对象

示例代码:

<%=12 %> <br>

<%=12.12 %> <br>

<%="我是字符串" %> <br>

<%=map%> <br>

<%=request.getParameter("username")%>

翻译对照:

iii. 代码脚本

代码脚本的格式是:

<%

java 语句

%>

代码脚本的作用是:可以在 jsp 页面中,编写我们自己需要的功能(写的是 java 语句)。

代码脚本的特点是:

1、代码脚本翻译之后都在_jspService 方法中

2、代码脚本由于翻译到_jspService()方法中,所以在_jspService()方法中的现有对象都可以直接使用。

3、还可以由多个代码脚本块组合完成一个完整的 java 语句。

4、代码脚本还可以和表达式脚本一起组合使用,在 jsp 页面上输出数据

练习:

1. 代码脚本----if 语句

2. 代码脚本----for 循环语句

3. 翻译后 java 文件中_jspService 方法内的代码都可以写

示例代码:

<%--练习:--%>

<%--1.代码脚本----if 语句--%>

<%int i = 13 ;

if (i == 12) {

%>

<h1>mark好帅</h1>

<%

} else {

%>

<h1>mark又骗人了!</h1>

<%

}

%>

<br>

<%--2.代码脚本----for 循环语句--%>

<table border="1" cellspacing="0">

<%

for (int j = 0; j < 10; j++) {

%>

<tr>

<td><%=j + 1%></td>

</tr>

<%

}

%>

</table>

<%--3.翻译后 java 文件中_jspService 方法内的代码都可以写--%>

<%

String username = request.getParameter("username");

System.out.println("用户名的请求参数值是:" + username);

%>

翻译之后的对比:

c)jsp 中的三种注释

i. html 注释

<!-- 这是 html 注释 -->

html 注释会被翻译到 java 源代码中。在_jspService 方法里,以 out.writer 输出到客户端。

ii. java 注释

<%

// 单行 java 注释

/* 多行 java 注释 */

%>

java 注释会被翻译到 java 源代码中。

iii. jsp 注释

<%-- 这是 jsp 注释 --%>

jsp 注释可以注掉,jsp 页面中所有代码。

4.jsp 九大内置对象

jsp 中的内置对象,是指 Tomcat 在翻译 jsp 页面成为 Servlet 源代码后,内部提供的九大对象,叫内置对象。

5.jsp 四大域对象

四个域对象分别是:

pageContext (PageContextImpl ) 当前 jsp 页面范围内有效

request (HttpServletRequest )、 一次请求内有效

session (HttpSession )、 一个会话范围内有效(打开浏览器访问服务器,直到关闭浏览器)

application (ServletContext ) 整个 web 工程范围内都有效(只要 web 工程不停止,数据都在)

域对象是可以像 Map 一样存取数据的对象。

四个域对象功能一样。不同的是它们对数据的存取范围。

虽然四个域对象都可以存取数据。在使用上它们是有优先顺序的。

四个域在使用的时候,优先顺序分别是,他们从小到大的范围的顺序。

pageContext ====>>> request ====>>> session ====>>> application

scope.jsp 页面

<body>

<h1>scope.jsp 页面</h1>

<%

// 往四个域中都分别保存了数据

pageContext.setAttribute("key", "pageContext");

request.setAttribute("key", "request");

session.setAttribute("key", "session");

application.setAttribute("key", "application");

%>

pageContext 域是否有值:<%=pageContext.getAttribute("key")%> <br>

request 域是否有值:<%=request.getAttribute("key")%> <br>

session 域是否有值:<%=session.getAttribute("key")%> <br>

application 域是否有值:<%=application.getAttribute("key")%> <br>

<%

request.getRequestDispatcher("/scope2.jsp").forward(request,response);

%>

</body>

scope2.jsp 页面

<body>

<h1>scope2.jsp 页面</h1>

pageContext 域是否有值:<%=pageContext.getAttribute("key")%> <br>

request 域是否有值:<%=request.getAttribute("key")%> <br>

session 域是否有值:<%=session.getAttribute("key")%> <br>

application 域是否有值:<%=application.getAttribute("key")%> <br>

</body>

6.jsp中的out输出和 response.getWriter 输出的区别

response 中表示响应,我们经常用于设置返回给客户端的内容(输出)

out 也是给用户做输出使用的。

由于 jsp 翻译之后,底层源代码都是使用 out 来进行输出,所以一般情况下。我们在 jsp 页面中统一使用 out 来进行输出。避免打乱页面输出内容的顺序。

out.write() 输出字符串没有问题

out.print() 输出任意数据都没有问题(都转换成为字符串后调用的 write 输出)

深入源码,浅出结论:在 jsp 页面中,可以统一使用 out.print()来进行输出

7.jsp 的常用标签

a)jsp 静态包含

示例说明:

<%--

<%@ include file=""%> 就是静态包含

file 属性指定你要包含的 jsp 页面的路径

地址中第一个斜杠 / 表示为 http://ip:port/工程路径/ 映射到代码的 web 目录

静态包含的特点:

1、静态包含不会翻译被包含的 jsp 页面。

2、静态包含其实是把被包含的 jsp 页面的代码拷贝到包含的位置执行输出。--%>

<%@ include file="/include/footer.jsp"%>

b)jsp 动态包含

示例说明:

<%--

<jsp:include page=""></jsp:include>

这是动态包含

page 属性是指定你要包含的 jsp 页面的路径

动态包含也可以像静态包含一样。把被包含的内容执行输出到包含位置

动态包含的特点:

1、动态包含会把包含的 jsp 页面也翻译成为 java 代码

2、动态包含底层代码使用如下代码去调用被包含的 jsp 页面执行输出。

JspRuntimeLibrary.include(request, response, "/include/footer.jsp", out, false);

3、动态包含,还可以传递参数

--%>

<jsp:include page="/include/footer.jsp">

<jsp:param name="username" value="bbj"/>

<jsp:param name="password" value="root"/>

</jsp:include>

动态包含的底层原理:

c)jsp 标签-转发

示例说明:

<%--

<jsp:forward page=""></jsp:forward> 是请求转发标签,它的功能就是请求转发

page 属性设置请求转发的路径

--%>

<jsp:forward page="/scope2.jsp"></jsp:forward>

8jsp 的练习题

练习一:在 jsp 页面中输出九九乘法口诀表

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html>

<head>

<title>Title</title>

<style type="text/css">

table{

width: 650px;

}

</style>

</head>

<body>

<%-- 练习一:在 jsp 页面中输出九九乘法口诀表 --%>

<h1 align="center">九九乘法口诀表</h1>

<table align="center">

<%-- 外层循环遍历行 --%>

<% for (int i = 1; i <= 9; i++) { %>

<tr>

<%-- 内层循环遍历单元格 --%>

<% for (int j = 1; j <= i ; j++) { %>

<td><%=j + "x" + i + "=" + (i*j)%></td>

<% } %>

</tr>

<% } %>

</table></body>

</html>

练习二:jsp 输出一个表格,里面有 10 个学生信息。

Student 类:

public class Student {

private Integer id;

private String name;

private Integer age;

private String phone;

SearchStudentServlet 程序:

public class SearchStudentServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException,

IOException {

// 获取请求的参数

// sql 语句查询学生的信息

// 使用 for 循环生成查询到的数据做模拟

List<Student> studentList = new ArrayList<Student>();

for (int i = 0; i < 10; i++) {

int t = i + 1;

studentList.add(new Student(t,"name"+t, 18+t,"phone"+t));

}

// 保存查询到的结果(学生信息)到 request 域中

req.setAttribute("stuList", studentList);

// 请求转发到 showStudent.jsp 页面req.getRequestDispatcher("/test/showStudent.jsp").forward(req,resp);

}

}

showStudent.jsp 页面

<%@ page import="java.util.List" %>

<%@ page import="com.tledu.pojo.Student" %>

<%@ page import="java.util.ArrayList" %>

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html>

<head>

<title>Title</title>

<style>

table{

border: 1px blue solid;

width: 600px;

border-collapse: collapse;

}

td,th{

border: 1px blue solid;

}

</style>

</head>

<body>

<%--练习二:jsp 输出一个表格,里面有 10 个学生信息。--%>

<%

List<Student> studentList = (List<Student>) request.getAttribute("stuList");

%>

<table>

<tr>

<td>编号</td>

<td>姓名</td>

<td>年龄</td>

<td>电话</td>

<td>操作</td>

</tr>

<% for (Student student : studentList) { %>

<tr>

<td><%=student.getId()%></td>

<td><%=student.getName()%></td>

<td><%=student.getAge()%></td>

<td><%=student.getPhone()%></td>

<td>删除、修改</td>

</tr>

<% } %>

</table></body>

</html>

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值