JSP知识

JSP概念
Servlet是j2ee提供的动态资源开发技术,
是以java的程序的形式进行开发,
在java中书写HTML标签是一件十分头疼的事情,
所以人们开发出了JSP,看起来像是HTML一样,
但是通过服务器的编译最终可以生成Servlet
动态网页技术


页面不需要改变->改变数据库数据


jsp = html + java




1、jsp页面中可以写哪些内容
        1.html标签
2.css
3.jstl标签库
4.java代码
5.EL表达式
6.javascript


页面会非常乱.java+html+css+js
不容易修改


.jsp -->  .java --> .class
    翻译


2、jsp是如何工作的以及jsp的特点.
1.jsp页面其实就是一个servlet。
2.jsp页面的运行需要服务器的支持。
3.服务器中的jsp引擎可以帮我们去运行jsp页面。(注意并不是所有服务器都有这样的引擎的.引擎其实就是别人写的支持jsp页面运行的jar包或者代码)
4.jsp页面在运行之前,要经过几个步骤:首先jsp页面要被翻译成.java文件,然后再编译成.class文件,最后再运行这个.class文件.(创建这个类的对象,调用指定方法_jspService,方法中把页面里面要显示的内容用io流一行行的写给浏览器)
5.jsp翻译成的.java文件中,其实就是写了一个servlet,在这个类中的方法里面,用io流,把jsp页面中的内容一行一行的输出给了浏览器。因为这是在java类中的方法里面做的事情,所有很多数据我们都可以用变量来表示,同时也可以调用其他类中的方法.(在这里,jsp动态页面的效果也就体现出来.)
6.运行jsp页面过程中,jsp引擎帮我们去翻译或者编译成的.java文件和.class文件都保存在了tomcat中的work目录里面。
7.通过上述jsp的特点可知,写完一个项目之后,第一次部署运行的时候,整个项目的运行jsp速度会慢一些,因为第一次访问运行jsp的时候,需要先翻译成.java文件然后再编译成.class文件,最后再运行,这个过程会耗费一些时间,但是第二访问运行的时候就会比较快了.


8.访问项目中的一个jsp页面的时候,服务器首先会检查你所访问的这个jsp页面是否存在,如果不存在,服务器直接给你返回404,如果存在,服务器会进一步检查有没有和这个jsp页面对应的.class文件,如果有的话就直接运行这个.class,如果没有的话,则先把这个jsp页面翻译成.java,然后再编译成.class,最后再运行这个.class文件.


9.jsp页面其实就是在html页面中直接写上java代码.但是,在一个jsp页面中,可以没有任何html的代码而只有java代码,也可以没有任何java代码只有html的代码.


10.servlet能做的事情jsp全能做。




3、jsp中的元素:三大元素
1,脚本元素  
<%!  声明  %> 
<%= 表达式 %> 
<% 脚本 %>
脚本元素 对应在 java文件为什么位置
2,指令元素  <%@ 指令 %>
3,动作元素  :为了避免在jsp中写过多的脚本元素
 1) 脚本元素
a) 声明(Declaration):相当于在类中方法外的代码
   语法: <%!  %> jsp页面任何地方
   作用: 在servlet中声明一些成员变量、成员方法和内部类
   特点: 声明被翻译进servlet后变成了成员变量、成员方法和内部类
   注意: 不能使用表达式和隐含对象-->jsp--9


b) 表达式(Expression):相当于在_jspServlet()方法中的 out.println(表达式);代码
   语法: <%= expression %>
   作用: 将expression输出到out(输出流)中,expression可以是算术、逻辑、关系表达式、变量、有返回值的方法、jsp中的9种隐含对象。
   9种隐含对象:
     page pageContext request response session application out config exception


   特点: 表达式翻译进servlet后变成了out.print(expression),该代码处于
   _jspService()方法中;


   注意: expression都一律被转换成字符串后再写到输出流out(JspWriter)中。另外,expression中不能有分号(;)。


c) 脚本(Scriptlet):相当于_jspService(...){脚本}中代码
    语法: <% java code %>
    作用: 在jsp中嵌入该jsp转化成的_jsp.jsp代码,不能嵌入成员变量、成员方法。
    特点: 脚本被翻译进servlet的_jspService()方法中。


 2) 指令元素
