JSTL标签

<!-- 写在jsp文件的最前 -->
<!-- JSTL标签库是一个JSP标签的集合,封装了许多jsp应用程序通用的核心功能
prefix="c"标签库的别名是c-->
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<!-- JSTL格式化标签 -->
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="f"%>

13 JSTL标签库与EL表达式综合运用

新建两个封装类,一个User一个City,city类重写有参构造方法

//BaseServlet继承了HttpServlet类,重写了doGet方法
public class MyServlet extends BaseServlet{ public void page1(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
User user = new User();
user.setId(11);
user.setName("zs");
user.setAge(18);
user.setSex(1); List<City> list = new ArrayList<City>();
list.add(new City(1,"北京"));
list.add(new City(2, "上海"));
list.add(new City(3, "广州")); req.setAttribute("list", list);
String string = "aaa123";
req.setAttribute("tar", string);
req.getRequestDispatcher("page/demo.jsp").forward(req, res);
}
}
<!-- jsp文件body中,最前勿忘加两标签 -->
<!-- 声明变量标签 -->
<c:set var="money" value="200" scope="request" /> <!-- 取值方式被称为EL表达式,可以访问JavaBeans和jsp内置对象 -->
金额:${money} <!-- 选中分支标签 -->
<c:if test="${sex eq 1}">
<input type="radio" value="1" checked>男
<input type="radio" value="0">女
</c:if>
<c:if test="${sex eq 0}">
<input type="radio" value="1">男
<input type="radio" value="0" checked>女
</c:if> <!-- 类似于Java中的switch --> <c:choose>
<c:when test="${sex eq 1}">

</c:when>
<c:otherwise>

</c:otherwise>
</c:choose> <hr> <!--
遍历结果集
var 表示每次遍历结果集取出来的元素
varStatus这个属性用来指定接收“循环状态”的变量名
current当前这次迭代的(集合中)项
index当前这次迭代从0开始的迭代索引
count当前这次迭代从1开始的迭代索引
first用来表明当前这轮迭代是否为第一次迭代的标志
last用来表明当前这轮迭代是否为最后一次迭代的标志
-->
<c:forEach items="${list}" var="no" varStatus="vs">
${vs,first},${no}<br>
</c:forEach> <c:set var="now" value="<%=new java.util.Date()%>" />
<!-- 获取时间 -->
${now}
<!-- 格式化时间日期标签 -->
<f:formatDate value="${now}" pattern="yyyy-MM-dd HH:ss:SSS" /> 用户id:<input type="text" value="${user.id}">
用户姓名:<input type="text" value="${user.name}">
用户年龄:<input type="text" value="${user.age}">
用户性别:
<c:if test="${user.sex eq 1}">男</c:if>
<c:if test="${user.sex eq 0}">女</c:if> <!-- 遍历集合 -->
<select>
<option value="">请选择城市</option>
<c:forEach items="${list}" var="city">
<option value="${city.id}">"${city.name}"</option>
</c:forEach> </select> <!-- 使用EL表达式获取参数值 -->
<c:out value="${tar}"></c:out>

HTTP请求方式与URI

HTTP请求方法

GET方法

GET与POST请求方式的区别:

1 GET请求业务参数以键值对的形式拼接在URL后面;POST请求业务参数存放在HTTP头信息中;

2 GET请求URL长度是受限制的,URL的最大长度是1024个字符,即2KB;POST请求理论上数据长度无限制,但是数据受web服务器限制;

3 GET请求安全性较差,因为参数是URL的一部分,对用户可见;POST请求相对更安全,因为参数不会被保存在浏览器历史或 web服务器日志中

4 GET请求只允许 ASCII 字符;POST请求没有限制。也允许二进制数据,所以提交多媒体文件用POST方式提交。

1.7.2 HTTP状态码列表

