2014-10-10 41 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。

並不令人驚訝,但我們可能需要完全擺脫春季社交,因爲我們需要一些更新的功能,並且無法解耦不同的社交網絡。