a) page指令
   语法: <%@ page attributeName="attribuerValue"...%>
   作用: 利用page指令中的属性可以和容器进行通信,这些属性的设置对整个jsp都有影响。


page指令中的属性:
 language="java"
表示当前页面中的编程语言是java,目前这个属性值只能写java
 import="package.class,package2.class2"
在当前页面中要引入哪些包下的类.和一般的java import意义一样,用","来隔开,
import="java.util.*"
import="java.util.HashMap,java.sql.Connection"


 session="true|false"  默认为true
用来指定当前页面是否支持使用session,如果设置为true,则翻译过来的servlet中将会有对session对象的引用,于是可以直接在jsp中使用session隐式对象。但是这将导致一旦访问jsp就会调用request.getSession()方法,可能导致不必要的空间浪费。如果确定jsp中不需要session可以设为false
 buffer="none|8kb|sizekb" 默认为8kb
out隐式对象所使用的缓冲区的大小
 autoFlush="true|false"  默认为true
out隐式对象是否自动刷新缓冲区,默认为true,不需要更改
 isThreadSafe="true|false"  默认为true
翻译过来的servlet是否实现SingleThreadModel
 info="text"
关于jsp页面的信息,定义一个字符串,可以使用getServletInfo()获得
 errorPage="b.jsp"   默认忽略
如果页面出错,将要跳转到的页面,除了在jsp中使用此属性指定错误页面外也可以在web.xml中配置整个web应用的错误页面,如果两个都设置则jsp中的此属性起作用


 isErrorPage="true|false"   默认为false
表明当前的页面是否为其它页面的errorPage目标,如果设置为true,则可以使用exception对象。反之,如果设置为false,则不可以使用exception对象
 extends="package.class"
设置jsp页面被翻译成java文件的时候,java文件中的类要继承那个父类.这个属性不用设置,jsp引擎会给它一个默认的父类去继承的.
 isELIgnored="true|false"
指定EL表达式语言是否被忽略,如为true则忽略,反之可以使用EL。


 contentType="text/html;charset=UTF-8"
定义response中的内容类型和jsp页面的编码格式,
翻译后变成response.setContentType("text/html;charset=UTF-8")。
 pageEncoding="UTF-8"
设置jsp页面文件保存时候所用的编码,实现功能跟contentType="text/html;charset="UTF-8"一致,但是两者若同时设置,jsp页面的编码格式以pageEncoding为准,response中的内容类型和编码格式以contentType为准。

b) include指令 : 静态导入
    语法: <%@ include file="url"%>,称为静态导入(静态包含)
    作用: 在一个页面中导入另一个页面的内容(这些内容一般不会有变化,如公司的标题和版权等信息)。


    特点: 在jsp翻译成servlet后就将被导入的页面内容嵌入到servlet中。
          导入时间发生在翻译阶段。
    被导入的资源: html、xml、jsp等
    优点: 执行效率高
    缺点: 当被导入页面的内容发生变化,那么jsp必须要重新被翻译。


c) taglib指令是定义一个标签库以及其自定义标签的前缀.
<%@ taglib uri="" prefix=""%>
指定在jsp中要使用的标签库描述文件(*.tld)的路径
prefix="给标签库取的别名"
uri="标签库的路径"


3) 动作元素(jsp自带的标准标签)

减少在jsp页面编写java代码


jsp基本动作元素:
jsp:attribute 设置动态定义的XML元素属性。


jsp:body 设置动态定义的XML元素内容。


jsp:element 定义动态XML元素


jsp:fallback 回滚,下载失败则显示里面的内容,此标记只能在内部使用


* jsp:forward 把请求转到一个新的页面。该操作允许将请求转发到另一个JSP,Servlet或者静态资源文件。一旦遇上此标记即会停止执行当前的JSP,转而执行被转发的资源。



jsp:getProperty 输出某个JavaBean的属性。此操作是对操作的补充,它用来访问一个Bean的属性。它访问的属性值将它转化成一个String,然后发送到输出流中。如果属性是一个对象,将调用toString()方法,



* jsp:include 在页面被请求的时候引入一个文件。该操作允许在请求的时间内在现成的JSP页面里面包含静态或动态的资源。被访问的对象对JSP write对象的访问权,并且它不能设置头或者Cookie.如果页面输出是缓冲的,那么缓冲区的刷新要俦于包含的刷新。因此它在运行效率上比<%@   include  file="include.html"%>要低,但它可以动态增加内容,使用



