Vue中前端请求后台,后台读取本地磁盘图片,到前端展示

Html代码

<a class="btn btn-primary" @click="viewImg">查看图片</a>
<div id="viewUserImg">
    <img id="userImg" :src="imgUrl">
    <!--<img id="userImg" src="${request.contextPath}/user/viewImg?userId=1">-->
</div>

JavaScript代码

var vm = new Vue({
    //当前vue对象接管的区域
    el: '#test',
    //属性
    data: {
        imgUrl: "user/viewImg"
    },
    //自定义方法
    methods: {
    	viewImg: function () {
			//这里映射的路径和你的包路径有关系,后台的映射路径可以根据具体的进行调整
			//也可以在这里拼接参数,去后台查询,先查询图片地址,然后在操作
			//vm.imgUrl = "user/viewImg?userId=1";
			vm.imgUrl = "user/viewImg";
		}
	}

Java后台代码

	/**
     * 根据用户id,读取相关的用户图片信息
     * @param userId 用户Id
     * @return
     */
    @RequestMapping("user/viewImg")
    public void viewUserImg(@RequestParam("userId") String userId, HttpServletResponse response) {
    	//根据用户Id查询用户信息
        //User user = userService.viewImg(userId, response);
        try {
        	//根据用户的图片路径,创建文件
        	//File file = new File(user.getImgUrl());
            File file = new File("D:\\userImg\\test.png");
            FileInputStream fileInputStream = new FileInputStream(file);
            long size = file.length();
            byte[] temp = new byte[(int) size];
            fileInputStream.read(temp, 0, (int) size);
            fileInputStream.close();
            byte[] data = temp;
            response.setContentType("image/png");
            OutputStream os = response.getOutputStream();
            os.write(data);
            os.flush();
            os.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值