在JSTL中使用字符串处理函数

本文介绍了JSTL中用于简化字符串操作的内置方法,如contains、endsWith等,并详细解释了如何在JSP中正确引入JSTL库以避免版本不一致导致的错误。
在JSTL中使用字符串处理函数

JSTL字符串处理函数

JSTL使用表达式来简化页面的代码,这对一些标准的方法,例如bean的getter/setter方法,请求参

数或者context以及session中的数据的访问非常方便,但是我们在实际应用中经常需要在页面调用对

象的某些方法,例如我需要调用字符串的length方法来获取字符串的长度时,在以往的开发过程中我

们必须把对象先转为String类,然后在调用其length方法,这样的代码繁琐而且容易出错。

因此JSTL 内置了几个用于字符串操作的方法,可以直接在表达式中使用,大大的简化了代码,提供代

码的可读性。在JSTL的表达是中要使用一个函数,其格式如下

${ns:m ethodNam e(args....)}

在使用这些函数之前必须在JSP中引入标准函数的声明

<% @ taglib prefix="fn" uri="http://java.sun.com /jsp/jstl/functions" % >

下面是JSTL中自带的方法列表以及其描述

[size=medium]
[b] 函数名 函数说明 使用举例[/b] [/size]

contains 判断字符串是否包含另外一个字符串 <c:if test="${fn:contains(name, searchString)}">

containsIgnoreCase 判断字符串是否包含另外一个字符串(大小写无关) <c:if test="${fn: containsIgnoreCase(name, searchString)}">


endsWith 判断字符串是否以另外字符串结束 <c:if test="${fn:endsWith(filename, ".txt")}">

escapeXml 把一些字符转成XML表示,例如 <字符应该转为< ${fn:escapeXml(param:info)}

indexOf 子字符串在母字符串中出现的位置 ${fn:indexOf(name, "-")}

join 将数组中的数据联合成一个新字符串,并使用指定字符格开 ${fn:join(array, ";")}

length 获取字符串的长度,或者数组的大小 ${fn:length(shoppingCart.products)}

replace 替换字符串中指定的字符 ${fn:replace(text, "-", "?")}

split 把字符串按照指定字符切分 ${fn:split(customerNames, ";")}

startsWith 判断字符串是否以某个子串开始 <c:if test="${fn:startsWith(product.id, "100-")}">

substring 获取子串 ${fn:substring(zip, 6, -1)}

substringAfter 获取从某个字符所在位置开始的子串 ${fn:substringAfter(zip, "-")}

substringBefore 获取从开始到某个字符所在位置的子串 ${fn:substringBefore(zip, "-")}

toLowerCase 转为小写 ${fn.toLowerCase(product.name)}

toUpperCase 转为大写字符 ${fn.UpperCase(product.name)}

trim 去除字符串前后的空格 ${fn.trim(name)}

今天将JSP的项目从Tomcat 5.5.12移植到Jboss AS去,偶然发现了一个奇怪的问题。"org.apache.jasper.

JasperException: This absolute uri (http://java.sun.com/jsp/jstl/core) cannot be resolved in

either web.xml or the jar files deployed with this application "

由于JSTL1.0和JSTL1.1的声明语句不一样。

JSTL 1.0 的声明是:

<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %>

JSTL1.1 的声明是:

<%@ taglib prefix="c" uri=http://java.sun.com/jsp/jstl/core %>

如果你使用的JSTL库和你在JSP中的声明不一致。就会报上面提到的Exception。

另外,要注意的是:Tomcat是先引用"TOMCAT_HOME/shared/lib"下面的库,再引用web项目下面

的"WEB-INF/lib'的库。

还有就是,jBuilder 自带库中的JSTL有两个配置,一个是"JSTL"(1.0),一个是"JSTL1.1"(1.1),注

意在做项目的时候别引用错了。

还有一个技巧是:如何判断JSTL的两个库文件(standar.jar和jstl.jar) 的版本?展开jar文件在"META-

INF" 目录下的MANIFEST.MF文件,其中"Specification-Version"指名的就是版本号。
内容概要:本文系统阐述了Java Persistence API(JPA)的核心概念、技术架构、核心组件及实践应用,重点介绍了JPA作为Java官方定义的对象关系映射(ORM)规范,如何通过实体类、EntityManager、JPQL和persistence.xml配置文件实现Java对象与数据库表之间的映射与操作。文章详细说明了JPA解决的传统JDBC开发痛点,如代码冗余、对象映射繁琐、跨数据库兼容性差等问题,并解析了JPA与Hibernate、EclipseLink等实现框架的关系。同时提供了基于Hibernate和MySQL的完整实践案例,涵盖Maven依赖配置、实体类定义、CRUD操作实现等关键步骤,并列举了常用JPA注解及其用途。最后总结了JPA的标准化优势、开发效率提升能力及在Spring生态中的延伸应用。 适合人群:具备一定Java基础,熟悉基本数据库操作,工作1-3年的后端开发人员或正在学习ORM技术的中级开发者。 使用场景及目标:①理解JPA作为ORM规范的核心原理与组件协作机制;②掌握基于JPA+Hibernate进行数据库操作的开发流程;③为技术选型、团队培训或向Spring Data JPA过渡提供理论与实践基础。 阅读建议:此资源以理论结合实践的方式讲解JPA,建议读者在学习过程中同步搭建环境,动手实现文中示例代码,重点关注EntityManager的使用、JPQL语法特点以及注解配置规则,从而深入理解JPA的设计思想与工程价值。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值