* jsp:param 操作被用来以“名-值”对的形式为其他标签提供附加信息。写一般与,,一起使用。



jsp:params 表示需要向Applet或Bean传送的参数或值


jsp:plugin 根据浏览器类型为Java插件生成OBJECT或EMBED标记。此操作是用来产生客户端浏览器的特别标签(Object或者embed),可以使用它来插入Applet或者JavaBean。一般来说元素指定的对象是Applet还是Bean,同样也会指定class的名字,另外还会指定将从哪里下载这个Java插件。

   
   
   

   
   

Unable  to  load  applet.


   


解释:
1:type="bean/applet"
2:code="classFileName"  插件执行JAVA类文件的名称。在名称中必须加上扩展名,且此文件必须放在用 codebase属性的目录下。
3:codebase="classFileDirectoryName"这包含插件将运行的JAVA类的目录或指向这个目录的路径。默认为JSP文件的当前路径。
4:name="instanceName" 这是Bean或Applet的实例的名称。使得被同一个JSP文件调用的Bean或Applet之间的通讯成为可能。
5:archive="URIToArchive,……"这是以逗号分隔的路径名列表,是那些用于codebase指定的目录下的类装载器预装载的存档文件所在的路径名。
6:align="botton/top/middle/left/right"图形,对象,Applet的排列方式。
7:height="displayPixels"  width="displayPixels"  显示的高宽
8:hspace="leftRightPixels"  vspace="topBottomPixels"  左右  上下留下空间大小
9:jreversion="JREVersionNumber | 1.1" 这是Applet或Bean运行时所需的JRE版本
10:nspluginurl="URLToPlugin" 这是Netscape Navigator用户能够使用的JRE下载地址
11:iepluginurl="URLToPlugin" 这是Internet Explorer用户能够使用的JRE下载地址


jsp:setProperty 设置JavaBean的属性。此操作与useBean协作,用来设置Bean的简单属性和索引属性。标签使用Bean的setXXX()方法。利用它设置属性多种方法。Bean的自省(introspection)用来发现出现的是哪些属性和它们的名字是什么,这些属性是简单的还是索引的,它们有什么类型等,用以下方法使用





jsp:useBean 寻找或者实例化一个JavaBean。此标签用于在JSP页面中创建一个Bean实例,并指定它的名字及作用范围。它保证对象在标签指定的范围内可以使用。
创建:


寻找:



scope的取值可以是page/request/session/application 范围依次递增!
相当于代码:
  <%
com.briup.Carts shopcar = null;
shopcar = (Carts)pageContext.getAttribute("shopcar");
if(shopcar==null){
shopcar = new Carts();
pageContext.setAttribute("shopcar",shopcar);
}
  %>




语法:


a) 动态导入(动态包含)
  语法: 或者
 
{}*
 



 特点: 动态导入发生在执行阶段,也就是在运行serlvet的时候才动态生成被导入页面的内容,然后嵌入到调用页面,最后将两个页面的内容一起返回给客户端。
 注意: 在翻译(.jsp->.java)阶段并没有生成被导入页面的内容。


 缺点: 执行效率没有静态导入高
 优点: 如果被导入页面的内容发生变化,调用页面不必重新翻译。


       b) forward(服务器内部跳转)
 语法: 或者

            {}*



4、jsp中的注释
    a) HTML/XML注释
语法:
注意: 它只能注释html、xml中的静态内容。不能注释脚本元素、指令元素和动作元素。如果注释,它们还是会被编译执行。


    b) 隐藏注释
语法: <%-- content --%>
注意: 它可以注释jsp中所有的内容。


    c) 脚本注释
语法: < %
//java code


/**
 java code
*/


/*
  java code
*/
     %>


三种注释的区别:
  servlet源文件 客户端页面源文件 浏览器显示


HTML/XML注释        出现   出现  不显示


隐藏注释     不出现  不出现  不显示


脚本注释    出现  不出现  不显示




静态导入: <%@ include %>
特点:-->a_jsp.java会包含两个页面中所有的数据
翻译阶段发生
动态导入:
特点:a.jsp-->b.jsp-->a_jsp.java不会包含b.jsp的内容
留下一个b.jsp的引用
在代码运行的时候(运行的时候导入)




 5) JSP九大隐含对象也叫九大内置对象

