【发布时间】:2015-03-17 06:07:42
【问题描述】:
我正在尝试将 Spring OAuth2 服务器集成到 Liferay 中。尽管存在一些问题,但执行此操作的基本方法似乎很明确:
- 使用
DispatcherServlet将 URL 映射到 servlet - 使用
<context:component-scan>标记配置此servlet 以查找和初始化Spring OAuth2 服务器 - 实现
AuthorizationServerConfigurer并添加@EnableAuthorizationServer标签。
但是,这似乎还不够,OAuth 服务器永远不会初始化,并且对服务器应该侦听的 URL 的调用只是以错误 404 回答。
为了定位问题,我(几乎)成功地添加了一个小 REST 服务。这是我使用的代码:
第一步:web.xml
<servlet>
<servlet-name>springwebservice</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springwebservice</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
第二步:springwebservice-servlet.xml
<context:component-scan base-package="mypackage" />
第三步:MyRestController.java
@RestController
public class MyRestController {
@RequestMapping("/test")
public String testRest() {
return "Hello World!";
}
}
奇怪的是,这不起作用。它似乎忽略了@RestController 标签,只是把它当作普通的@Controller 处理,因此搜索了一个名为“Hello World!”的视图。而不是仅仅返回该文本:
WARN
[PageNotFound:1114] No mapping found for HTTP request with URI
[/TestLiferaySpring-1.0-SNAPSHOT/rest/Hello World!]
in DispatcherServlet with name 'springwebservice'
但除此之外,它确实表明第 1 步和第 2 步不应该是问题所在。但是,我的 OAuth2 服务器配置根本不会被调用!为什么会这样,我错过了什么?
这是OAuth2服务器配置的代码:
@EnableAuthorizationServer
public class OAuth2Config implements AuthorizationServerConfigurer {
@Override
public void configure(AuthorizationServerSecurityConfigurer security) throws Exception {
System.out.println("configure1");
}
@Override
public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
System.out.println("configure2");
}
@Override
public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
System.out.println("configure3");
}
}
【问题讨论】:
标签: java spring servlets spring-security liferay