jsp文件中引入js、css文件失败问题

本文介绍了解决JSP页面加载JS和CSS文件失败的问题,通过配置SpringMVC来正确引用静态资源。

最近刚搭建了个项目,在jsp中引入js、css文件时失败,用绝对路径和相对路径均失败原因:

文件结构:



jsp代码:

<!DOCTYPE html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    System.out.println(basePath);
%>  
<html>
<head>
    <title>小程序后台登录</title>

    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" type="text/css" href="${basePath}assets/js/bootstrap-3.3.7/dist/css/bootstrap.css">
    <script type="text/javascript" src="${basePath}assets/js/jquery/jquery-3.2.1.js"></script>
    <srcipt type="text/javascript" src="${basePath}assets/js/bootstrap-3.3.7/dist/js/bootstrap.js"></srcipt>
</head>


中间使用的绝对路径引入失败,修改为相对路径也失败。

解决方法:

由于在浏览器的开发者模式下,发现引入静态文件报错404,所以访问不了资源,

需要在springmvc.xml文件中配置静态资源目录:

	<!-- 配置资源映射 -->
	<mvc:resources location="/assets/" mapping="/assets/**"/>

然后就OK了。





### SSM框架中JSP页面引入CSS文件失效的解决方案 在SSM框架下,当遇到JSP页面引入CSS文件失效的情况时,通常是因为SpringMVC配置不当导致静态资源被拦截。为了使CSS和其他静态资源能够正常加载,可以采取以下几种方法: #### 方法一:调整`web.xml`中的配置 如果在`web.xml`中设置了SpringMVC的前端控制器DispatcherServlet来处理所有的请求路径,则需要特别指定哪些URL模式应该排除在外,允许直接访问静态资源。 ```xml <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- 添加对静态资源的支持 --> <init-param> <param-name>defaultHtmlEscape</param-name> <param-value>true</param-value> </init-param> <multipart-config/> ``` 对于静态资源如CSSJavaScript等,可以通过添加默认的Servlet映射或者通过springmvc配置文件内的内部资源处理器来绕过SpringMVC的过滤[^1]。 #### 方法二:移除HTML5文档声明 有时浏览器或JSP本身可能不完全支持某些HTML5特性,这可能会干扰外部样式表的应用。尝试去掉`<!DOCTYPE html>`声明可以帮助解决问题,但这并不是推荐的做法,因为这样做会使得网页不再遵循标准规范[^2]。 #### 方法三:正确设置相对路径并使用EL表达式 确保链接到CSS文件的方式是正确的,并且考虑到项目的上下文根路径。一种常见做法是在JSP页面中利用EL表达式的`${pageContext.request.contextPath}`变量动态构建完整的URL地址。 ```jsp <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/css/style.css"/> ``` 这种方法能有效防止因项目部署位置变化而导致的路径错误问题[^3]。 #### 方法四:应用JSTL核心库<c:url/>标签 另一种更优雅的方法是借助JSTL的核心库提供的`<c:url>`标签来生成绝对路径。这种方式不仅简化了编码工作量,而且提高了代码可读性和维护性。 ```jsp <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> ... <link rel="stylesheet" href="<c:url value='/resources/css/style.css'/>"> ``` 上述措施均有助于解决SSM框架下的JSP页面无法成功加载CSS样式的难题。具体选择哪种方式取决于实际应用场景和个人偏好[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值