问题:数据库中varchar类型的长度设置为5000,通过一个富文本编辑器编辑了通知内容,接收到了内容字段长度为8000多,unruly数据库时候,数据库报错(字段太长,显示下标越界异常)
解决办法:通过将得到的内容压缩后存入数据库中,取数据时候,将数据解压缩即可
代码案例如下所示:(一个字符串长度为一万以上,通过压缩后,长度仅为800左右,完全满足存库条件)
package vaadin.demo;
import java.io.IOException;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.util.zip.GZIPInputStream;
import java.util.zip.GZIPOutputStream;
public class VaadinDemo {
/**
* 字符串的压缩
*/
public static String compress(String str) throws IOException {
if (null == str || str.length() <= 0) {
return str;
}
// 创建一个新的 byte 数组输出流
ByteArrayOutputStream out = new ByteArrayOutputStream();
// 使用默认缓冲区大小创建新的输出流
GZIPOutputStream gzip = new GZIPOutputStream(out);
// 将 b.length 个字节写入此输出流
gzip.write(str.getBytes());
gzip.close();
// 使用指定的 charsetName,通过解码字节将缓冲区内容转换为字符串
return out.toString("ISO-8859-1");
}
/**
* 字符串的解压
*/
public static String unCompress(String str) throws IOException {
if (null == str || str.length() <= 0) {
return str;
}
// 创建一个新的 byte 数组输出流
ByteArrayOutputStream out = new ByteArrayOutputStream();
// 创建一个 ByteArrayInputStream,使用 buf 作为其缓冲区数组
ByteArrayInputStream in = new ByteArrayInputStream(str
.getBytes("ISO-8859-1"));
// 使用默认缓冲区大小创建新的输入流
GZIPInputStream gzip = new GZIPInputStream(in);
byte[] buffer = new byte[256];
int n = 0;
while ((n = gzip.read(buffer)) >= 0) {// 将未压缩数据读入字节数组
// 将指定 byte 数组中从偏移量 off 开始的 len 个字节写入此 byte数组输出流
out.write(buffer, 0, n);
}
// 使用指定的 charsetName,通过解码字节将缓冲区内容转换为字符串
return out.toString("GBK");
}
public static void main(String[] args) throws IOException {
String content = "
+ ">Dear All,
近期Jerry Shih会来到AGS。"
+ "
作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!
+ "r/>
时间:
· 请按时上、下班,避免"
+ "迟到或早退。
· 中午按时吃饭(12:00),"
+ "请不要提前。
公共设施:
· &n"
+ "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。
· "
+ " 带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。
· &"
+ "nbsp; 最后下班的同事请确认所有空调、灯等设备电源是否关闭。
+ "yle='text-align: justify;'>· VIP厕所请不要使用(哺乳期"
+ "员工除外)。
仪表:
· &nbs"
+ "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。
·  "
+ "; 请避免大声喧哗。
办公环境:
·  "
+ "; 请保证办公桌桌面的整洁。
·  "
+ "; 外套、围巾等服饰请挂在衣架或收进柜子里,请不要