Java中关于超长字符串压缩,解压缩问题

问题:数据库中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的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


" +"

Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


" +">Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


" +"

Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


"+">Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


" +"

Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


" +">Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


" +"

Dear All,  


近期Jerry Shih会来到AGS。" + "


作为AGS的一员,请大家配合以下事项,让我们共同展现出AGS的专业风貌!

时间:


·         请按时上、下班,避免" + "迟到或早退。


·         中午按时吃饭(12:00)," + "请不要提前。


公共设施:


·        &n" + "bsp;中午请大家在就餐区吃午饭,请不要在会议室或座位上就餐。


·     " + "    带饭的同仁请不要把饭盒放在吧台上,请放在冰箱。


·    &" + "nbsp;    最后下班的同事请确认所有空调、灯等设备电源是否关闭。


·         VIP厕所请不要使用(哺乳期" + "员工除外)。


仪表:


·        &nbs" + "p;着装需正式,颜色庄重、款式大方,请不要穿着休闲装。


·     " + ";    请避免大声喧哗。


办公环境:


·   " + ";      请保证办公桌桌面的整洁。


·       " + ";  外套、围巾等服饰请挂在衣架或收进柜子里,请不要搭在椅背或放在桌面上。


信息" + "安全:


·         离开座位时请锁掉电脑。


" + "

·         涉及保密信息的文件请不要放在桌面上。


·         请不要把信息留在白板上。


HR & A" + "dmin


AMAX Global Services


"; System.out.println(content); System.out.println("字符串长度为:" + content.length()); String ysStr = compress(content); System.out.println("\n压缩后的字符串为----->" + ysStr); float len1 = ysStr.length(); System.out.println("压缩后的字符串长度为----->" + len1); String jyStr = unCompress(ysStr); System.out.println("\n解压缩后的字符串为--->" + jyStr); System.out.println("解压缩后的字符串长度为--->" + jyStr.length()); //判断 if(jyStr.equals(content)){ System.out.println("解压后的字符串是一样的。。。。"); }else{ System.out.println("解压后的字符串不是一样的。。。。"); } } }

Java中关于超长字符串压缩,解压缩问题_第1张图片

/**
* 字符串gzip压缩
*/
 @SuppressWarnings("restriction")
	public static String gzip(String primStr) {
    	if (primStr == null || primStr.length() == 0) {
    		return primStr;
    	}
    	ByteArrayOutputStream out = new ByteArrayOutputStream();
    	GZIPOutputStream gzip=null;
    	try {
    		gzip = new GZIPOutputStream(out);
    		gzip.write(primStr.getBytes());
    	} catch (IOException e) {
    		e.printStackTrace();
    	}finally{
	    	if(gzip!=null){
		    	try {
		    		gzip.close();
		    	} catch (IOException e) {
		    		e.printStackTrace();
		    	}
	    	}
    	}
    	return new sun.misc.BASE64Encoder().encode(out.toByteArray());
    }
/**
     * 字符串的解压
     * Aaron Wang
     * 2019-06-03
     */
    @SuppressWarnings("restriction")
	public static String jyZip(String compressedStr){
    	if(compressedStr == null){
    	return null;
    	}

    	ByteArrayOutputStream out = new ByteArrayOutputStream();
    	ByteArrayInputStream in = null;
    	GZIPInputStream ginzip = null;
    	byte[] compressed = null;
    	String decompressed = null;
    	try {
    		compressed = new sun.misc.BASE64Decoder().decodeBuffer(compressedStr);
    		in=new ByteArrayInputStream(compressed);
    		ginzip=new GZIPInputStream(in);

	    	byte[] buffer = new byte[1024];
	    	int offset = -1;
	    	while ((offset = ginzip.read(buffer)) != -1) {
	    	out.write(buffer, 0, offset);
	    	}
	    	decompressed=out.toString();
    	} catch (IOException e) {
    		e.printStackTrace();
		} finally {
			if (ginzip != null) {
				try {
					ginzip.close();
				} catch (IOException e) {
				}
			}
			if (in != null) {
				try {
					in.close();
				} catch (IOException e) {
				}
			}
			if (out != null) {
				try {
					out.close();
				} catch (IOException e) {
				}
			}
		}
    	return decompressed;
    }

 

 

 

 

你可能感兴趣的:(Java)