[jQuery+Html5]上传图片预览Image

使用jQuery+Html5实现前端上传图片后,无须上传至后台,回显到image中。

Html中需要的两个组件:

  • input file
  • img

JS代码

var upfile = document.querySelector(file的ID);
if(!/image\/\w+/.test(upfile.files[0].type)){
    alert("文件必须为图片!");
    return false;
}
var fileReader = new FileReader();
fileReader.onload = function(evt){  
    if(FileReader.DONE==fileReader.readyState){
        //this.result为图片的Base64编码
        $(图片的id选择器).attr('src',this.result); 
     }
}
fileReader.readAsDataURL(upfile.files[0]);

Java后台处理,将Base64编码字符转为图片,并且存入至服务器。
注 : 图片会存放至服务器根目录remarkImage文件夹中。

    /**
     * 根据传入的Base64压缩后的编码,反向生成图片,存入服务器,并且返回html img标签字符串
     * @param remark
     * @param request
     * @return
     */
    public static String createRemarks(String remark , HttpServletRequest request){
        if(remark==null||"".equals(remark)){
            return null;
        }

        String[] split = remark.split(",");
        String start = "<p>";
        StringBuffer center = new StringBuffer() ;
        for(String rem : split){
            //绝对路径-生成图片用的绝对路径
            String path = request.getServletContext().getRealPath("/remarkImage"); 
            String imageName = UUID.randomUUID().toString() + ".jpg";
            String imagePath = path+"\\"+imageName;
            boolean generateImage = generateImage(rem,imagePath);
            //虚拟路径-img回显时用的虚拟路径
            String contextPath = request.getServletContext().getContextPath();
            contextPath = contextPath+"/remarkImage/"+imageName;
            if(generateImage){
                String createHtmlImage = createHtmlImage(contextPath);
                center.append(createHtmlImage);
            }
        }
        String end = "</p>";
        String string = start + center.toString() + end;
        return string;
    }
    /**
     * 创建一个HTML编码的图片标签
     * @return
     */
    public static String createHtmlImage (String imageSrc){
        String image = "<img src=\""+imageSrc+"\" />";
        return image;
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值