JSP
- 指令
作用:用于配置JSP页面,导入资源文件
格式:<%@ 指令名称 属性名1=属性值1 属性名2=属性值2 ... %>
分类:
page相关
- page: 配置JSP页面的, *contentType:等同于response.setContentType();1. 设置响应体的mime类型以及字符集, 2. 设置当前jsp页面的编码(只能是高级的IDE才能生效,如果使用低级工具,则需要设置pageEncoding属性设置当前页面的字符集)
- import:导包
- errorPage:当前页面发生异常后,会自动跳转到指定的错误页面
- isErrorPage:标识当前也是是否是错误页面。true:是,可以使用内置对象exception, * false:否。默认值。不可以使用内置对象exception
include
include : 页面包含的。导入页面的资源文件
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@include file="top.jsp"%>
top.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>这是头部</h1>
</body>
</html>
taglib 导入资源
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> prefix:前缀,自定义的
注释:
1. html注释:
:只能注释html代码片段
2. jsp注释:推荐使用
<%-- --%>:可以注释所有
内置对象: 在jsp页面中不需要创建,直接使用的对象
一共有9个:
变量名 真实类型 作用
pageContext PageContext 当前页面共享数据,还可以获取其他八个内置对象
request HttpServletRequest 一次请求访问的多个资源(转发)
session HttpSession 一次会话的多个请求间
application ServletContext 所有用户间共享数据
response HttpServletResponse 响应对象
page Object 当前页面(Servlet)的对象 this
out JspWriter 输出对象,数据输出到页面上
config ServletConfig Servlet的配置对象
exception Throwable 异常对象
EL表达式
- 概念:Expression Language 表达式语言
- 作用:替换和简化jsp页面中java代码的编写、
- 语法:${表达式}
- 注意:
jsp默认支持el表达式的。如果要忽略el表达式
设置jsp中page指令中:isELIgnored="true" 忽略当前jsp页面中所有的el表达式
${表达式} :忽略当前这个el表达式
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.List" %><%--
Created by IntelliJ IDEA.
User: Eric
Date: 2020/8/31
Time: 08:50
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%--<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="true" %>--%>
<html>
<head>
<title>Title</title>
</head>
<body>
${3>4}
<br>
\${3>4}
<br>
<h3>算术运算符</h3>
${3+4}
${3*4}
${3/4}
${3%4}
${3 mod 4}
<h3>比较运算符</h3>
${3==4}
<h3>逻辑运算符</h3>
${3>4 && 3<4}
${3>4 and 3<4}
<h3>empty运算符</h3>
<%
String str = "";
request.setAttribute("str", str);
List<String> list = new ArrayList<>();
list.add("haha");
request.setAttribute("list", list);
%>
<%--${empty }--%>
${empty str}
${empty list}
${not empty str}
${not empty list}
</body>
</html>
获取值
- el表达式只能从域对象中获取值
- 语法:
- ${域名称.键名}:从指定域中获取指定键的值
- 域名称:
1. pageScope --> pageContext
2. requestScope --> request
3. sessionScope --> session
4. applicationScope --> application(ServletContext)
<%--
Created by IntelliJ IDEA.
User: Eric
Date: 2020/8/31
Time: 09:31
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
// 在域中存储数据
session.setAttribute("name", "李四");
request.setAttribute("name", "张三");
session.setAttribute("age", "23");
request.setAttribute("str", "");
%>
<h3>el获取值</h3>
${requestScope.name}
${sessionScope.name}
${sessionScope.age}
${name}
</body>
</html>
${键名}:表示依次从最小的域中查找是否有该键对应的值,直到找到为止。
-
获取对象、List集合、Map集合的值
-
对象:${域名称.键名.属性名}
- 本质上会去调用对象的getter方法
· 2. List集合:${域名称.键名[索引]}
- 本质上会去调用对象的getter方法
Map集合:
{域名称.键名["key名称"]}
-
<%@ page import="neusoft.el.User" %>
<%@ page import="java.util.Date" %>
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.List" %>
<%@ page import="java.util.HashMap" %><%--
Created by IntelliJ IDEA.
User: Eric
Date: 2020/8/31
Time: 09:35
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
User user = new User();
user.setName("小桌子");
user.setAge(23);
user.setBirthday(new Date());
request.setAttribute("u", user);
List<Object> list = new ArrayList<>();
list.add("aaa");
list.add("bbb");
list.add(user);
request.setAttribute("list", list);
HashMap<String, Object> map = new HashMap<>();
map.put("sname", "赵四");
map.put("gender", "男");
map.put("user", user);
request.setAttribute("map", map);
%>
<h1>el获取对象中的值</h1>
${requestScope.u}
<%-- 对象属性获取
setter 或者 getter方法 去掉 set和get
将剩余部分首字母变为小写
getName() ---> Name ----> name
--%>
${requestScope.u.name}<br>
${u.age} <br>
${u.birthday}<br>
<h3>获取list值</h3>
${requestScope.list}
${list}
${list[0]}
${list[2]}
${list[2].name}
<h5>list[10]</h5>
${list[10]}
<h3>获取map值</h3>
${requestScope.map}
${map}
${map.gender}
${map["gender"]}
${map.user.name}
</body>
</html>
JSTL
概念:JavaServer Pages Tag Library JSP标准标签库,是由Apache组织提供的开源的免费的jsp标签<标签>。 作用:用于简化和替换jsp页面上的java代码
使用步骤:
- 导入jstl相关jar包
- 引入标签库:taglib指令: <%@ taglib %>
- 使用标签
- 常用的JSTL标签
1. if:相当于java代码的if语句
- 属性:
- test 必须属性,接受boolean表达式
- 如果表达式为true,则显示if标签体内容,如果为false,则不显示标签体内容
- 一般情况下,test属性值会结合el表达式一起使用
- 注意:
- c:if标签没有else情况,想要else情况,则可以在定义一个c:if标签
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.List" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>if标签</title>
</head>
<body>
<%--c:if
1、 属性 test 必须属性, 接受的是boolean表达式
一般 test配合 el表达式一起使用
2、 没有else部分, 想要的话需要在定义一个 c:if
--%>
<c:if test="fasle">
<h1>还有一个月就过节了</h1>
</c:if>
<%
List<Object> list = new ArrayList<>();
list.add("aaaa");
request.setAttribute("list", list);
request.setAttribute("number", 6);
%>
<c:if test="${not empty requestScope.list}">
<h2>遍历集合</h2>
</c:if>
<br>
<c:if test="${number % 2 != 0}">
<h2>${number}为奇数</h2>
</c:if>
<c:if test="${number % 2 == 0}">
<h2>${number}为偶数</h2>
</c:if>
</body>
</html>
2. choose:相当于java代码的switch语句
- 使用choose标签声明 相当于switch声明
- 使用when标签做判断 相当于case
- 使用otherwise标签做其他情况的声明 相当于default
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.List" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="d" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>choose标签</title>
</head>
<body>
<%
request.setAttribute("number", 7);
%>
<d:choose>
<d:when test="${number == 1}">星期一</d:when>
<d:when test="${number == 2}">星期二</d:when>
<d:when test="${number == 3}">星期三</d:when>
<d:when test="${number == 4}">星期四</d:when>
<d:when test="${number == 5}">星期五</d:when>
<d:when test="${number == 6}">星期六</d:when>
<d:when test="${number == 7}">星期天</d:when>
<d:otherwise >过年</d:otherwise>
</d:choose>
</body>
</html>
3. foreach:相当于java代码的for语句
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.List" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>forEach标签</title>
</head>
<body>
<!--
begin 开始
end 结束
var 临时变量
step 步长
varStatus :循环状态对象
index : 容器中元素的索引
count : 循环次数 (从开始)
items : 容器对象
-->
<c:forEach begin="0" end="10" var="i" step="2" varStatus="s">
${i}
<h3>index ${s.index}</h3>
<h4>count ${s.count}</h4>
</c:forEach>
<hr>
<%
List<String> list = new ArrayList<>();
list.add("小鲁班");
list.add("妲己");
list.add("后羿");
request.setAttribute("list", list);
// for (String str:
// list) {
//
// }
%>
<c:forEach items="${list}" var="str" varStatus="s">
${s.index} ---- ${s.count} ${str}<br>
</c:forEach>
</body>
</html>
Spring JDBC JdbcTemplate
Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发
- 导入jar包
- 创建JdbcTemplate对象。依赖于数据源DataSource, JdbcTemplate template = new JdbcTemplate(ds);
- 调用JdbcTemplate的方法来完成CRUD的操作
* update():执行DML语句。增、删、改语句
* queryForMap():查询结果将结果集封装为map集合,将列名作为key,将值作为value 将这条记录封装为一个map集合
* 注意:这个方法查询的结果集长度只能是1
* queryForList():查询结果将结果集封装为list集合
* 注意:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中
* query():查询结果,将结果封装为JavaBean对象 * query的参数:RowMapper
* 一般我们使用BeanPropertyRowMapper实现类。可以完成数据到JavaBean的自动封装 new BeanPropertyRowMapper<类型>(类型.class)
* queryForObject:查询结果,将结果封装为对象
* 一般用于聚合函数的查询