- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 spring 的新手,我在 Spring 应用程序(基于 Java 的配置)中遇到了这个问题。
我的应用程序无法定位静态资源(css 文件、js 等)我尝试了不同的方法,但这个问题仍然存在。
我的 WebAppConfig.java 文件中有如下内容:
@EnableWebMvc
@EnableTransactionManagement
@ComponentScan("com.x.apimanager")
@PropertySource("classpath:application.properties")
@EnableJpaRepositories("com.x.apimanager.repository")
public class WebAppConfig extends WebMvcConfigurerAdapter {
// Other codes here that is not shown.
@Bean
public UrlBasedViewResolver setupViewResolver() {
UrlBasedViewResolver resolver = new UrlBasedViewResolver();
resolver.setPrefix("/WEB-INF/pages/");
resolver.setSuffix(".jsp");
resolver.setViewClass(JstlView.class);
return resolver;
}
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/resources/**").addResourceLocations("/resources/");
}
}
我的目录结构是这样的(图片可以在下面的链接中看到): http://pbrd.co/1EAR1II
我的 Spring Security Config 文件看起来像这样。我添加了一个拦截器,允许对特定文件夹的请求通过。
@Configuration
@EnableWebMvcSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Autowired
public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
//Implementation not shown
}
@Override
public void configure(WebSecurity web) throws Exception {
web.ignoring().antMatchers("/resources/**");
}
}
这是在 jsp 页面/ View 上发生此问题时 firebug 显示的内容。
"NetworkError: 404 Not Found - http://localhost:9999/apimanager/resources/libs/bootstrap-3.3.1/css/navbar.css"
navbar.css
我的 jsp 页面包含以下内容:
<c:set var="url">${pageContext.request.requestURL}</c:set>
<base href="${fn:substring(url, 0, fn:length(url) - fn:length(pageContext.request.requestURI))}${pageContext.request.contextPath}/" />
<link href="resources/libs/bootstrap-3.3.1/css/navbar.css" rel="stylesheet">
我的日志显示如下:
2015-01-22 12:07:39 DEBUG SecurityContextPersistenceFilter:97 - SecurityContextHolder now cleared, as request processing completed
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 1 of 14 in additional filter chain; firing Filter: 'WebAsyncManagerIntegrationFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 2 of 14 in additional filter chain; firing Filter: 'SecurityContextPersistenceFilter'
2015-01-22 12:07:40 DEBUG HttpSessionSecurityContextRepository:171 - Obtained a valid SecurityContext from SPRING_SECURITY_CONTEXT: 'org.springframework.security.core.context.SecurityContextImpl@e18bbb85: Authentication: org.springframework.security.authentication.UsernamePasswordAuthenticationToken@e18bbb85: Principal: org.springframework.security.core.userdetails.User@a5979349: Username: x; Password: [PROTECTED]; Enabled: true; AccountNonExpired: true; credentialsNonExpired: true; AccountNonLocked: true; Granted Authorities: ROLE_USER; Credentials: [PROTECTED]; Authenticated: true; Details: org.springframework.security.web.authentication.WebAuthenticationDetails@12afc: RemoteIpAddress: 127.0.0.1; SessionId: 0102DF1734E5DCC343FF4C767FE3AD17; Granted Authorities: ROLE_USER'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 3 of 14 in additional filter chain; firing Filter: 'HeaderWriterFilter'
2015-01-22 12:07:40 DEBUG HstsHeaderWriter:129 - Not injecting HSTS header since it did not match the requestMatcher org.springframework.security.web.header.writers.HstsHeaderWriter$SecureRequestMatcher@528199b
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 4 of 14 in additional filter chain; firing Filter: 'CsrfFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 5 of 14 in additional filter chain; firing Filter: 'LogoutFilter'
2015-01-22 12:07:40 DEBUG AntPathRequestMatcher:127 - Request 'GET /resources/libs/bootstrap-3.3.1/css/navbar.css' doesn't match 'POST /logout
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 6 of 14 in additional filter chain; firing Filter: 'UsernamePasswordAuthenticationFilter'
2015-01-22 12:07:40 DEBUG AntPathRequestMatcher:127 - Request 'GET /resources/libs/bootstrap-3.3.1/css/navbar.css' doesn't match 'POST /login
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 7 of 14 in additional filter chain; firing Filter: 'DefaultLoginPageGeneratingFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 8 of 14 in additional filter chain; firing Filter: 'BasicAuthenticationFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 9 of 14 in additional filter chain; firing Filter: 'RequestCacheAwareFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 10 of 14 in additional filter chain; firing Filter: 'SecurityContextHolderAwareRequestFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 11 of 14 in additional filter chain; firing Filter: 'AnonymousAuthenticationFilter'
2015-01-22 12:07:40 DEBUG AnonymousAuthenticationFilter:107 - SecurityContextHolder not populated with anonymous token, as it already contained: 'org.springframework.security.authentication.UsernamePasswordAuthenticationToken@e18bbb85: Principal: org.springframework.security.core.userdetails.User@a5979349: Username: x; Password: [PROTECTED]; Enabled: true; AccountNonExpired: true; credentialsNonExpired: true; AccountNonLocked: true; Granted Authorities: ROLE_USER; Credentials: [PROTECTED]; Authenticated: true; Details: org.springframework.security.web.authentication.WebAuthenticationDetails@12afc: RemoteIpAddress: 127.0.0.1; SessionId: 0102DF1734E5DCC343FF4C767FE3AD17; Granted Authorities: ROLE_USER'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 12 of 14 in additional filter chain; firing Filter: 'SessionManagementFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 13 of 14 in additional filter chain; firing Filter: 'ExceptionTranslationFilter'
2015-01-22 12:07:40 DEBUG FilterChainProxy:337 - /resources/libs/bootstrap-3.3.1/css/navbar.css at position 14 of 14 in additional filter chain; firing Filter: 'FilterSecurityInterceptor'
2015-01-22 12:07:40 DEBUG FilterSecurityInterceptor:194 - Secure object: FilterInvocation: URL: /resources/libs/bootstrap-3.3.1/css/navbar.css; Attributes: [authenticated]
2015-01-22 12:07:40 DEBUG FilterSecurityInterceptor:310 - Previously Authenticated: org.springframework.security.authentication.UsernamePasswordAuthenticationToken@e18bbb85: Principal: org.springframework.security.core.userdetails.User@a5979349: Username: x; Password: [PROTECTED]; Enabled: true; AccountNonExpired: true; credentialsNonExpired: true; AccountNonLocked: true; Granted Authorities: ROLE_USER; Credentials: [PROTECTED]; Authenticated: true; Details: org.springframework.security.web.authentication.WebAuthenticationDetails@12afc: RemoteIpAddress: 127.0.0.1; SessionId: 0102DF1734E5DCC343FF4C767FE3AD17; Granted Authorities: ROLE_USER
2015-01-22 12:07:40 DEBUG AffirmativeBased:65 - Voter: org.springframework.security.web.access.expression.WebExpressionVoter@49950c0d, returned: 1
2015-01-22 12:07:40 DEBUG FilterSecurityInterceptor:215 - Authorization successful
2015-01-22 12:07:40 DEBUG FilterSecurityInterceptor:227 - RunAsManager did not change Authentication object
2015-01-22 12:07:40 DEBUG FilterChainProxy:323 - /resources/libs/bootstrap-3.3.1/css/navbar.css reached end of additional filter chain; proceeding with original chain
2015-01-22 12:07:40 DEBUG DispatcherServlet:823 - DispatcherServlet with name 'dispatcher' processing GET request for [/apimanager/resources/libs/bootstrap-3.3.1/css/navbar.css]
2015-01-22 12:07:40 DEBUG RequestMappingHandlerMapping:226 - Looking up handler method for path /resources/libs/bootstrap-3.3.1/css/navbar.css
2015-01-22 12:07:40 DEBUG RequestMappingHandlerMapping:236 - Did not find handler method for [/resources/libs/bootstrap-3.3.1/css/navbar.css]
2015-01-22 12:07:40 WARN PageNotFound:1108 - No mapping found for HTTP request with URI [/apimanager/resources/libs/bootstrap-3.3.1/css/navbar.css] in DispatcherServlet with name 'dispatcher'
2015-01-22 12:07:40 DEBUG DispatcherServlet:966 - Successfully completed request
2015-01-22 12:07:40 DEBUG ExceptionTranslationFilter:115 - Chain processed normally
我将不胜感激这个问题的解决方案。非常感谢您回答我的问题。
最佳答案
我希望您缺少的是应用程序上下文路径。
试试这个
<link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/resources/css/navbar.css" />
关于css - JSP找不到css文件(基于java的webconfig),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28110912/
是否可以让标准 Java EE servlet 容器将文件解释并呈现为 JSP,即使该文件没有 .jsp 扩展名? 假设我的 WAR 根目录中有一个名为 foo.xyz 的文件。该文件包含一些 jST
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
我有几个通用元素(组件),它们会生成一些 html。似乎我的选择是创建一个 taglib,或者只是将该逻辑放入一个 jsp 页面并包含 jsp。 有什么不同?积极与消极? 最佳答案 Taglibs 允
我是 Ejb-JSP 的新手,对它知之甚少。我已经创建了一个 JSP 页面,它调用 Controller Servlet,而 servlet 调用 EJB。结构就像 JSP -> Servlet ->
我想编写一个自定义 JSP 标签,其输出包括其他 JSP 标签,这些标签本身也应该被动态评估。但显然我的一切TagSupport子类写入 pageContext.getOut()无需任何进一步评估,直
我有一个包含页面顶部内容的 JSP,我们称它为 header.jsp。出于性能原因,我想呈现此 JSP 并将其刷新给用户,然后再构建页面的其余部分。 (有关性能优势的解释,请参阅 here。) 我能想
我发现自己在处理一些旧的 JSP,想做一些简单的事情,比如以 dd/mm/yyyy 格式显示今天的日期 好像没那么简单, 到目前为止,我已经导入了 java.util.* 我试过很多东西 String
关于 JSP 标签字符集的简单问题。 mytag很简单。 tag文件位于 WEB-INF/tags .这个文件在 Eclipse 中的字符集是 UTF-8。出于某种原因,UTF-8 符号无法
这让我很吃惊!我的 JSP 中有以下代码。 在我重构 SlideShow 类并公开所有属性并删除 getter/setter 之前,这段代码一直有效。所以在我看来,EL 只适用于 getter 而不
现有的一组 JSP,用英文字段标签、javascript 错误/信息消息、图像“alt”消息等硬编码,需要多语言化。 将这些 JSP 转换为使用标准 Java 多语言功能(资源包、语言环境等)的最佳方
Closed. This question needs to be more focused。它当前不接受答案。 想改善这个问题吗?更新问题,使其仅通过editing this post专注于一个问题
我已经在 Tomcat 6.0 下部署了我们的 War 到 Linux 服务器。在那个 Linux 机器上,我们没有打开浏览器的权限。 是否可以从命令行执行 JSP? 最佳答案 您可以使用其中 wge
有没有人建议为 JSP 设置最佳缓冲区大小?您可以使用以下页面指令在 JSP 中设置缓冲区大小 我的问题如下 我的理解是,您使用的缓冲区大小越小,客户端浏览器的性能就越好。我的假设正确吗?如
我们正在使用 JBoss 7.1.3.Final 和 Java 6。我想将 UTF-8 页面编码应用于我们网站上提供的所有 JSP 页面,因此我将其添加到我们的 web.xml 文件中
学过jsp native,想包含动态文件。我想使用 include 调用动态页面 这段代码 如果我输入 dashboard.jsp?p=about 页面打开“pages/a
在我的 JSP 页面中,我希望链接转发到另一个 JSP 页面。当用户在 home.jsp 上时,我希望他们转到 login.jsp 等。我遇到的问题是无法找到 JSP,除非我将页面放在项目文件夹中(在
我正在尝试在新的grails应用程序中使用index.jsp切换index.gsp。我将默认的index.gsp重命名为not_index.gsp,并添加了index.jsp。现在,我收到以下错误。
是否可以从服务器端 jsf 代码将资源打开到新的浏览器选项卡(如命令按钮的 target="_newtab")? 以下代码在同一选项卡中打开资源: FacesContext.getCurrentIns
我想问一个关于 .jsp 的问题。使用 jsp 语法(例如 )和 XML 语法(例如 ... )有什么不同。使用其中一种语法是否有维护或某种 advs?谢谢。 最佳答案 原始的 语法更加紧凑,但如
JSP 文件是否有行业标准命名约定? 我遇到过来自不同来源的三种约定: 全部小写 (thisismyfile.jsp) 首字母小写的驼峰式大小写 (thisIsMyFile.jsp) 首字母大写的驼峰
我是一名优秀的程序员,十分优秀!