求mybatis 对BLOB数据的操作以及base64格式的处理
来源:互联网 发布:淘宝美工工作计划表 编辑:程序博客网 时间:2024/05/05 07:33
原文:求mybatis 对BLOB数据的操作以及base64格式的处理
源代码下载地址:http://www.zuidaima.com/share/1550463715314688.htm
寻求一个从前台将图片转成base64格式,base64与BLOB的转换以及基于mybatis将BLOB数据插入数据库的范例。跪求!
package com.zuidaima.mybatis;import java.io.ByteArrayOutputStream;import java.io.File;import java.io.InputStream;import javax.sql.rowset.serial.SerialBlob;import org.apache.commons.io.FileUtils;/***@author www.zuidaima.com**/public class Base64 {private static char[] base64EncodeChars = new char[] { 'A', 'B', 'C', 'D','E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q','R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd','e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q','r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3','4', '5', '6', '7', '8', '9', '+', '/' };private static byte[] base64DecodeChars = new byte[] { -1, -1, -1, -1, -1,-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,-1, -1, -1, -1, 62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59,60, 61, -1, -1, -1, -1, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1,-1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37,38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1,-1, -1 };private Base64() {}public static String encode(byte[] data) {StringBuffer sb = new StringBuffer();int len = data.length;int i = 0;int b1, b2, b3;while (i < len) {b1 = data[i++] & 0xff;if (i == len) {sb.append(base64EncodeChars[b1 >>> 2]);sb.append(base64EncodeChars[(b1 & 0x3) << 4]);sb.append("==");break;}b2 = data[i++] & 0xff;if (i == len) {sb.append(base64EncodeChars[b1 >>> 2]);sb.append(base64EncodeChars[((b1 & 0x03) << 4)| ((b2 & 0xf0) >>> 4)]);sb.append(base64EncodeChars[(b2 & 0x0f) << 2]);sb.append("=");break;}b3 = data[i++] & 0xff;sb.append(base64EncodeChars[b1 >>> 2]);sb.append(base64EncodeChars[((b1 & 0x03) << 4)| ((b2 & 0xf0) >>> 4)]);sb.append(base64EncodeChars[((b2 & 0x0f) << 2)| ((b3 & 0xc0) >>> 6)]);sb.append(base64EncodeChars[b3 & 0x3f]);}return sb.toString();}public static byte[] decode(String str) {byte[] data = str.getBytes();int len = data.length;ByteArrayOutputStream buf = new ByteArrayOutputStream(len);int i = 0;int b1, b2, b3, b4;while (i < len) {/* b1 */do {b1 = base64DecodeChars[data[i++]];} while (i < len && b1 == -1);if (b1 == -1) {break;}/* b2 */do {b2 = base64DecodeChars[data[i++]];} while (i < len && b2 == -1);if (b2 == -1) {break;}buf.write((int) ((b1 << 2) | ((b2 & 0x30) >>> 4)));/* b3 */do {b3 = data[i++];if (b3 == 61) {return buf.toByteArray();}b3 = base64DecodeChars[b3];} while (i < len && b3 == -1);if (b3 == -1) {break;}buf.write((int) (((b2 & 0x0f) << 4) | ((b3 & 0x3c) >>> 2)));/* b4 */do {b4 = data[i++];if (b4 == 61) {return buf.toByteArray();}b4 = base64DecodeChars[b4];} while (i < len && b4 == -1);if (b4 == -1) {break;}buf.write((int) (((b3 & 0x03) << 6) | b4));}return buf.toByteArray();}public static void main(String[] args) throws Exception {File file = new File("c:/a.png");SerialBlob blob = new SerialBlob(FileUtils.readFileToByteArray(file));InputStream in = blob.getBinaryStream();ByteArrayOutputStream outStream = new ByteArrayOutputStream();byte[] data = new byte[1024];int count = -1;while ((count = in.read(data, 0, 1024)) != -1)outStream.write(data, 0, count);data = null;byte[] bytes = outStream.toByteArray();String encode = encode(bytes);System.out.println(encode);byte[] _bytes = decode(encode);File dst = new File("c:/a_1.png");FileUtils.writeByteArrayToFile(dst, _bytes);System.out.println(dst);}}
1 0
- 求mybatis 对BLOB数据的操作以及base64格式的处理
- spirng 对clob blob数据的处理
- JDBC对多媒体等大数据的处理-Blob
- oracle对BLOB类型数据的操作与性能问题
- oracle对BLOB类型数据的操作与性能问题
- oracle对BLOB类型数据的操作与性能问题
- oracle对BLOB类型数据的操作与性能问题
- mybatis对oracel LONG数据的处理
- hibernate3中对blob的处理
- ORACLE的BLOB和BASE64
- hibernate对clob和blob的操作
- 数据库对 日期格式数据 操作处理
- SSM之Mybatis对数据库的查询以及批量操作
- 由对BLOB数据的操作所引发的一系列思考
- 由对BLOB数据的操作所引发的一系列思考
- hibernate操作mysql的blob数据
- java操作oracle的blob,clob数据
- java 操作oracle的blob类型数据
- livefyre评论获取
- 深入分析Java的接口和抽象类
- Matlab Toolbox for Dimensionality Reduction
- 判断是否包含非法字符的方法(小白法)
- Java Mail 发送邮件失败问题:Sending the email to the following server failed
- 求mybatis 对BLOB数据的操作以及base64格式的处理
- wireshark的使用
- 2015阿里暑期实习招聘在线笔记题
- 混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集。
- WindowsPhone自定义控件详解(二) - 模板类库分析
- Untiy3D生命周期
- Fragment之间的通信
- Python版Appium实现中文输入
- Android自定义属性时TypedArray的使用方法