Controller层:

@Controller
@RequestMapping(value = {"/Test/TestController"})
public class TestController extends BaseController implements ServletContextAware {
    private ServletContext servletContext;

@Override
    public void setServletContext(ServletContext servletContext) {
        this.servletContext = servletContext;
    }

/**写入数据的方法
     * 添加文件信息
     *
     * @param file
     * @param request
     * @return
     */
    @RequestMapping(value = {"/testFileAdd.html"}, method = RequestMethod.POST)
    public ModelAndView toTestFileAdd(@RequestParam(value = "Files", required = false) MultipartFile file, HttpServletRequest request) {
        Map<Object, Object> param = new HashMap<Object, Object>();
        String name = file.getOriginalFilename();
        InputStream stream = null;
        String ioStr = "";
        try {
            stream = file.getInputStream();
            //将流转换成String
            byte[] in = new byte[stream.available()];
            stream.read(in);
            ioStr = HQCodec.hexEncode(in); //调用工具类
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (null != stream) {
                try {
                    stream.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        param.put("FILE_NAME", name);
        param.put("FILES", ioStr);
        param.put("ID", 99);
        try {
            accessService.insert("TestFile.insertFile", param); //调用方法插入
        } catch (Exception e) {
            e.printStackTrace();
        }
        return new ModelAndView("sys/user/test");
    }

//写出的方法

//跳转到修改文件页面并将文件写到本地E盘中
    @RequestMapping("/toEditFiles.html")
    public ModelAndView toFiles(Integer id) {
        Map<Object, Object> param = new HashMap<Object, Object>();
        Map<String, Object> model = new HashMap<String, Object>();
        param.put("ID", id);
        try {
            Map<Object, Object> map = accessService.queryObject("TestFile.select", param);
            String file_name = (String) map.get("FILE_NAME");
            //写出clob 数据
           Clob o = (Clob) map.get("FILES");
            Reader stream = o.getCharacterStream();
            char[] c = new char[(int) o.length()];
            stream.read(c);
            String s = new String(c);
            stream.close();
            byte[] iobyte = HQCodec.hexDecode( s);
            File file = new File("E:"+file_name);
            OutputStream output = new FileOutputStream(file);
            output.write(iobyte);
            output.close();
            //将查询结果放入模型中
            model.put("TestFile", map);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return new ModelAndView("sys/user/toEditFiles", model);
    }

}

//转换类
public class HQCodec {
 
    static final char[] HEX = new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E',
            'F' };
 
    public static String hexEncode(byte[] buffer) {
        if (buffer.length == 0) {
            return "";
        }
        int holder = 0;
        char[] chars = new char[buffer.length * 2];
        for (int i = 0; i < buffer.length; i++) {
            holder = (buffer[i] & 0xf0) >> 4;
            chars[i * 2] = HEX[holder];
            holder = buffer[i] & 0x0f;
            chars[(i * 2) + 1] = HEX[holder];
        }
        return new String(chars);
    }
 
    public static byte[] hexDecode(String hex) {
        //A null string returns an empty array
        if (hex == null || hex.length() == 0) {
            return new byte[0];
        } else if (hex.length() < 3) {
            return new byte[] { (byte) (Integer.parseInt(hex, 16) & 0xff) };
        }
        //Adjust accordingly for odd-length strings
        int count = hex.length();
        int nibble = 0;
        if (count % 2 != 0) {
            count++;
            nibble = 1;
        }
        byte[] buf = new byte[count / 2];
        char c = 0;
        int holder = 0;
        int pos = 0;
        for (int i = 0; i < buf.length; i++) {
            for (int z = 0; z < 2 && pos < hex.length(); z++) {
                c = hex.charAt(pos++);
                if (c >= 'A' && c <= 'F') {
                    c -= 55;
                } else if (c >= '0' && c <= '9') {
                    c -= 48;
                } else if (c >= 'a' && c <= 'f') {
                    c -= 87;
                }
                if (nibble == 0) {
                    holder = c << 4;
                } else {
                    holder |= c;
                    buf[i] = (byte) holder;
                }
                nibble = 1 - nibble;
            }
        }
        return buf;
    }
}

将文件转成clob添加到Oracle数据库中的更多相关文章

  1. 如何将dmp文件导入到oracle数据库中

    如何将dmp文件导入到oracle数据库中 1.首先,我们可以先建立自己的一个用户表空间,创建表空间的格式如下: CREATE TABLESPACE certification(表空间的名字) DAT ...

  2. Oracle数据库中调用Java类开发存储过程、函数的方法

    Oracle数据库中调用Java类开发存储过程.函数的方法 时间:2014年12月24日  浏览:5538次 oracle数据库的开发非常灵活,不仅支持最基本的SQL,而且还提供了独有的PL/SQL, ...

  3. Oracle数据库中字段定义为Char类型,Hibernate用该字段进行动态绑定参数查询,获取不到结果的问题

    一.问题背景 产生环境:oracle数据库,hibernate操作 定义了一个表 create table STORE_INFORMATION ( id CHAR(32) not null, name ...

  4. ArcCatalog中通过ArcSDE向Oracle数据库中导入数据

    将数据导入到Oracle指定的表空间的具体内容如下: 首先,在ArcCatalog中建立指定表空间的数据库连接(要以指定表空间的用户登录): 然后,在ArcCatlog中定位到数据源,选中并拷贝图层; ...

  5. ORACLE数据库中执行计划出现INTERNAL_FUNCTION一定是隐式转换吗?

    ORACLE数据库中,我们会使用一些SQL语句找出存在隐式转换的问题SQL,其中网上流传的一个SQL语句如下,查询V$SQL_PLAN的字段FILTER_PREDICATES中是否存在INTERNAL ...

  6. oracle数据库中提供的5种约束

    约束作用:用来保持数据的完整性,防止无效数据进入到数据库中.oracle数据库中提供的5种约束,都是限定某个列或者列的组合的.1.主键约束(PRIMARY KEY):在一个表中能唯一的标识一行.主键可 ...

  7. sybase数据库和oracle数据库中字段中含有换行符的解决办法

    最近在做数据库从sybase到oracle的迁移工作,sybase数据库表bcp导出后,通过sqlldr导入到oracle数据库,然后oracle数据库通过spool按照sybase数据库bcp的格式 ...

  8. Oracle 数据库中查看表空间的2种方法

    在Oracle数据库中查看表空间使用状况是我们在实际应用中经常涉及到的,以下的内容就就是对Oracle 数据库中查看表空间使用状况时所要用到的SQL的描述,希望你能从中获得自己想要的东西. Oracl ...

  9. oracle 数据库中(创建、解锁、授权、删除)用户

    上文我们已经建立了名为orcl66的数据库. 想要在数据库中创建.修改用户需要我们以管理员权限登录到数据库中. 首先我们通过sqlplus命令登录连接数据库. 输入sqlplus命令--用户名: sy ...

随机推荐

  1. Ubuntu14.04和16.04官方默认更新源sources.list和第三方源推荐(干货!)

    不多说,直接上干货! 写在前面:笔者由于还在学校学习,学校没有开发给Linux用的上网客户端,所以只能用在windows系统中通过安装虚拟机运行linux比较方便,但没有外网,只有学校的教育网,所以我 ...

  2. GUI Design Studio的使用方法

    一.GUI Design Studio的介绍 GUI DesignStudio 是一个给应用软件设计图形用户界面的专业工具,它可在画基于web形态的原型时,可以用 Axure RP. Balsamiq ...

  3. Jupyter notbook& REVEAL.JS& nbconvert 使用jupyter notebook制作slides

    使用Jupyter notebook作为slide主要有两个方面: 在运行notebook 的时候可以幻灯片播放 这样幻灯片就有了notebook可交互的功能,而notebook就有了幻灯片全屏容易分 ...

  4. Petrozavodsk Summer-2017. Moscow IPT Contest

    A. A Place For My Head 留坑. B. New Divide 从高位到低位贪心,当这一位是$0$时,要尽量取$1$,维护高维后缀最小值进行判断即可. 时间复杂度$O((n+a)\l ...

  5. Matrix [POJ3685] [二分套二分]

    Description 有一个N阶方阵 第i行,j列的值Aij =i2 + 100000 × i + j2 - 100000 × j + i × j,需要找出这个方阵的第M小值. Input 第一行输 ...

  6. Vue(二十五)打包后路径报错问题

    1.修改 config - index.js 2.修改 build - utils.js

  7. tp5.0与mysql存储过程

    存储过程是一组预编译的sql语句,只需要创建一次过程,以后在程序中就可以调用该过程任意次,执行的速度快于普通sql语句,对于没有权限执行存储过程的用户,也可授权他们执行存储过程,存储过程是保存在数据库 ...

  8. @ConfigurationProperties注解取消location属性

    当我正在自学如何自定义properties配置文件,为了防止不必要的麻烦,重新创建了一个新的properties文件 fu.properties 然后在自定义的配置类中引入fu.properties/ ...

  9. [转]BT原理分析

    BitTorrent协议. BT全名为BitTorrent,是一个p2p软件,你在下载download的同时,也在为其他用户提供上传upload,因为大家是“互相帮助”,所以不会随着用户数的增加而降低 ...

  10. Vs Code 中文包设置

    首先打开Vs Code 然后点击扩展 下载中文包 安装中文包 在没打开任何文件的时候我们可以看到一些提示 这个时候使用快捷键 Ctrl + Shift + P  (显示所有命令),然后选择" ...