JSP容器生成的Servlet类的_jspService()方法中,定义的几个对象我们可以在编写



     JSP页面时使用的隐含对象。
page:当前的jsp页面,指针this
pageContext:当前的jsp页面的上下文:容器
request:封装请求的信息
response:封装响应
session:会话
application:指web应用
out:输出流
config :配置信息
exception:异常信息


在哪里声明?
_jspService()
jsp 三大元素 
    四大容器: pageCentext : 当前页面
     req
     session
     application
   九大内置对象:
page---> this
pageContext  --> 当前页面容器
request  
response
session
application
out
config
     
脚本元素
<%    %>


<%= 表达式  %> 

<%! 声明 %>
指令元素
动作元素











    pageContext 对象提供了访问其他隐含对象的方法
getRequest()
getResponse()
getSession()
getServletContext()
JspWriter getOut()
getServletConfig()
Object getPage()
Exception getException()


pageContext还可以用来保存属性,但是只能在当前页面中获取
 setAttribute(String name,Object val);
 Object getAttribute(String name);

pageContext还可以设置和得到其他范围对象中保存的属性
 setAttribute(String name,Object val,int scope);
 Object getAttribute(String name,int scope);
 removeAttribute(String name,int scope)删除指定范围内名字为name的属性
 removeAttribute(String name) 删除所有范围内名字为name的属性
 findAttribute(String name) 该方法会按照page,request,session,application
范围顺序搜索指定名字的属性。


PageContext.PAGE_SCOPE 页面范围
PageContext.REQUEST_SCOPE 请求范围
PageContext.SESSION_SCOPE 会话范围
PageContext.APPLICATION_SCOPE 应用程序范围
    exception
对象表示了JSP页面运行时产生的异常,该对象只有在错误页面(page指令中指定
isErrorPage=true的页面)中才可以使用。当JSP页面运行发生错误时,JSP容器会
自动调用指定的错误处理页面,如果JSP页面使用errorPage属性定义了错误页面,
那么在web.xml文件中定义的任何错误页面将不会被使用


  6) 对象和范围
在JSP中,有4中范围
page范围:--->pageContext
 具有page范围的对象被绑定到javax.servlet.jsp.PageContext对象中,在这个
 范围中的对象,只能在创建对象的页面中访问。page范围内的对象,在客户端
 每次请求JSP页面时创建,在页面向客户端发送回响应或请求被转发到其他资源
 后被删除。
request范围
 具有request范围的对象被绑定到javax.servlet.http.HttpServletRequest对象
 中。在调用forward()方法转向的页面或调用include()方法包含的页面中,都可
 以访问这个范围内的对象。
session范围


 具有session返回的对象被绑定到javax.servlet.http.HttpSession对象中,JSP
 容器为每次会话,创建一个HttpSession对象,在会话期间,可以访问session
 范围内的数据
application范围
 具有application范围的对象被绑定到javax.servlet.ServletContext中,在web
 应用程序运行期间,所有页面都可以访问这个范围内的对象。




JSTL


什么JSTL
第三方标签库,是一个JSP标签集合,需要导入jar包才可以使用。
该标签库可以完成更复杂的功能,比如可以完成遍历集合,条件判断,循环等功能。
根据标签功能,JSTL标签库可分5类:
核心标签库 <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
I18N格式化标签库<%@taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
SQL标签库 <%@taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>
XML标签库 <%@taglib prefix="xml" uri="http://java.sun.com/jsp/jstl/xml" %>
函数标签库 <%@taglib prefix="functions" uri="http://java.sun.com/jsp/jstl/functions" %>


使用原因:
不希望在jsp页面中出现java逻辑代码。
相关jar包
老版本:
standard.jar 标准jar包,定义规范
jstl.jar   具体实现jar包
新版本:
jstl-1.2.jar
注意:
1)web工程导包需要将包copy到WEB-INF下lib文件夹中。
    2)在jsp页面中导入标签库。
如核心标签库的引入:
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
核心标签库,可分为四大类


