自定义EL表达式输出Clob内容

本文介绍了一个在项目中遇到的问题:EL表达式无法输出Clob内容。通过自定义EL表达式函数,成功解决了该问题。具体步骤包括编写函数、创建tld约束文件以及在JSP页面中引用和使用此函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

做项目的时候遇到了一个问题,就是EL表达式无法输出Clob的内容,只是会把Clob的类型简单的打印一下,从网上搜了一下,找到解决方法就是自定义一个EL表达式函数,来输出Clob内容,
1.首先写一个函数,注意所有的函数都必须是静态的啊。
代码如下:

package com.mj.utils;

import java.io.IOException;
import java.io.Reader;
import java.sql.Clob;
import java.sql.SQLException;


/**
* 自定义EL表达式输出Clob内容
* @author M.J
*
*/
public class El_Clob {
//输出clob内容,方法必须为静态方法
public static String printClob(Clob clob){
StringBuffer strClob=new StringBuffer();
String str="";
try {
Reader reader=clob.getCharacterStream();
char[] buffer=new char[1024];
int length=0;
while((length=reader.read(buffer, 0, 1024))!=-1){
strClob.append(buffer, 0, length);
}
} catch (SQLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
str=strClob.toString();
return str;
}
}

2.写tld约束文件
代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<taglib xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"
version="2.0">

<tlib-version>1.0</tlib-version>
<short-name>myEL</short-name>
<function>
<description>将Clob转换成String对象</description>
<name>printClob</name>
<function-class>com.mj.utils.El_Clob</function-class>
<function-signature>java.lang.String printClob(java.sql.Clob)</function-signature>
<example>${myEL:printClob(clob)}</example>
</function>
</taglib>

3.在JSP页面中引用

<%@ taglib uri="/WEB-INF/tlds/myEL.tld" prefix="myEL" %>

使用的时候,可以把Clob对象用<c:set/>标签设置到一个变量中,然后在引用这个变量

<td>
<c:set value="${user.userDesc}" var="clob" scope="page"></c:set>
${myEL:printClob(clob)}
</td>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值