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

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的热部署问题,还有绝对路径和相对路径的问题。共勉就完事了。

  • 19
    点赞
  • 62
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值