第一类:表达式控制标签
:用于在JSP中显示数据,就像<%= ... >
: 用于将数据放到容器中(4大容器)
: 用于删除容器中数据
: 用来处理产生错误的异常状况,并且将错误信息储存起来
第二类:流程控制标签
:与我们在一般程序中用的if一样
: 本身只当做的父标签
的子标签,相当于 else if() 用来判断条件是否成立
的子标签,相当于 else{} 接在标签后,当标签判断为false时被执行
上面三个标签一起使用相当于 java中:if(){} else if(){}else if(){}else{}


第三类:循环标签
:基础迭代标签,接受多种集合类型
:根据指定的分隔符来分隔内容并迭代输-->split("/")
第四类:URL操作标签

: 检索一个绝对或相对 URL,然后将其内容暴露给页面:导入到页面中

 任意的uri
当前项目下的url




: 用来给包含或重定向的页面传递参数
获取的话:从请求中获取
req.getParameter("")


: 重定向 至一个新的URL.




: 使用可选的查询参数来创造一个URL


核心标签详解


1、 输出变量到JspWriter输出流中
语法1:
语法2:
default value

注意: a)如果result为null,则输出default中的值
a.1)属性default="值" 和标签的文本域默认值 不能同时出现
b)escapeXml:设定是否转换特殊字符(如<、>等一些转义字符)
默认值为true的情况下直接在输出<的,
如果改为false将会进行转义输出“<”等。
例如:
     


2、 该标签用于在某个范围中设置指定变量,或者设置某个对象的属性
1)设置范围变量
语法1:
注: var指定的值-->属性名、变量名
value指定的值-->属性值、变量值
value可以通过el标签来取到数据,如:value="${user }"
语法2:
body content

注:var指定的值-->属性名、变量名
   body content指定的值-->属性值、变量值
   scope指定变量存放的范围,默认为page
等价于:scope.setAttribute("name","attrValue");
2)设置某个特定对象的一个属性
语法1:
注:target:目标对象
propertyName:目标对象属性名
propertyValue:属性值
语法2:
body content

注:target:目标对象
   propertyName:目标对象属性名
   body content:属性值
例子:

注:把一个值为terry赋值给指定的student对象的name属性,
等价于调用student对象的setter方法。
注意: 1)scope属性不能在这里使用。
eg:


3、 在指定scope中根据属性名varName来删除属性值
语法:
等价于 scope.removeAttribute("varName");
注意:如果没有指定scope,那么依次从page、request、session和application范围中
根据该属性名去删除属性值。
eg:
4、 捕获由嵌套在它里面的代码抛出的异常
    语法:
nested actions

注:var:用于存放这个异常对象的属性名,
通过它可以输出异常对象的所有信息。
scope:默认为page。
eg:

<%
int  x=10/0;
%>




5、 判断
语法:  
body content

注: var为存放布尔型变量的属性名
scope为该变量的存放范围。
condition通常为el表达式
eg:

条件为真



6、 用于条件选择,它和以及一起使用
语法:  
( and )

注意: body体内容只能由以下的元素构成
1) 空格
2) 0个或者多个子标签,
必须出现在之间
3) 0个或者多个


7、 代表了的一个分支
语法:
body content

注意: 必须以作为它的父标签
 必须在之前出现


8、 代表了的最后的选择
语法:
body

注意: 必须以作为父标签
 必须是的最后分支




9、 用来迭代集合、数组、枚举或者迭代器(Iterator))
语法1: items="collection/array/Enumaration/Iterator"
[varStatus="varStatusName"]
[begin="begin"] [end="end"]
[step="step"]>
body



语法2: 迭代固定的次数(做普通的循环输出,类似for循环)
[varStatus="varStatusName"]
begin="begin" end="end"
[step="step"]>
body content



名字 类型 描述
var String 存放变量(迭代出来的)的属性名(scope为page)
items    任何支持的类型 将要迭代itmes的集合/数组/枚举/Iterator
varStatus String 迭代的状态,可以访问迭代的自身信息,如索引号
begin int items从index[begin]开始迭代
没有指定items从index开始做循环
end int items从index[end]结束
没有指定items从end结束
step int 迭代的步长(>0)


注意:varStatus中有index(索引),count(循环次数)
 ,first(是否是第一个位置),last(是否为最后一个位置)


eg:遍历List

${str}-----${index.count }


