java进阶(八)------动态获取图片---服务端获取图片显示在jsp中

142 篇文章 2 订阅



应用场景

如果我们本地或者服务器目录有一张图片,我们不能直接以访问静态资源的形式去访问这张图片。

所以考虑使用Action(服务端)作为中介去获得这张图片。

或者为了解决跨域问题:

比如我们使用了canvas把我们的动态页绘制保存成静态html页,但是动态页又用了其它第三方来源的图片,这种情况下canvas是不能绘制成功的,因为canvas不能跨域去获取第三方的图片。

所以我们需要把图片下载下来成流的形式再设置成允许跨域访问再返回给页面。





目标

把图片下载过来到内存里,然后response出去





原理

我们这里就有2种情况:

一种是读取本地获取服务器目录中的图片,转化成流的形式,把这个图片流用servlet的response直接返回到前台页面,通过解析在前台JSP页面上把这个图片显示出来。

第二种是下载第三方外链的图片,转化成流的形式,把这个图片流用servlet的response直接返回到前台页面,通过解析在前台JSP页面上把这个图片显示出来。




实例

我这里用的是springMVC框架。

本地服务器图片

    @RequestMapping("/testpic")
    public void testpic(HttpServletResponse response) throws IOException {        
        FileInputStream fis = null;
        File file = new File("D://timg.jpg");
        //File file = new File("home/images/test.png"); 服务器目录和本地图片的区别是图片路径
        fis = new FileInputStream(file);
        response.setContentType("image/jpg"); //设置返回的文件类型   
        response.setHeader("Access-Control-Allow-Origin", "*");//设置该图片允许跨域访问
        IOUtils.copy(fis, response.getOutputStream()); 
    }

我们在浏览器或者jsp页面使用以下路由就能访问到(显示)该图片:

http://localhost:8080/testpic






外链图片

    @RequestMapping("/testpic")
    public void testpic(HttpServletResponse response) throws IOException {
        String imgUrl="https://www.baidu.com/img/bd_logo1.png";
        URL url = new URL(imgUrl);                 
        URLConnection conn = url.openConnection();  
        InputStream inStream = conn.getInputStream();        
        response.setContentType("image/jpg"); //设置返回的文件类型   
        response.setHeader("Access-Control-Allow-Origin", "*");//设置该图片允许跨域访问
        IOUtils.copy(inStream, response.getOutputStream()); 
    }

我们在浏览器或者jsp页面使用以下路由就能访问到(显示)该图片:

http://localhost:8080/testpic






ps:判断图片类型

如果要判断不同的图片格式可以加上判断:
string imgType=imgUrl.Substring(imgUrl.LastIndexOf(".")+1).ToLower();
switch(imgType)
{
case "jpg":
imgType="image/jpeg";
break;
case "gif":
imgType="image/gif";
break;
//...........
default:
return;
}




  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张小凡vip

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值