JSP的基础使用及应用案例

JSP的基础使用及应用案例

JSP的基础使用及应用案例

引言:

本文主要分享了有关JSP的相关知识,包括:JSP页面的格式、九个隐式对象、JSP三个页面的交互、JSP注释、输出语法、编译指令(导包、include)、JSP中调用类对象、遍历集合、使用JSP实现从数据库中拿到数据然后输出;

@[toc]

1. JSP开发_引入

文件后缀.jsp

文件首行编译指令

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

jsp: java server page 服务器端页面

2. JSP的九个隐式对象

JSP中编译执行时默认会产生9个隐式对象:

2.1 Request :请求对象

javax.servlet.http.HttpServletRequest 类的实例,获取客户端请求信息,主要用于接受http协议传送到服务器的数据,当页面请求到web容器时,JSP引擎对请求数据信息封装成request

常用方法:

request.getParameter("表单属性名称"):获取表单参数,返回值String;

request.setAttribute("key","value"):设定请求转发对象;

Object obj = request.getAttribute("key"):获取请求转发对象;

request.getRequestDispatcher("去往页面").forward(request,response):页面请求转发;

2.2 Response:响应对象

javax.servlet.http.HttpServletResponse类的实例,代表客户端的响应,当服务器创建request对象时会同时创建用于响应这个客户端的response对象,主要用于将jsp容器处理过的对象传送到客户端;

服务器响应客户端时对外发出的信息统一封装成reponse对象,随request同时创建;

2.3 out对象

响应输出为输出对象,可以把字符型打印到浏览器,打印流(PrintWriter),用来在response对象中写入内容;

2.4 session对象

javax.servlet.http.HttpSession 类的实例,代表浏览器的一次回话,用来跟踪在各个客户端请求间的会话;

有多次请求组成,有生命周期在tomcat的server.xml中设定默认25‘或30’

同一设备同一浏览器发出多次请求,属于同一session;

同一设备,不同浏览器发出多次请求,为不同session;

不同设备发出请求属于不同session

session超时就终止

服务关闭,session清空

2.5 application对象

application对象直接包装了servlet的ServletContext类的对象,是javax.servlet.ServletContext 类的实例,代表当前的web应用类似于一个全局变量;

全局作用域,随服务器启动创建,随服务器关闭消亡;

2.6 config对象

javax.servlet.ServletConfig 类的实例,包装了servlet的ServletConfig类的对象,可以获取服务器的配置信息;

2.7 pageContext对象

javax.servlet.jsp.PageContext 类的实例,页面的上下文对象,可以从中获取到当前页面的其他信息,可以从中获取到其他8个隐含对象;

2.8 Page对象

指的是当前jsp对应的servlet对象的引用

2.9 exception对象

用来处理jsp文件在执行时所产生的错误和异常

3. GET和POST传输方式

get请求地址或链接请求 参数会坠在请求url中 ,有大小限制2k大小;

post:邮寄 无大小限制 ;

4. JSP案例(输入界面--->JSP处理--->展示界面)

4.1 输入界面

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

pageEncoding="UTF-8"%>

提交页面

提交信息

成员姓名

年        龄

毕业院校

所学专业

目前住址

联系电话

4.2 JSP处理操作

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

pageEncoding="UTF-8"%>

<%

//请求转化

request.setCharacterEncoding("UTF-8");

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

//接收表单请求参数

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

int age = Integer.parseInt(request.getParameter("age"));

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

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

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

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

//业务处理

System.out.println("stuname:" + stuname +"age:" + age + "school:" + school + "specialty:" + specialty + "address:" + address + "phone:" + phone);

//显示成功页面

RequestDispatcher rd = request.getRequestDispatcher("show.jsp");

//请求转发

rd.forward(request, response);

%>

4.3 展示界面

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

pageEncoding="UTF-8"%>

展示页面

展示页面

<%