解析:
items="${}"需要遍历的集合
var="str"给遍历到的每个对象取个名字方便使用
varStatus="index"给角标对象取名字-->${index.count}-->注意:从1开始
step="2"步长为2  0__ 1__ 2__ 现在在0位置 然后步长为2 所以到了2号位
begin="1"从集合的几号位置开始读取数据
end="2"取到2号位置


eg:遍历map

${m.key }----${m.value}---${index.count }





10、 类似java中的StringTokenizer
这个标签专门用于处理TokenString的迭代,
可以指定一个或者多个分隔符号(delimiters)
语法: delims="delimiters"
[var="varName"]
[varStatus="varStatusName"]
[begin="begin"] [end="end"]
[step="step"]>
body content
 

eg:
delims="|" var="a" begin="" end="" step="" varStatus="">
${a }



item:需要被打断的字符串
delims:通过什么打断
var:打断以后的每个字符取个名字方便使用


11、 导入一个基于URL的资源,可以把其他静态或动态文件包含到本JSP页面
语法:
[]*
 

var:存放URL资源内容的属性名
scope:存放的范围


区别:
:只能包含同一个web应用中的文件。
可以包含其他web应用中的文件,甚至是网络上的资源。
eg:




12、 中添加请求的参数
语法1:
语法2:
parameter value

eg:

jjj

解释:
先使用c:import 跳转到一个servlet然后使用s:param给请求附加数据域加在reqeust的请求体中




13、 用于构造URL,主要用途是URL重写
语法:
[]*
 

注意:1)var:存放重写后的URL的属性名
 2)scope:存放的范围
 3)若为相对路径,url会被重写
 4)若使用绝对路径则url不会重写
 5)一般和a连用,如test
eg:">TEST
14、 把客户的请求重定向到另一个资源
语法:
[]*
 

注意:1)若为相对路径,url会被重写
 2)若使用绝对路径则url不会重写








EL最初是定义在JSTL1.0规范中,在JSP2.0中,EL从JSTL中剥离出来,放到JSP规范中
成为了JSP2.0规范的一部分,并添加了新的特性。在JSP页面中,使用EL可以简化对
变量和对象的访问。
JSP中的表达式语言,使得访问存储在JavaBean中的数据变得非常简单。
它既可以用来创建算术表达式也可以用来创建逻辑表达式。
el表达式内可以使用整型数,浮点数,字符串,常量true、false,还有null。
目的:
通过EL标签取数据和输出信息,
简化代码,不需要使用java来输出。
使用Java代码也可以取数据,但是这样不利于维护JSP。


 
 ${map.key}
 ${map.value}
EL详解


 


形式:${ }




* 作用:从一个范围里面取值或者从一个
${name}
容器 
key   value
name obj
对象中取值或是向页面输出值.
1.接收客户端参数.
  ${param.name1 }
2.指定范围并取值
  ${pageScope.name2 }
    ${requestScope.name3 }
    ${sessionScope.name4 }
    ${applicationScope.name5 }
        3.可以不指定范围再去取值
  ${name}
  这时候会按照pageContext request session application这样一个顺序依次的去找有没有一个叫name的值存在,一旦找到了就输出出来,最终没有找到那么就什么都不输出。




${对象.属性}


4.取出一个对象中的属性值.
  ${requestScope.student.id}
  ${requestScope.student.name}
  ${requestScope.student.age}
  或者
  ${student.id}
  ${student.name}
  ${student.age}
  或者
  ${student["id"]}
  ${student["name"]}
  ${student["age"]}


  注意:比如 ${student.id}表示是要调用student对象中的getId方法,至于对象中有没有id属性对这个操作没有任何影响.


  如果Student类中一个方法是getAddress,返回一个Address类的对象,Address类中有一个方法getCity,这个时候我们就可以这样写去拿到city属性的值.
  ${student.address.city}




5.输出字符串
   ${"hello"}


6.输出运算结果或者boolean表达式
a)算术运算符
+、-、*、/和 %(或 mod)
b)关系运算符
==(或 eq)、!=(或 ne)、<(或 lt)、
>(或 gt)、<=(或 le)和 >=(或 ge)
c)逻辑运算符
&&(或 and)、||(或 or)和 !(或 not)

d)判空运算符 ${empty ""}-->变量name是否为空:${empty name}-->为空就是true
empty
 <% String name="";%>
