基于jifnal框架的文件上传一般形式(img)

Posted 白兰居士

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于jifnal框架的文件上传一般形式(img)相关的知识,希望对你有一定的参考价值。

实现mvc模式基于jfinal框架

首先是上传接口:

前端代码基于bootstrap和插件ajaxfileupload.js的异步上传:test.html

<script src="${base}/resources/js/ajaxfileupload.js" type="text/javascript"></script>

<input  type="file"  id="map" name="map">

<button type="button" onclick="ajaxFileUpload()" class="btn btn-info" id="upload">上传图片</button>

<img id="img1" alt="上传的图片显示位置" src=""  style="max-width:400px;max-length:400px;"/>

<script>

function ajaxFileUpload() {
  if(!checkImageExt("map")){
    return;
  }

  var map = $("#map").val();
  if(!validate_required(map)){
    alert("请选择要上传的图片!");
    return;
  }
  $.ajaxFileUpload
   (
     {
          url: ‘${base}/img/uploadMap‘, //用于文件上传的服务器端请求地址
      type: ‘post‘,
      data: { mapType: ‘2‘}, //此参数非常严谨,写错一个引号都不行
      secureuri: false, //一般设置为false
      fileElementId: ‘map‘, //文件上传空间的id属性 <input type="file" id="file" name="file" />
      dataType: ‘json‘, //返回值类型 一般设置为json
      success: function (data, status) //服务器成功响应处理函数
    {
      mapCode = data.imgName;
      $("#img1").attr("src", "${base}/img/iconMap?imgName="+data.imgName);
      if (typeof (data.error) != ‘undefined‘) {
        if (data.error != ‘‘) {
          alert("上传失败!");
        } else {
          alert(data.message);
        }
      }
    },
    error: function (data, status, e)//服务器响应失败处理函数
    {
      alert(e);
    }
  }
  );
}
//检测文件格式
function checkImageExt(eleId) {
  var _file = document.getElementById(eleId);
  var i = _file.value.lastIndexOf(‘.‘);
  var len = _file.value.length;
  var extEndName = _file.value.substring(i + 1, len);
  var extName = "GIF,BMP,JPG,JPEG,PNG";//首先对格式进行验证
  if (extName.indexOf(extEndName.toUpperCase()) == -1) {
    alert("*您只能输入" + extName + "格式的文件");
    return false;
  } else {
    return true;
  }
}

</script>

---------------------------------------------------------------------------------------------

控制器:FileCtrl.class代码如下:

/**
* 根据图片id获取图片

* 备注:调用此方法URL返回在html的直接是一个图片
* */
public void iconMap() throws IOException{
  String imageCode = this.getPara("imgName");
  EbMapFile image = null;
  MapService imgSer = new MapService();
  image = imgSer.findMapFile(imageCode);
  if(image != null){
    byte[] bs = image.getBytes("map_conten");
    this.getResponse().setContentLength(bs.length);
    this.getResponse().setContentType("image/*;charset=UTF-8");
    this.getResponse().setHeader("Content-Disposition", "filename="+ URLEncoder.encode(image.get("map_code")+"", "utf-8"));
    this.getResponse().getOutputStream().write(bs);
  }else{
  }
  this.renderNull();
}

 

