利用struts实现jsp中的图片上传和预览

jsp代码

<input type=”file” name=”file” id=”f_UpImgId” value=”” style=”width: 200px”/>//选取图片
<input type=”button” value=”预览” id=”preBtnId”/>//预览按钮
<div id=”previewImgId” ></div>//要显示的图片
<input type=”hidden” id=”imgUrlID” name=”imgUrl” value=”sa”/>

ajax代码

$("#preBtnId").click(function(){
            $.ajaxFileUpload
            (
                {
                    url: '${url}adminjs/image!preview.action', //用于文件上传的服务器端请求地址
                    secureuri: false, //是否需要安全协议,一般设置为false
                    fileElementId: 'f_UpImgId', //文件上传域的ID
                    dataType: 'json', //返回值类型 一般设置为json
                    success: function (data, status)  //服务器成功响应处理函数
                    {
                        $("#previewImgId").html("&lt;img style='height: 100px;' src='${url}admin/image!toView.action?imgPath="+data.imgNewPath+"'/>");

                        $("#imgUrlID").val(data.imgNewPath);
                    },
                    error: function (data, status, e)//服务器响应失败处理函数
                    {

                    }
                }
            )
        });

引入头文件

<script src=”${url}lib/jquery-1.4.2.min.js” type=”text/javascript”></script>
<script src=” ${url}lib/ajaxfileupload.js” type=”text/javascript”></script>

配置文件

adminjs包下面的用来上传图片的配置文件
<action name=”image” class=”adminArticleAction”>
<interceptor-ref name=”defaultStack”>
<param name=”allowedTypes”>image/bmp,image/pjpeg,image/x-png,image/png,image/gif,image/jpg</param>
<param name=”fileUpload.maximumSize”>4MB</param>
</interceptor-ref>
<result type=”json”>
<param name=”contentType”>text/html</param>
</result>
</action>
admin包下面的用来预览图片的配置文件
<action name=”image” class=”adminArticleAction”>
<result name=”stream” type=”stream”>
<param name=”contentType”>image/jpeg</param>
<param name=”inputName”>photo</param>
</result>
</action>

action

private File file;
private InputStream photo;//预览图片
private String fileFileName;//与jsp中的对应。否则获取不到
private String fileFileContentType;
private String imgNewPath;
public InputStream getPhoto() {
return photo;
}
public void setFile(File file) {
this.file = file;
}
public void setFileFileName(String fileFileName) {
this.fileFileName = fileFileName;
}
public void setFileFileContentType(String fileFileContentType) {
this.fileFileContentType = fileFileContentType;
}
public String getImgNewPath() {
return imgNewPath;
}
//上传图片
public String preview() throws Exception{
if(file == null){
s = -101;
return SUCCESS;
}
String path = SysConfigStatic.COVER_IMAGE_UPLOAD_PATH;//要上传的目录
imgNewPath = path+adminArticleService.addImage(file, fileFileName, path);//上传图片到指定目录
return SUCCESS;
}

//预览
public String toView() throws Exception{
String imgPath=request.getParameter(“imgPath”);
System.out.println(imgPath);
File f = new File(imgPath);
photo = new FileInputStream(f);
response.setHeader(“Pragma”, “No-cache”);
response.setDateHeader(“Expires”, 0L);
response.setHeader(“Content-Length”,f.length()+”“);
return “stream”;
}

service

@Override
public String addImage(File srcFile, String oldFileName, String path) {
boolean f = false;
String suffix = oldFileName.substring(oldFileName.lastIndexOf(“.”));//获取图片后缀
String fileName = String.valueOf(new Date().getTime())+suffix;//随机生成文件名

try {
FileInputStream fis = new FileInputStream(srcFile);
FileOutputStream fos = new FileOutputStream(path+”/”+fileName);
byte[] buffer = new byte[(int)fis.available()];
fis.read(buffer);
fos.write(buffer);
f = true;
} catch (FileNotFoundException e) {
e.printStackTrace();
f = false;
} catch (IOException e) {
e.printStackTrace();
f = false;
}
if(!f)
return “error”;
return fileName;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值