ssh框架+oracle实现将文件保存到服务器

1.字段类型    private java.sql.Blob  pactByte;   

2.配置文件类型      <property name="pactByte" type="java.sql.Blob"> <column name="PACT_byte" />  </property>

3.action层  service层与平常操作无异

4.dao层上传

  public void save(Pact pact,java.io.File file) throws Exception {
  try {
        Session session = getHibernateTemplate().getSessionFactory().getCurrentSession();
         session.beginTransaction();
         pact.setPactByte(Hibernate.createBlob(new byte[1]));
         session.save(pact);
         session.flush();
         session.refresh(pact, LockMode.UPGRADE);

         //将java.sql.blob 转化为oracle.sql.blob
         SerializableBlob sc = (SerializableBlob)  pact.getPactByte();
         java.sql.Blob wrapclob = sc.getWrappedBlob();
         oracle.sql.BLOB clob = (oracle.sql.BLOB) wrapclob;

         //将oracle.sql.blob类型重新放回字段中
         OutputStream fout = clob.getBinaryOutputStream();
         java.io.InputStream fin =new java.io.FileInputStream(file);
         byte[] buff = new byte[fin.available()];
         fin.read(buff);
         fin.close();
         fout.write(buff);
         fout.close();
         session.save(pact);
   
  } catch (Exception re) {
         throw re;
  }
 }
 

5.action层下载方法

     //下载合同文件
    public InputStream getDownloadFile() throws Exception{ 
     Pact pact = this.pactBiz.findById(pact_id);
     Blob blob = pact.getPactByte();
     InputStream fin=blob.getBinaryStream();  
     ServletActionContext.getResponse().setHeader("Content-Disposition", "attachment;filename=" + java.net.URLEncoder.encode(pact.getPactName(), "UTF-8"));
     ServletActionContext.getResponse().setContentType("application/msword");      
     return fin;
    }    
  
    public String downloadpact() {   
       return "success";
   }



   


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值