如果为空 --> true
不为空   --> false


${empty ""}
${empty name}








   ${1+1 }
   ${(1+2)*3-4+5*3 }
   ${1<3 }
   //为空的话返回true
   ${empty "" }
   ${empty "hello" }
   //取否 不为空的话返回true
   ${not empty "hello" }
   ${! empty "hello" }
   ${param.score >50 }
   ${param.score >60?"good":"bad" }


7.输出数组、集合中的元素


${str[0] }

${list[1] }

${map["c"] }



<%
String[] str = {"hello","world"};


List list = new ArrayList();
list.add("zhangsan");
list.add("lisi");


Map map = new HashMap();
map.put("a",100);
map.put("b",200);
map.put("c",300);


request.setAttribute("str",str);
request.setAttribute("list",list);
request.setAttribute("map",map);


%>


${str[0] }

${list[1] }

${map["c"] }











8.表达式语言(EL)中定义了一些可以使用的隐含对象:
1) pageContext: jsp页面的上下文,它提供了访问以下对象的方法
a) servletContext
${pageContext.servletContext}
等于
out.println(pageContext.getServletContext())
b) session
${pageContext.session.id}
等于
out.println(pageContext.getSession().getId())
c) request
${pageContext.request}
等于
out.println(pageContext.getRequest())
d) response
${pageContext.response}
等于
out.println(pageContext.getResponse())


------>看看
2) parma: 把请求中的参数和单个值进行映射
${param.name}或者${param["name"]}或者${param['name']}
等于
out.println(request.getParameter("name"))
 注意:${param.name}如果获取不到值返回""。
       request.getParameter("name")如果获取不到值返回null。


3) paramValues: 把请求中的参数和一个array值进行映射
${paramValues.hobby}或者${paramValues["hobby"]}或者${paramValues['hobby']}
  等于
String[] array = request.getParameterValues("hobby")
        out.println(array);


4) header: 把请求头中header的字段和单个值映射
${header.referer}
等于
out.println(request.getHeader("referer"));
//获得http request请求头中所有字段名字
Enumeration e =
request.getHeaderNames();




5) headerValues: 把请求头中header的字段和一个枚举进行映射
${headerValues.referer}
等于
Enumeration enum =
request.getHeaders("referer")
out.println(enum);


6) cookie: 把请求中的Cookie和单个值进行映射
Cookie cookie = new Cookie("height","100");
Cookie cookie2 = new Cookie("width","200");
response.addCookie(cookie);
response.addCookie(cookie2);


                在服务器端获得从客户端发送过来的cookie:
${cookie.height}: 输出一个Cookie的对象
${cookie.height.name}=${cookie.height.value}
分别输出Cookie的名称和值(height=100)
    ${cookie.width}: 同上
${cookie.width.name}=${cookie.width.value}: 同上


7) initParam: 把Web应用上下文的初始化参数和单个值进行映射

name
value



${initParam.name}
等于
String value = getServletContext()
.getInitParameter("name");
out.println(value);


8) pageScope: 把page范围中的key和value进行映射
pageContext.setAttribute
("name","jack");


${pageScope.name}
等于
out.println
(pageContext.getAttribute("name"));


9) requestScope: 把request范围中的key和value进行映射
request.setAttribute("name","jack");
${requestScope.name}
等于
out.println(request.getAttribute("name"));


10) sessionScope: 把session范围中的key和value进行映射
session.setAttribute("name","jack");
${sessionScope.name}
等于
out.println(session.getAttribute("name"));


11) applicationScope: 把application范围中的key和value进行映射
getServletContext().setAttribute("name","jack");
${applicationScope.name}
等于
out.println(getServletContext().getAttribute("name"));


  注意: 如果没有指明任何的范围根据key来查找对应的value,默认从page、request、session和application从小到大的范围开始查找,若找到就不往更大的范围去查找。
例如: ${name} ,分别从page request session
和 application中去查找name的值
(scope.getAttribute("name")),scope为上面四种范围。




补充:
JSTL-fmt标签库


国际化核心标签:
格式化标签:


1.标签:用于解析日期
属性描述
value:将被解析的字符串
type:解析格式化的类型
pattern:解析格式化模式
var:结果保存变量,类型为 java.lang.Date
scope:变量的作用范围
parseLocale:以本地化的形式来解析字符串,该属性的内容为 String 或 java.util.Locale 类型的实例
timeZone:指定解析格式化日期的时区