状态码		状态码英文名称		中文描述
200 OK 请求成功。一般用于GET与POST请求
400 Bad Request 客户端请求的语法错误,服务器无法理解
404 Not Found 服务器无法根据客户端的请求找到资源(网页)。通过此代码,网站设计人员可设置"您所请求的资源无法找到"的个性页面
405 Method Not Allowed 客户端请求中的方法(GET/POST)被禁止
500 Internal Server Error 服务器内部错误,无法完成请求
502 Bad Gateway 作为网关或者代理工作的服务器尝试执行请求时,从远程服务器接收到了一个无效的响应

URL与URI

2.1 URI

2.1.1 URI定义

URI,统一资源标志符(Uniform Resource Identifier),表示的是web上每一种可用的资源,如 HTML文档、图像、视频片段、程序等都由一个URI进行唯一标识的。

2.1.3 示例

如:https://blog.csdn.net/qq_32595453/article/details/79516787

可以这样解释它:

1)这是一个可以通过https协议访问的资源;

2)位于域名为blog.csdn.net的主机服务器上;

3)通过“/qq_32595453/article/details/79516787”可以对该资源进行唯一标识(注意,这个不一定是完整的路径)

注意:以上三点只不过是对实例的解释,以上三点并不是URI的必要条件,URI只是一种概念,怎样实现无所谓,只要它唯一标识一个资源就可以了。

2.1.2 URI的结构组成

1)资源的命名机制;

2)存放资源的主机名;

3)资源自身的名称。

(注意:这只是一般URI资源的命名方式,只要是可以唯一标识资源的都被称为URI,上面三条合在一起是URI的充分不必要条件)

2.2 URL(Uniform Resource Locator)

URL是URI的一个子集。

URL的一般格式为(带方括号[]的为可选项):

protocol://hostname[:port]/path/[;parameters][?query]#fragment

protocol:网络传输协议:TCP/UDP

hostname:域名或IP地址

port:端口号

path:资源路径

parameters:参数

query:请求参数

URL的格式由三部分组成:

1)协议(或称为服务方式)。

2)存有该资源的主机IP地址(有时也包括端口号)。

3)主机资源的具体地址,如目录和文件名等。

第一部分和第二部分用“/”符号隔开,

第二部分和第三部分用“/”符号隔开。

第一部分和第二部分是不可缺少的,第三部分有时可以省略。

2.3 URI和URL之间的区别

从上面的例子来看,你可能觉得URI和URL可能是相同的概念,其实并不是,URI和URL都定义了资源是什么,但URL还定义了该如何访问资源。URL是一种具体的URI,它是URI的一个子集,它不仅唯一标识资源,而且还提供了定位该资源的信息。URI 是一种语义上的抽象概念,可以是绝对的,也可以是相对的,而URL则必须提供足够的信息来定位,是绝对的。

day34 JSTL标签的更多相关文章

  1. JSTL标签 参考手册

    前言 ========================================================================= JSTL标签库,是日常开发经常使用的,也是众多 ...

  2. JSTL标签库

    JSP页面作为内嵌java的Html简化了Servlet在控制页面显示的语法,但JSP脚本中的表达式功能不够强大,语法也稍显繁杂,EL(Expression Language)表达式语言的出现能够大大 ...

  3. 重温JSP学习笔记--JSTL标签库

    以前写jsp的时候对jstl标签库是有些抵触的,因为我觉得嵌入java代码的方式几乎无往不利,没有必要使用标签库,不过这次复习还是好好地学习了一下,发现这个还是很有用处的,用得好能省不少事,JSTL是 ...

  4. 简单实用JSTL标签库

    1. JSTL标签库是一个什么东东? 简单来说,有了它你就可以在类似HTML的JSP页面里面运用一些高级语法,实现迭代.条件判断.XML文档操作.国际化标签.SQL标签. 2. 如何使用 ? 参考网址 ...

  5. JSTL标签库之核心标签

    一.JSTL标签库介绍 JSTL标签库的使用是为弥补html标签的不足,规范自定义标签的使用而诞生的.使用JSLT标签的目的就是不希望在jsp页面中出现java逻辑代码 二.JSTL标签库的分类 核心 ...

  6. jstl 标签库的使用

    JSTL 核心标签库 使用   JSTL 核心标签库标签共有13个,功能上分为4类: 1.表达式控制标签:out.set.remove.catch 2.流程控制标签:if.choose.when.ot ...

  7. jstl标签

    为什么提出jstl标签? Jsp中包含html标签+java片段+jsp片段使得jsp页面比较乱.提出:能不能把<% %>java片段用标签替换 jsp页面更简洁 <!-- 引入js ...

  8. 自定义jstl标签库

    开发环境:Spring+SpringMVC +Maven +Mybatis JSTL 标签库的配置: 导入对应的 jstl.jar 和 standard.jar ,我使用的配置如下: <prop ...

  9. JSP的JSTL标签使用

    JSTL标签和asp.net中的webform控件很像,但是功能确比asp.net的强很多. 配置过程,从最简单的项目开始: 1.下载JSTL标签库:http://archive.apache.org ...

  10. JavaWeb学习之JSP常用标签、EL表达式的运算符、JSTL标签库(6)

    1.JSP常用标签 * 只要支持JSP文件,常用标签有可以直接使用 * 格式: jsp:xxxx * jsp:forward ,完成jsp页面的转发 * page属性:转发的地址 <% requ ...