out.write("学员姓名:"+request.getParameter("stuname") + "
");

out.write("学员年龄:"+request.getParameter("age") + "
");

out.write("毕业院校:"+request.getParameter("school") + "
");

out.write("所学专业:"+request.getParameter("specialty") + "
");

out.write("现住地址:"+request.getParameter("address") + "
");

out.write("电话号码:"+request.getParameter("phone") + "
");

%>

4.4 运行结果

5. JSP相关语法及知识

5.1 JSP注释

HTML注释:

< !-- xxxx-- > :可以发送到浏览器中;

JSP注释:

<%--xxxxxx--%>:只能存在于jsp中,不会随网页发往浏览器;

<%--Java注释,浏览器不可见 --%>

5.2 JSP中的输出语法

输出到java控制台 System.out.XXX() 原生的java语法

out输出:输出到响应流中

<% out.print("xxxx")%>

表达式输出

<%=java表达式%>

5.2.1 home.html页面传入数据

Person info...

欢迎你!!!

personName:
age:
sex:

5.2.2 Java输出以及Out输出

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

pageEncoding="UTF-8"%>

<%

//获取表单提交的内容

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

String ageStr = request.getParameter("age");

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

int age = Integer.parseInt(ageStr);

//Java输出

System.out.println(name + "\t" + age +"\t" +sex);

out.print("使用Java书写HTML");

out.print("");

out.print("

");

out.print(name+" "+age+" "+sex);

out.print("

");

out.print("");

%>

5.2.3 表达式输出

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

pageEncoding="UTF-8"%>

使用Java书写HTML

<%

//获取表单提交的属性数据

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

String ageStr = request.getParameter("age");

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

int age = Integer.parseInt(ageStr);

%>

<%--JSP表达式:必须等号开始,不能带有分号 --%>

name:<%=request.getParameter("name") %>

age:<%=request.getParameter("age") %>

sex:<%=request.getParameter("sex") %>

5.3 JSP常见的编译指令

5.3.1 page

import属性(导包):

方法1: <%@ page language="java" contentType="text/html; charset=UTF-8" import="java.util.,java.text." pageEncoding="UTF-8"%>

方法2:<%@page import ="java.text.*" %>

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

pageEncoding="UTF-8" import="java.util.*"%>

<%@page import = "java.text.*" %>

Insert title here

<%

Date date = new Date();

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");

String dateStr = sdf.format(date);

%>

<%=dateStr %>

5.3.2 include

语法:<%@include file="xxx.jsp"%>

作用:将页面通用部分单独作为一个页,可以重复利用便于修改;

5.3.2.1 页头

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

pageEncoding="UTF-8"%>

Insert title here

页头

5.3.2.2页脚

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

pageEncoding="UTF-8"%>

Insert title here

页脚

5.3.2.3 main.jsp_添加页头页脚

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

pageEncoding="UTF-8"%>

Insert title here

<%@include file = "header.jsp" %>

main content......

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

5.3.2.4 list.jsp_复用页头页脚

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

pageEncoding="UTF-8"%>

Insert title here

<%@include file="header.jsp" %>

我是商品列表清单

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

5.4 JSP中调用Java类对象

步骤:

导包

创建对象

调用方法

5.4.1 编写Person类

package com.kaka.entity;

public class Person {

private int pid;

private String pname;

private int age;

private String address;

public Person() {

super();

}

public Person(int pid, String pname, int age, String address) {

super();

this.pid = pid;

this.pname = pname;

this.age = age;

this.address = address;

}

@Override

public String toString() {

return "Person [pid=" + pid + ", pname=" + pname + ", age=" + age + ", address=" + address + "]";

}

public int getPid() {

return pid;

}

public void setPid(int pid) {

this.pid = pid;

}

public String getPname() {

return pname;

}

public void setPname(String pname) {

this.pname = pname;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

public String getAddress() {

return address;

}

public void setAddress(String address) {

this.address = address;

}

}

5.4.2 编写entityUse,jsp

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

pageEncoding="UTF-8" import="com.kaka.entity.Person"%>

<%

//jsp中使用java对象-实体应用

Person person = new Person();

person.setPid(1001);

person.setPname("kaka");

person.setAge(23);

person.setAddress("陕西省西安市");

//将person对象放入request作用域中

request.setAttribute("person", person);

request.getRequestDispatcher("success.jsp").forward(request, response);

%>

5.4.3 编写success,jsp

<%@ page language="java" import="com.kaka.entity.Person" contentType="text/html; charset=UTF-8"

pageEncoding="UTF-8"%>

Insert title here

<%

if( request.getAttribute("person")!=null){

Person per = (Person) request.getAttribute("person");

out.write(per.toString());

}

%>

5.4.4 运行结果

5.5 JSP中如何遍历Java集合对象

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

pageEncoding="UTF-8" import = "com.kaka.entity.Person,java.util.*"%>

Insert title here

<%

//jsp中遍历对象对象应用

List li = new ArrayList();

li.add(new Person(1001,"kaka",23,"西安"));

li.add(new Person(1002,"zhangsan",23,"武汉"));

li.add(new Person(1003,"lisi",23,"北京"));

li.add(new Person(1004,"wangwu",23,"西安"));

%>

<%for(int i=0;i

Person p = (Person) li.get(i);

%>

<%} %>

id name age address
<%=p.getPid() %> <%=p.getPname() %> <%=p.getAge() %> <%=p.getAddress() %>

遍历结果

5.6 JSP实现数据库查找功能

利用JDBC从数据库中拿到数据,在通过JSP页面显示出来

5.6.1 编写Dept.java类

package com.kaka.entity;

public class Dept {

private int id;

private String name;

private String sex;

private String age;

public Dept() {

super();

}

public Dept(int id, String name, String sex, String age) {

super();

this.id = id;

this.name = name;

this.sex = sex;

this.age = age;

}

@Override

public String toString() {

return "Dept [id=" + id + ", name=" + name + ", sex=" + sex + ", age=" + age + "]";

}

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public String getAge() {

return age;

}

public void setAge(String age) {

this.age = age;

}

}

5.6.2 编写BaseDao.javaJDBC工具类

package com.kaka.util;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

public class BaseDao {

//定义常量

final static String driver = "com.mysql.jdbc.Driver";

final static String url = "jdbc:mysql://localhost:3306/db0711?useUnicode=true&characterEncoding=utf8";

final static String username = "root";

final static String password = "root";

//声明常用的对象

protected Connection conn = null;

protected PreparedStatement pstmt = null;

protected ResultSet rs = null;

//静态块

static{

try {

Class.forName(driver);

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

//获取连接

public void getConnection(){

try {

conn = DriverManager.getConnection(url,username,password);

} catch (SQLException e) {

e.printStackTrace();

}

}

//关闭资源

public void closeAll(){

if(rs != null){

try {

rs.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if(pstmt != null){

try {

pstmt.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if(conn != null){

try {

conn.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

}

5.6.3 编写接口类DeptDao.java

package com.kaka.dao;

import java.util.List;

import com.kaka.entity.Dept;

public interface DeptDao {

public List findAll();

}

5.6.4 编写接口实现类DeptDaoImpl.java

package com.kaka.dao.impl;

import java.sql.SQLException;

import java.util.ArrayList;

import java.util.List;

import com.kaka.dao.DeptDao;

import com.kaka.entity.Dept;

import com.kaka.util.BaseDao;

public class DeptDaoImpl extends BaseDao implements DeptDao{

@Override

public List findAll() {

String sql = "select * from student";

List li = new ArrayList();

try {

super.getConnection();

pstmt = conn.prepareStatement(sql);

rs = pstmt.executeQuery();

while(rs.next()){

Dept d = new Dept();

d.setId(rs.getInt("id"));

d.setName(rs.getString("name"));

d.setSex(rs.getString("sex"));

d.setAge(rs.getString("age"));

li.add(d);

}

return li;

} catch (SQLException e) {

e.printStackTrace();

}finally{

super.closeAll();

}

return null;

}

}

5.6.5 编写showDept.jsp

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

pageEncoding="UTF-8" import="java.util.*,com.kaka.entity.*,com.kaka.dao.*,com.kaka.dao.impl.*"%>

Insert title here

<%

DeptDao deptDao = new DeptDaoImpl();

List depts = deptDao.findAll();

for(int i = 0; i < depts.size(); i++){

Dept d = depts.get(i);

%>

<%}%>

IDNAMESEXAGE
<%=d.getId() %> <%=d.getName() %> <%=d.getAge() %> <%=d.getSex() %> 编辑删除

5.6.6 运行结果

相关文章

穿作腹黑影后的赘A
beat365官方网站

穿作腹黑影后的赘A

08-23 5957
直播答题相关
官网体育在线365

直播答题相关

10-20 1022
Alloy218不锈钢知识介绍
官网体育在线365

Alloy218不锈钢知识介绍

10-25 814
甘肃会宁:“葱”民蹚出致富增收路
官网体育在线365

甘肃会宁:“葱”民蹚出致富增收路

06-28 7992
让0球什么意思
官网体育在线365

让0球什么意思

09-18 5814
5 款最佳 Android 应用程序隐藏器
beat365官方网站

5 款最佳 Android 应用程序隐藏器

08-13 9889
中国社会科学报:中国宗族演变的阶段性及其特色
365娱乐游戏是哪个公司

中国社会科学报:中国宗族演变的阶段性及其特色

08-05 4895
1.Object类、以及通用的类
365娱乐游戏是哪个公司

1.Object类、以及通用的类

08-06 7897