idea中javaweb的jsp页面图片加载不出来问题及解决

 更新时间:2023年07月17日 14:42:10   作者:Hello World 357  
这篇文章主要介绍了idea中javaweb的jsp页面图片加载不出来问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

idea中javaweb的jsp页面图片加载不出来

方式一

删掉out输出文件,重新生成(删除out文件夹,然后运行)

处理前:

在这里插入图片描述

处理后:

在这里插入图片描述

方式二

更改路径(将路径改为tomcat下的应用程序上下文里的内容+地址)

原路径:

<img src="../image/logo.jpg" alt="Paris" width="120" height="120"></div>

修改后的路径:

<img src="/Paris/image/logo.jpg" alt="Paris" width="120" height="120"></div>

idea部署javaweb项目jsp无法加载图片(资源无法加载的问题)

发现图片加载不出来,按了f12,发现404nofound,于是乎花了一天时间看博客

可能的原因有几个:

图片文件夹的位置弄错了

不应该把图片等静态资源放入WEB-INF里面,应该放入和WEB-INF的同等级的目录下

在这里插入图片描述

借用一下百度百科的解释

WEB-INF是Java的WEB应用的安全目录。所谓安全就是客户端无法访问,只有服务端可以访问的目录。

如果想在页面中直接访问其中的文件,必须通过web.xml文件对要访问的文件进行相应映射才能访问。

WEB-INF文件夹下除了web.xml外,还存一个classes文件夹,用以放置 *.class文件,这些 *.class文件是网站设计人员编写的类库,实现了jsp页面前台美工与后台服务的分离,使得网站的维护非常方便。web.xml文件为网站部署描述XML文件,对网站的部署非常重要。

在jsp中访问静态资源的方法

<body style="background-image:url(img/bgc.jpg);background-repeat: no-repeat;background-size: cover;">
<img src="img/icon_账号.png" style="width:1.5rem;height:1.5rem;vertical-align: middle;">

由于我放在web目录下,所以直接用相对路径访问,img/bgc.jpg就可以访问到了。通常不建议使用绝对路径,因为搭建完毕后,路径是会有改变的。

访问的路径不对

在我这个项目里面,假如使用绝对路径的话

那么应该是这个格式

<%String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
协议://server名字+:端口号(Tomcat默认8080)+(web目录下的路径)+"/"
%>

这个是我的:http://localhost:8080/servletdemo_war_exploded/img/bgc.jpg

使用相对路径的话那么应该是img/xxx.jpg

可能是拦截器的问题

把WEB-INF下的web.xml文件添加上下面的代码

 <servlet-mapping>
        <servlet-name>default</servlet-name>
        <url-pattern>*.gif</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>default</servlet-name>
        <url-pattern>*.png</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>default</servlet-name>
        <url-pattern>*.jpg</url-pattern>
    </servlet-mapping>

四.可能是tomcat配置,以及项目out没更新的问题

在这里插入图片描述

打开tomcat配置

在这里插入图片描述

设置为热部署

在这里插入图片描述

添加img文件夹的依赖

在这里插入图片描述

重启项目发现out目录出现了img文件夹就可以了

有时候可能因为缓存问题,里面的东西没有刷新,造成很多玄学事件 = =,例如有的图片可以访问,有的不可以,这时可以把整个out文件夹删掉,重启项目,估计就好了。

这次发现图片加载不了。学会了很多东西,例如img资源放置的位置,例如tomcat的热部署问题,还有绝对路径和相对路径的问题。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 详解springSecurity之java配置篇

    详解springSecurity之java配置篇

    这篇文章主要介绍了详解springSecurity之java配置篇,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • JAVA如何读取Excel数据

    JAVA如何读取Excel数据

    这篇文章主要介绍了JAVA如何读取Excel数据,帮助大家更好的理解和学习Java,感兴趣的朋友可以了解下
    2020-09-09
  • ​​​​​​​Java公平锁和非公平锁的区别

    ​​​​​​​Java公平锁和非公平锁的区别

    本文介绍​​​​​​​Java公平锁和非公平锁区别,公平锁是每个线程获取锁顺序是按照线程访问锁的先后顺序获取的,最前面的线程总是最先获取到锁;而非公平锁是每个线程获取锁的顺序是随机的,并不会遵循先来先得的规则,所有线程会竞争获取锁,下文内容需要的朋友可以参考下
    2022-05-05
  • Spring Boot 底层原理基础深度解析

    Spring Boot 底层原理基础深度解析

    这篇文章主要介绍了Spring Boot 底层原理基础,包括底层注解@Configuration,底层注解@Import及底层注解@Conditional的相关知识,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • springboot结合websocket聊天室实现私聊+群聊

    springboot结合websocket聊天室实现私聊+群聊

    本文主要介绍了springboot结合websocket聊天室实现私聊+群聊,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 一文弄懂Java中ThreadPoolExecutor

    一文弄懂Java中ThreadPoolExecutor

    ThreadPoolExecutor是Java中的一个线程池实现,它可以管理和控制多个 Worker Threads,本文就详细的介绍一下Java中ThreadPoolExecutor,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • Springboot项目编译后未能加载静态资源文件的问题

    Springboot项目编译后未能加载静态资源文件的问题

    这篇文章主要介绍了Springboot项目编译后未能加载静态资源文件的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • Java SPI的简单小实例

    Java SPI的简单小实例

    这篇文章主要介绍了Java SPI的简单小实例,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • java面试题之try中含return语句时代码的执行顺序详解

    java面试题之try中含return语句时代码的执行顺序详解

    这篇文章主要介绍了关于java中的一道面试题,这套题就是在try中含return语句时代码的执行顺序,这个问题看似简单,却暗藏杀机啊!文中通过一个个例子详细介绍了其中玄机,需要的朋友可以参考学习,下面来一起看看吧。
    2017-04-04
  • Java实战之兼职平台系统的实现

    Java实战之兼职平台系统的实现

    这篇文章主要介绍了如何利用Java编写一个兼职平台系统,采用到的技术有Springboot、SpringMVC、MyBatis、ThymeLeaf等,感兴趣的小伙伴可以了解一下
    2022-03-03

最新评论