随机推荐

  1. 如何使用Arthas定位问题

    在我们日常的工作中,经常会遇到一些线上才会遇到的问题.Arthas无疑是我们在工作中,定位线上问题的神奇.下面,我将介绍一下我们在工作中经常用到的一些功能. dashboard 首先我们可以通过das ...

  2. 安装vm,在vm中安装windows10操作系统。

    步骤:双击打开虚拟机文件 根据向导安装  下一步 然后等待安装 安装好了后点击许可证 ZF3R0-FHED2-M80TY-8QYGC-NPKYF YF390-0HF8P-M81RQ-2DXQE-M2U ...

  3. 记录一下对jdk8后的接口的一些理解

    对于jdk8后的接口,接口中加入了可以定义默认方法和静态方法. 为什么要这样设计呢? 是为了在给接口扩展方法的时候,不会影响已经实现了该接口的类 加入默认方法可以解决:在添加方法的同时,不影响现有的实 ...

  4. CentOS7 系统服务器初始化配置、安全加固、内核升级优化常用软件安装的Shell脚本分享

    转载自:https://www.bilibili.com/read/cv13875630?spm_id_from=333.999.0.0 描述: 适用于企业内部 CentOS7 系列操作服务器初始化. ...

  5. Minio纠删码快速入门

    官方文档地址:http://docs.minio.org.cn/docs/master/minio-erasure-code-quickstart-guide Minio使用纠删码erasure co ...

  6. Elasticsearch 堆内存

    转载自:https://www.lbbniu.com/6148.html 1.什么是堆内存? Java 中的堆是 JVM 所管理的最大的一块内存空间,主要用于存放各种类的实例对象. 在 Java 中, ...

  7. es分片数相关知识

    分片数量 总分片数=主分片数 *(副分片数+1) 如下创建索引配置表示,总分片数=1 *(1+4),表示总共5个分片. "settings": { "number_of_ ...

  8. TCP服务端收到syn但是不回复syn ack问题分析

    文章转载自:https://blog.csdn.net/jueshengtianya/article/details/52130667 最近在分析客户的一个问题时遇到了一种奇怪的情况,客户在服务端开启 ...

  9. 前端图形:SVG与Canvas

    00.前端图形 前端代码实现图形的几种方式:CSS.SVG.Canvas(主要是JavaScript编码) CSS也是可以画图的,需要借助于高宽.边框border.clip-path裁剪.渐变色背景等 ...

  10. HTML+CSS基础知识(6)背景的设置、表格的设计、表单的设计和框架集

    文章目录 1.背景 1.1 代码 1.2 测试结果 2.背景练习 2.1 代码 2.2 测试结果 3.表格 3.1 代码 3.2 测试结果 4.练习 4.1 代码 4.2 测试结果 5.表单 5.1 ...