2.标签:用于格式化数字
属性描述
value:格式化的数字,该数值可以是 String 类型(需要是全数字)或 java.lang.Number 类型的实例
type:格式化的类型,可能值包括:currency(货币)、number(数字)和percent(百分比)
pattern:格式化模式:前缀
var:结果保存变量
scope:变量的作用范围
maxIntegerDigits:指定格式化结果的:小数点前最多保留几位
minIntegerDigits:指定格式化结果的:小数点前保留几位 ,补全
maxFractionDigits:指定格式化结果的:小数点后最多保留几位
minFractionDigits:指定格式化结果的:小数点后最少保留几位 默认是2


如:
   结果将被保存在“ money ”变量中,将根据 Locale 环境显示当地的货币格式





3. 标签:用于资源配置文件的数据来源
3.1 标签将资源配置文件绑定于它标签体中的显示
属性描述
basename:资源配置文件的指定,只需要指定文件名而无须扩展名
prefix:前置关键字
如:
资源文件中配置的数据为:
label.backcolor=#FFF
label.fontcolor=#000
则,可以用如下方法取得label的backcolor和fontcolor值:
   


   



3.2 标签则允许将资源配置文件保存为一个变量,在之后的工作可以根据该变量来进行
属性描述 ,二组标签共有的属性
var: 独有的属性,用于保存资源配置文件为一个变量
scope:变量的作用范围
如:
   查找一个名为 applicationMessage_zh_CN.properties 的资源配置文件,来作为显示的 Resource 绑定
   




4. 标签:用于显示资源配置文件信息(该资源文件必须遵循如下格式:1.扩展名必须为properties,2.文件的内容必须依照key = value的格式;3.文件要放到WEB-INF/classes目录下)
属性描述
key:资源配置文件的“键”指定
bundle:若使用 保存了资源配置文件,该属性就可以从保存的资源配置文件中进行查找
var:将显示信息保存为一个变量
scope:变量的作用范围
如:
1)用标签将"applicationMessage"资源配置文件被赋于了变量"applicationBundle"
   用标签显示由标签保存的资源配置文件中"键"为"passWord"的信息






2)用标签定义的"applicationAllMessage"资源配置文件作用于其标签体内的显示
   用标签显示"applicationAllMessage"资源配置文件中"键"为"userName"的信息



   



5. 标签应该位于 标签内,将为该消息标签提供参数值。它只有一个属性value
如:在MyResourse.properties文件中,有一个索引值如下(其中,{0}代表占位符):
Str2=Hi,{0}
则,使用标签传入值如下:
   

   

   

也可以在资源文件中指定参数的类型:
如:在MyResourse.properties文件中,有一个索引值如下:
Str3={0,date}
则,使用标签传入值如下:
   <% request.setAttribute("now",new Date()); %>
   

   

   





6.标签:用于设定时区
标签将使得在其标签体内的工作可以使用该时区设置
标签则允许将时区设置保存为一个变量,在之后的工作可以根据该变量来进行
属性描述
value:时区的设置
var: 独有的属性,用于保存时区为一个变量
scope:变量的作用范围




7.标签:用于为请求设置字符编码
它只有一个属性 value ,在该属性中可以定义字符编码。
如:
   




8. 标签:用于解析数字
属性描述
value:将被解析的字符串
type:解析格式化的类型
pattern:解析格式化模式
var:结果保存变量,类型为 java.lang.Number
scope:变量的作用范围
parseLocale:以本地化的形式来解析字符串,该属性的内容应为 String 或 java.util.Locale 类型的实例


如:
   将"15%"转换为数字



------------
9.标签:用于格式化日期
属性描述
value:格式化的日期,该属性的内容应该是 java.util.Date 类型的实例
type:格式化的类型
pattern:格式化模式
var:结果保存变量
scope:变量的作用范围
timeZone:指定格式化日期的时区




10.标签:用于设置本地化环境
属性描述
value:Locale 环境的指定,可以是 java.util.Locale 或 String 类型的实例
scope:Locale 环境变量的作用范围(可选)
如:
   设置本地环境为繁体中文
   
   设置本地环境为简体中文
   

你可能感兴趣的:(java知识)