2014-10-10 56 views
0

我们有一个使用spring-social-facebook,spring-social-twitter,spring-social-linkedin和spring-social-google的项目。目前,我们使用以下版本:spring-social-linkedin与spring-social的兼容性1.1

  • 弹簧社会核心:1.0.3
  • 弹簧社会Facebook的:1.0.1
  • 弹簧社会叽叽喳喳:1.0.5
  • 春天 - 社会 - 谷歌:1.0.0
  • 弹簧社会LinkedIn:1.0.0.RC1

我们正试图更新Facebook和Twitter 1.1有许多可用于LinkedIn和GOOGL没有1.1库向在本+,因此所得到的版本是:

  • 弹簧社会核心:1.1.0.RELEASE
  • 弹簧社交Facebook的:1.1.1.RELEASE
  • 弹簧社交Twitter的: 1.1.0.RELEASE
  • 春 - 社会 - 谷歌:1.0.0
  • 弹簧社会LinkedIn:1.0.0.RC1

由于此更改,LinkedIn登录不再起作用,扔以下例外和:

org.springframework.http.converter.HttpMessageNotReadableException'。 org.springframework.http.converter.HttpMessageNotReadableException:无法读取JSON:找不到类型为[简单类型,类org.springframework.social.linkedin.api.LinkedInProfile]的合适构造函数:无法从JSON对象实例化(需要添加/启用类型信息?) at [Source:[email protected];行:2,列:3];嵌套异常是com.fasterxml.jackson.databind.JsonMappingException:找不到类型为[简单类型,类org.springframework.social.linkedin.api.LinkedInProfile]的合适构造函数:无法从JSON对象实例化(需要添加/启用类型信息?) at [Source:[email protected]; line:2,column:3] at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.readJavaType(MappingJackson2HttpMessageConverter.java:170)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web。org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.read(MappingJackson2HttpMessageConverter.java:162)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] 。 client.HttpMessageConverterExtractor.extractData(HttpMessageConverterExtractor.java:94)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java: 492)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:447)〜[spring-web-3.2。 0.RELEASE.jar:3.2.0.RELEASE] at org.spri ngframework.web.client.RestTemplate.getForObject(RestTemplate.java:215)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.social.linkedin.api.impl。 ProfileTemplate.getUserProfile(ProfileTemplate.java:79)〜[spring-social-linkedin-1.0.0.RC1.jar:na] at com.globaldawn.social.core.oauth.handler.LinkedInOAuthHandler.authenticate(LinkedInOAuthHandler.java: 94)〜[social-core-4.0.4219.jar:na] at com.globaldawn.social.core.oauth.service.SocialOAuthService.authenticateWithSocialNetwork(SocialOAuthService.java:371)〜[social-core-4.0.4219。jar:na] at com.globaldawn.social.core.oauth.service.SocialOAuthService.authenticate(SocialOAuthService.java:160)〜[social-core-4.0.4219.jar:na] at com.globaldawn.social。 web.controller.login.SocialLoginControllerUtil.login(SocialLoginControllerUtil.java:194)〜[classes /:na] at com.globaldawn.social.web.controller.login.SocialLoginControllerUtil.successfulLoginCallback(SocialLoginControllerUtil.java:117)〜[classes /:na] at com.globaldawn.social.web.controller.login.LinkedInSocialLoginController.successfulOAuthLoginCallback(LinkedInSocialLoginController.java:126)〜[classes /:na] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)〜[ na:1.7.0_51] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)〜[na:1.7.0_51] at sun.reflect。 DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)〜[na:1.7.0_51] at java.lang.reflect.Method.invoke(Method.java:606)〜[na:1.7.0_51] at org.springframework。 web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.method.support.InvocableHandlerMethod。 invokeForRequest(InvocableHandlerMethod.java:132)〜[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod。 java:104)〜[spring-webmvc-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:746) 〜[弹簧webmvc-3.2.0.RELEASE.j ar:3.2.0.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:687)〜[spring-webmvc-3.2.0.RELEASE.jar:3.2。 0.RELEASE] at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)〜[spring-webmvc-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925)[spring-webmvc-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.servlet.DispatcherServlet.doService (DispatcherServlet.java:856)[spring-webmvc-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:915)[spring-webmvc -3.2.0.RELEASE.jar:3.2.0.RELEASE] at或g.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:811)[spring-webmvc-3.2.0.RELEASE.jar:3.2.0.RELEASE] at javax.servlet.http.HttpServlet.service(HttpServlet .java:735)[social-rest-service.war:na] at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:796)[spring-webmvc-3.2.0.RELEASE.jar:3.2 .0.RELEASE] at javax.servlet.http.HttpServlet.service(HttpServlet.java:848)[social-rest-service.war:na] at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder。 java:698)[social-rest-service.war:na] at org.eclipse.jetty.servlet.ServletHandler $ CachedChain.doFilter(ServletHandler.java:1506)[social-rest-service.war:na] at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)[spring-web-3.2.0.RELE ASE.jar:3.2.0.RELEASE] 在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)[弹簧网络3.2.0.RELEASE.jar:3.2.0.RELEASE] org.eclipse.jetty.servlet.ServletHandler $ CachedChain.doFilter(ServletHandler.java:1494)[social-rest-service.war:na] at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java: 89)[spring-web-3.2.0.RELEASE.jar:3.2.0.RELEASE] at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)[spring-web-3.2.0。 org.eclipse.jetty.servlet.ServletHandler $ RELEASE.jar:3.2.0.RELEASE] $ CachedChain.doFilter(ServletHandler.java:1486)[social-rest-service.war:na] at org.eclipse.jetty .servlet.ServletHandler.doHandle(ServletHandler.java:503)[social-rest-service。war:na] at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:138)[social-rest-service.war:na] at org.eclipse.jetty.security.SecurityHandler.handle (SecurityHandler.java:564)[social-rest-service.war:na] at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:213)[social-rest-service.war:na ] org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1096)[social-rest-service.war:na] at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler。 java:432)[social-rest-service.war:na] at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:175)[social-rest-service.war:na] at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1030)[social-re st-service.war:na] at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:136)[social-rest-service.war:na] at org.eclipse.jetty.server .handler.HandlerWrapper.handle(HandlerWrapper.java:97)[social-rest-service.war:na] at com.codahale.metrics.jetty9.InstrumentedHandler.handle(InstrumentedHandler.java:173)[social-rest-service .war:na] at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)[social-rest-service.war:na] at com.globaldawn.application.monitoring.RequestMetricsHandler。 handle(RequestMetricsHandler.java:98)[social-rest-service.war:na] at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)[social-rest-service.war: na] at org.eclipse.jetty.server.Server.handle(Server.java:445)[ org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:268)[social-rest-service.war:na] at org.eclipse.jetty.server .HttpConnection.onFillable(HttpConnection.java:229)[social-rest-service.war:na] at org.eclipse.jetty.io.AbstractConnection $ ReadCallback.run(AbstractConnection.java:358)[social-rest-service .war:na] at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:601)[social-rest-service.war:na] at org.eclipse.jetty.util.thread。 QueuedThreadPool $ 3.run(QueuedThreadPool.java:532)[social-rest-service.war:na] at java.lang.Thread.run(Thread.java:744)[na:1.7.0_51] 引起:com .fasterxml.jackson.databind.JsonMappingException:找不到类型为[simple type,org.springframe work.social.linkedin.api.LinkedInProfile]:无法从JSON对象实例化(需要添加/启用类型信息?) at [Source:[email protected]; line:2,column:3] at com.fasterxml.jackson.databind.JsonMappingException.from(JsonMappingException.java:164)〜[jackson-databind-2.3.2.jar:2.3.2] at com.fasterxml。 jackson.databind.deser.BeanDeserializerBase.deserializeFromObjectUsingNonDefault(BeanDeserializerBase.java:1078)〜[jackson-databind-2.3.2.jar:2.3.2] at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer。 java:268)〜[jackson-databind-2.3.2.jar:2.3.2] at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:124)〜[jackson-databind-2.3。 2.jar:2.3.2] at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:2993)〜[jackson-databind-2.3.2.jar:2.3.2] at com.fasterxml。 jackson.databind.ObjectMapper.readValue(ObjectMapper.java:2158)〜[jackson- databind-2.3.2.jar:2.3.2] at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.readJavaType(MappingJackson2HttpMessageConverter.java:167)〜[spring-web-3.2.0.RELEASE.jar:3.2。 0.RELEASE] ... 58共同框架省略

我们使用gradle这个对我们的依赖管理,它始终以在需要不同版本的软件包的最高版本号,这样的依赖弹簧社会 - linkedin在spring-social-core 1.0.3上被强制升级到1.1.0。这是兼容的吗?在使用spring-social-facebook版本1.1和/或spring-social-twitter的项目中是否可以使用spring-social-linkedin?

回答

1

答案似乎是spring-social-core v1.1与spring-social-linkedin v1.0不兼容 - v1.0使用org.codehaus.jackson来序列化JSON,而v1.1使用com .fasterxml.jackson.core。

如果您需要在同一模块中使用spring-social-linkedin,则无法将spring-social-facebook或spring-social-twitter升级到v1.1。

并不令人惊讶,但我们可能需要完全摆脱春季社交,因为我们需要一些更新的功能,并且无法解耦不同的社交网络。