/**
* 带参数传递测试上传图片
* @throws IOException
*/
public void uploadMap() throws IOException{
  UploadFile uploadFile = getFile();
  String mapType = this.getPara("mapType");

  String mapCode= "";//初始化图片id

  //取到文件保存
  if(uploadFile!=null){
    byte[] bs = FileHelper.toBytes(uploadFile.getFile());
    String nameImg = uploadFile.getFileName();
    String[] strs=nameImg.split("\\.");
    mapCode = strs[0];

    //检测数据库里图片的id是否已经存在
    MapService imgSer = new MapService();
    EbMapFile img = imgSer.findMapFile(mapCode);
    if(img == null){
      img = new EbMapFile();
      //建立文件路径
      File dirFile = new File(MCubeAppConfig.getInstance().getImagUrl());
    if(!dirFile.exists()){
      dirFile.mkdirs();
    }

    File desFile = new File(dirFile, mapCode);//定义文件名
    boolean success = false;
    try {
      success = uploadFile.getFile().renameTo(desFile);//jfinal批量上传文件时重命名
    } catch (Exception e) {
      e.printStackTrace();
    }
    setAttr("error", success ? 0 : 1);
    if(success){
      img.set("map_id", "EB_MAP_seq.nextval");
      img.set("map_code", mapCode);
      // img.set("map_type",1);
      img.set("map_type", new BigDecimal(mapType));//图片类型,1为中心地图
      img.set("map_CONTEN",bs);
      String mapUrl = MCubeAppConfig.getInstance().baseUrl +"/img/iconMap?imgName="+mapCode;
      img.setMapUrl(mapUrl);
      if(img.save()){
        setAttr("message", "上传成功");
      }
    }else{
      setAttr("message", "上传失败");
    }
  }
}
  setAttr("imgName",mapCode);
  render(new JsonRender().forIE());
}

--------------------------------------------------------------------------

图片的model类对象:

package cn.com.minstone.eBusiness.model;

import com.jfinal.plugin.activerecord.Model;

public class EbMapFile extends Model<EbMapFile>{

/**
* 展示地图文件图片表
*/
private static final long serialVersionUID = 1L;

public static final EbMapFile dao = new EbMapFile();

/**
* 数据库列名称:MAP_CODE
* */
private java.lang.String mapCode;

public java.lang.String getMapCode() {
  this.mapCode = this.get("MAP_CODE");
  return this.mapCode;
}

public void setMapCode(java.lang.String mapCode) {
  this.mapCode = mapCode;
  this.set("MAP_CODE", this.mapCode);
}

/**
* 数据库列名称:MAP_URL
* */
private java.lang.String mapUrl;

public java.lang.String getMapUrl() {
  this.mapUrl = this.get("MAP_URL");
  return mapUrl;
}

public void setMapUrl(java.lang.String mapUrl) {
  this.mapUrl = mapUrl;
  this.set("MAP_URL", this.mapUrl);
}

/**
* 数据库列名称:MAP_ID
* */
private java.math.BigDecimal mapId;

public java.math.BigDecimal getMapId() {
  this.mapId = this.get("MAP_ID");
  return mapId;
}

public void setMapId(java.math.BigDecimal mapId) {
  this.mapId = mapId;
  this.set("MAP_ID", this.mapId);
}

/**
* 数据库列名称:MAP_CONTEN
* */
private oracle.jdbc.OracleBlob mapConten;

public oracle.jdbc.OracleBlob getMapConten() {
  this.mapConten = this.get("MAP_CONTEN");
  return mapConten;
}

public void setMapConten(oracle.jdbc.OracleBlob mapConten) {
  this.mapConten = mapConten;
  this.set("MAP_CONTEN", this.mapConten);
}

/**
* 数据库列名称:MAP_TYPE
* */
private java.math.BigDecimal mapType;

public java.math.BigDecimal getMapType() {
  this.mapType = this.get("MAP_TYPE");
  return this.mapType;
}

public void setMapType(java.math.BigDecimal mapType) {
  this.mapType = mapType;
  this.set("MAP_TYPE", this.mapType);
}
}

 

以上是关于基于jifnal框架的文件上传一般形式(img)的主要内容,如果未能解决你的问题,请参考以下文章

vue框架input框上传图片文件实时显示

基于file上传文件的并发上传(多个文件一起上传到后台并把数据存储的同一条数据中,如 数据库字段videopath,imge。前台发送来的文件file1,file2。 videopath=file1,

基于Flask开发网站 -- 前端Ajax异步上传文件到后台(文末送书)

OkHttpUtils一个专注于让网络请求更简单的框架

OkGO一个专注于让网络请求更简单的框架

django基于mysql实现图片上传与打开