我正在使用https://apereo.github.io/cas/5.3.x/installation/Configuring-Servlet-Container.html#external中指定的Maven叠加层并在以下位置使用项目模板:https://github.com/apereo/cas-overlay-template/tree/5.3
在Wildfly 14上部署CAS 5.3.10我已经编辑了可以在Wildfly 9上正确部署的pom,但是在Wildfly 14上部署失败,但有以下例外:
由于:java.lang.IllegalArgumentException:对象不是 在声明类的实例 sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)位于 sun.reflect.NativeMethodAccessorImpl.invoke(未知来源)位于 sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)位于 java.lang.reflect.Method.invoke(来源未知) org.springframework.core.io.VfsUtils.invokeVfsMethod(VfsUtils.java:100) 在org.springframework.core.io.VfsUtils.getFile(VfsUtils.java:172) 在 org.springframework.core.io.VfsResource.getFile(VfsResource.java:90) 在org.apereo.cas.util.CasVersion.getDateTime(CasVersion.java:59)处 org.apereo.cas.util.SystemUtils.getSystemInfo(SystemUtils.java:50) ...........
问题似乎与CasVersion
类有关,该类试图通过VFS(通过spring)访问以检索与模块的最后修改日期有关的信息。
答案 0 :(得分:1)
由于@Marco没有提供他的解决方案,所以我会的。对于遇到相同问题的任何人,请按照以下步骤解决:
cas-overlay-template
后,创建CasVersion.java
在src/main/java/org/apereo/cas/util
下具有以下内容:package org.apereo.cas.util;
import lombok.SneakyThrows;
import lombok.experimental.UtilityClass;
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.io.VfsResource;
import java.io.File;
import java.net.URL;
import java.time.ZonedDateTime;
/**
1. Class that exposes the CAS version. Fetches the "Implementation-Version"
2. manifest attribute from the jar file.
3. 4. @author Dmitriy Kopylenko
4. @since 3.0.0
*/
@Slf4j
@UtilityClass
public class CasVersion {
/**
* @return Return the full CAS version string.
* @see java.lang.Package#getImplementationVersion
*/
public static String getVersion() {
return CasVersion.class.getPackage().getImplementationVersion();
}
/**
* Gets specification version from the manifest package.
*
* @return the specification version
*/
public static String getSpecificationVersion() {
return CasVersion.class.getPackage().getSpecificationVersion();
}
/**
* Gets last modified date/time for the module.
*
* @return the date/time
*/
@SneakyThrows
public static ZonedDateTime getDateTime() {
final Class clazz = CasVersion.class;
final URL resource = clazz.getResource(clazz.getSimpleName() + ".class");
if ("file".equals(resource.getProtocol())) {
return DateTimeUtils.zonedDateTimeOf(new File(resource.toURI()).lastModified());
}
if ("jar".equals(resource.getProtocol())) {
final String path = resource.getPath();
final File file = new File(path.substring(5, path.indexOf('!')));
return DateTimeUtils.zonedDateTimeOf(file.lastModified());
}
// These lines are causing the reported exception so we just comment them out.
// if ("vfs".equals(resource.getProtocol())) {
// final File file = new VfsResource(resource.openConnection().getContent()).getFile();
// return DateTimeUtils.zonedDateTimeOf(file.lastModified());
// }
LOGGER.warn("Unhandled url protocol: [{}] resource: [{}]", resource.getProtocol(), resource);
return ZonedDateTime.now();
}
}
pom.xml
<!-- Required for lombok imports -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.16</version>
<scope>provided</scope>
</dependency>
<!-- Required for DateTimeUtils to be available on classpath -->
<dependency>
<groupId>org.apereo.cas</groupId>
<artifactId>cas-server-core-util</artifactId>
<version>${cas.version}</version>
</dependency>
<app-server>-tomcat</app-server>
替换出现的<app-server></app-server>
,因为您将提供应用程序服务器。上述步骤足以解决所报告的问题。