项目启动过程中,出现了java.lang.NoSuchFieldError: SERVER_SENT_EVENTS_TYPE异常,查看抛出的异常函数调用栈,发现是在使用jaxrs-api-3.0.12.Final.jar的类MediaType中没有SERVER_SENT_EVENTS_TYPE字段。通过全局查找发现,这个字段在另外一个jar包javax.ws.rs-api-2.1.jar的同名类MediaType中有,并且两个MediaType的package名称相同。显然,出现异常的代码中要使用的是后者的MediaType,但是实际使用的是jvm加载的前者MediaType,前者的MediaType没有SERVER_SENT_EVENTS_TYPE字段,抛出了异常。
jvm在创建一个类的实例之前,会通过类的全限定名称(即包路径名+类名)来判断该类是否已经加载,如果没有加载,就会从jar包中去加载这个类。如果有两个全限定名称相同的类,则jvm只会加载其中一个,另一个类在运行过程中就不会被加载。这种情况下,在使用另一个类的代码中,就可能会出现诸如:找不到方法(java.lang.NoSuchMethodError)、找不到字段(java.lang.NoSuchFieldError)的异常。
这种错误通常出现在,一个工程中,同时引用了相同jar包的两个不同版本。
常见的解决办法是:
方法一,在jar包管理中,直接将其中一个jar包删除
方法二,如果使用maven依赖,找到相关依赖项,通过exclusion排除一个依赖即可