图片转base64字符串以及页面显示

/**
*页面提交的图片转base64字符串。
*base64字符串中有\s,\t,\n转义字符,需要用空字符串替换掉他们。
*base64字符串在http传输中,其中的+号会被弄丢,导致图片无法
*正常显示,例如这段代码最后return的时候,如果是redirect重定向
*或者forward转发携带字符串,下一个controller方法接收到的
*base64字符串+号会丢掉
*
**/

    @RequestMapping("/upload")
    public String upload(@RequestParam("image") MultipartFile file, Model model) {
        BASE64Encoder bEncoder = new BASE64Encoder();
        String[] suffixArra = file.getOriginalFilename().split("\\.");
        String preffix = "data:image/jpg;base64,".replace("jpg", suffixArra[suffixArra.length - 1]);
        String base64EncoderImg = null;
        try {
            base64EncoderImg = preffix + bEncoder.encode(file.getBytes()).replaceAll("[\\s*\t\n\r]", "");
        } catch (IOException e) {
            e.printStackTrace();
        }
        model.addAttribute("base64Str", base64EncoderImg);
        return "upload_image";
        //        return "redirect:/index?base64Str?" + base64Str;
    }

//以下是页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="text/javascript" src="../jquery-1.8.3.js"></script>
</head>
<body>
<title>图片上传功能</title>
选择图片:
<form action="/upload" enctype="multipart/form-data" method="post" onsubmit="return beforeSubmit()">

    <input type="file" name="image">
    <input type="submit" value="上传"/>
</form>
<#--如果base64Str为空就显示网图-->
<img id="img"
     src="${base64Str!"https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1544667855,450621728&fm=26&gp=0.jpg"}"
     style="margin-top: 30px;width: 300px;height: 150px;"/>
</body>
<script>
    function beforeSubmit() {
        var img = $("input[name='image']").get(0).files[0];

        if (img == undefined || img.size <= 0 || img.name == null) {
            alert("你还没选择图片");
            return false;
        } else {
            return true;
        }
        return false;
    }
</script>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值