Jira启动失败,自定义插件使用rest api(jersey)

时间:2014-06-26 13:34:35

标签: jersey jira jira-rest-api jira-rest-java-api

我们正在开发一个使用rest api的jira自定义插件。

安装自定义插件后,当我们重启jira时,它会失败。

我们在日志中遇到以下异常:

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'activator' defined in URL [bundle://109.0:0/META-INF/spring/atlassian-plugins-components.xml]: Invocation of init method failed; nested exception is com.sun.jersey.spi.service.ServiceConfigurationError: com.sun.jersey.spi.HeaderDelegateProvider: The class com.sun.jersey.core.impl.provider.header.LocaleProvider implementing provider interface com.sun.jersey.spi.HeaderDelegateProvider could not be instantiated: Cannot cast com.sun.jersey.core.impl.provider.header.LocaleProvider to com.sun.jersey.spi.HeaderDelegateProvider
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1338)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
at java.security.AccessController.doPrivileged(Native Method)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:429)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:728)
at org.springframework.osgi.context.support.AbstractDelegatedExecutionApplicationContext.access$1600(AbstractDelegatedExecutionApplicationContext.java:69)
at org.springframework.osgi.context.support.AbstractDelegatedExecutionApplicationContext$4.run(AbstractDelegatedExecutionApplicationContext.java:355)
at org.springframework.osgi.util.internal.PrivilegedUtils.executeWithCustomTCCL(PrivilegedUtils.java:85)
at org.springframework.osgi.context.support.AbstractDelegatedExecutionApplicationContext.completeRefresh(AbstractDelegatedExecutionApplicationContext.java:320)
at org.springframework.osgi.extender.internal.dependencies.startup.DependencyWaiterApplicationContextExecutor$CompleteRefreshTask.run(DependencyWaiterApplicationContextExecutor.java:132)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:724)
Caused by: com.sun.jersey.spi.service.ServiceConfigurationError: com.sun.jersey.spi.HeaderDelegateProvider: The class com.sun.jersey.core.impl.provider.header.LocaleProvider implementing provider interface com.sun.jersey.spi.HeaderDelegateProvider could not be instantiated: Cannot cast com.sun.jersey.core.impl.provider.header.LocaleProvider to com.sun.jersey.spi.HeaderDelegateProvider
at com.sun.jersey.core.osgi.Activator$OsgiServiceFinder$1.next(Activator.java:80)
at com.sun.jersey.core.spi.factory.AbstractRuntimeDelegate.<init>(AbstractRuntimeDelegate.java:76)
at com.sun.jersey.server.impl.provider.RuntimeDelegateImpl.<init>(RuntimeDelegateImpl.java:54)
at com.sun.jersey.server.osgi.Activator.start(Activator.java:63)
at com.atlassian.plugins.rest.module.Activator.afterPropertiesSet(Activator.java:22)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
... 19 more
Caused by: java.lang.ClassCastException: Cannot cast com.sun.jersey.core.impl.provider.header.LocaleProvider to com.sun.jersey.spi.HeaderDelegateProvider
at java.lang.Class.cast(Class.java:3084)
at com.sun.jersey.core.osgi.Activator$OsgiServiceFinder$1.next(Activator.java:78)
... 25 more

您能为上述例外情况提出解决方案吗?

此插件的

atlassian-plugin.xml 文件:

<atlassian-plugin key="${project.groupId}.${project.artifactId}" name="${project.name}" plugins-version="2">
    <plugin-info>
        <description>${project.description}</description>
        <version>${project.version}</version>
        <vendor name="${project.organization.name}" url="${project.organization.url}" />
        <param name="plugin-icon">images/pluginIcon.png</param>
        <param name="plugin-logo">images/pluginLogo.png</param>
    </plugin-info>

  <web-resource key="QC-Jira-Linkage" name="QC-Jira-Linkage Web Resources">
        <dependency>com.atlassian.auiplugin:ajs</dependency>
    <!--     <resource type="download" name="qc-jira-linkage.css" location="css/qc-jira-linkage.css"/> -->
        <resource type="download" name="qc-jira-linkage.js" location="js/qc-jira-linkage.js"/>
        <resource type="download" name="images/" location="images/"/>
        <context>QC-Jira-Linkage</context>
        <context>atl.general</context>
       <context>atl.admin</context>


  </web-resource> 
     <!-- add our i18n resource -->
    <resource type="i18n" name="qc-jira-linkage" location="qc-jira-linkage"/>

     <web-item key="add-qc-link" section="create-issue-link-types" weight="20">
        <label key="com.example.externallinkage.type" />
        <link linkId="add-qc-link">
            /secure/LinkQC!default.jspa?id=${issueId}
        </link> 
    </web-item>
    <component key="link-service" class="com.example.externallinkage.LinkService"/>

    <component-import key="activityService" interface="com.atlassian.streams.thirdparty.api.ActivityService"/>
    <component-import key="sal-request-factory" interface="com.atlassian.sal.api.net.RequestFactory"/>

    <webwork1 key="issue-link-qc" name="Link Issues With QC" class="java.lang.Object">
        <actions>
            <action name="com.example.externallinkage.LinkQC" alias="LinkQC">
                <view name="error">/templates/qc-jira-linkage-view.vm</view>
                <view name="input">/templates/qc-jira-linkage-view.vm</view>
            </action>
        </actions>
    </webwork1>



    <component-import key="remote-issue-link-service" interface="com.atlassian.jira.bc.issue.link.RemoteIssueLinkService"/>

    <issue-link-renderer key="qc-jira-linkagekey" application-type="com.example.externallinkage" class="com.example.externallinkage.JiraQCLinkRenderer">
         <resource name="initial-view" type="velocity" location="templates/renderer/loadingissuelink.vm"/>
        <resource name="final-view" type="velocity" location="templates/renderer/qclink.vm"/>
    </issue-link-renderer>

    <component-import key="userManager" interface="com.atlassian.sal.api.user.UserManager" />
    <component-import key="loginUriProvider" interface="com.atlassian.sal.api.auth.LoginUriProvider" />
    <component-import key="renderer" interface="com.atlassian.templaterenderer.velocity.one.six.VelocityTemplateRenderer" />
    <component-import key="applicationProperties" interface="com.atlassian.sal.api.ApplicationProperties" />
    <component-import key="pluginSettingsFactory" interface="com.atlassian.sal.api.pluginsettings.PluginSettingsFactory" />
    <component-import key="transactionTemplate" interface="com.atlassian.sal.api.transaction.TransactionTemplate" />
    <template-context-item key="applicationPropertiesContextItem" component-ref="applicationProperties"
                        context-key="applicationProperties" name="Application Properties Context Item"/> 

    <servlet key="link-servlet" class="com.example.externallinkage.LinkServlet">
      <url-pattern>/asurion/TestInstanceDetails</url-pattern>

    </servlet>


    <webwork1 key="DeleteLink" name="DeleteLink" class="java.lang.Object">
              <actions>
                     <action name="com.example.externallinkage.RemoteDeleteLink" alias="DeleteRemoteIssueLink" roles-required="use">
                        <view name="input">/secure/views/issue/deletelink.jsp</view>
                        <view name="error">/secure/views/issue/deletelink.jsp</view>
                    </action>
              </actions>
       </webwork1>   

</atlassian-plugin>

2 个答案:

答案 0 :(得分:0)

无法编辑问题,因此请在此处添加更多详细信息。

此插件的

atlassian-plugin.xml 文件已按照评论中的要求消失:(

<atlassian-plugin key="${project.groupId}.${project.artifactId}" name="${project.name}" plugins-version="2">
    <plugin-info>
        <description>${project.description}</description>
        <version>${project.version}</version>
        <vendor name="${project.organization.name}" url="${project.organization.url}" />
        <param name="plugin-icon">images/pluginIcon.png</param>
        <param name="plugin-logo">images/pluginLogo.png</param>
    </plugin-info>

  <web-resource key="QC-Jira-Linkage" name="QC-Jira-Linkage Web Resources">
        <dependency>com.atlassian.auiplugin:ajs</dependency>
    <!--     <resource type="download" name="qc-jira-linkage.css" location="css/qc-jira-linkage.css"/> -->
        <resource type="download" name="qc-jira-linkage.js" location="js/qc-jira-linkage.js"/>
        <resource type="download" name="images/" location="images/"/>
        <context>QC-Jira-Linkage</context>
        <context>atl.general</context>
       <context>atl.admin</context>


  </web-resource> 
     <!-- add our i18n resource -->
    <resource type="i18n" name="qc-jira-linkage" location="qc-jira-linkage"/>

     <web-item key="add-qc-link" section="create-issue-link-types" weight="20">
        <label key="com.example.externallinkage.type" />
        <link linkId="add-qc-link">
            /secure/LinkQC!default.jspa?id=${issueId}
        </link> 
    </web-item>
    <component key="link-service" class="com.example.externallinkage.LinkService"/>

    <component-import key="activityService" interface="com.atlassian.streams.thirdparty.api.ActivityService"/>
    <component-import key="sal-request-factory" interface="com.atlassian.sal.api.net.RequestFactory"/>

    <webwork1 key="issue-link-qc" name="Link Issues With QC" class="java.lang.Object">
        <actions>
            <action name="com.example.externallinkage.LinkQC" alias="LinkQC">
                <view name="error">/templates/qc-jira-linkage-view.vm</view>
                <view name="input">/templates/qc-jira-linkage-view.vm</view>
            </action>
        </actions>
    </webwork1>



    <component-import key="remote-issue-link-service" interface="com.atlassian.jira.bc.issue.link.RemoteIssueLinkService"/>

    <issue-link-renderer key="qc-jira-linkagekey" application-type="com.example.externallinkage" class="com.example.externallinkage.JiraQCLinkRenderer">
         <resource name="initial-view" type="velocity" location="templates/renderer/loadingissuelink.vm"/>
        <resource name="final-view" type="velocity" location="templates/renderer/qclink.vm"/>
    </issue-link-renderer>

    <component-import key="userManager" interface="com.atlassian.sal.api.user.UserManager" />
    <component-import key="loginUriProvider" interface="com.atlassian.sal.api.auth.LoginUriProvider" />
    <component-import key="renderer" interface="com.atlassian.templaterenderer.velocity.one.six.VelocityTemplateRenderer" />
    <component-import key="applicationProperties" interface="com.atlassian.sal.api.ApplicationProperties" />
    <component-import key="pluginSettingsFactory" interface="com.atlassian.sal.api.pluginsettings.PluginSettingsFactory" />
    <component-import key="transactionTemplate" interface="com.atlassian.sal.api.transaction.TransactionTemplate" />
    <template-context-item key="applicationPropertiesContextItem" component-ref="applicationProperties"
                        context-key="applicationProperties" name="Application Properties Context Item"/> 

    <servlet key="link-servlet" class="com.example.externallinkage.LinkServlet">
      <url-pattern>/asurion/TestInstanceDetails</url-pattern>

    </servlet>


    <webwork1 key="DeleteLink" name="DeleteLink" class="java.lang.Object">
              <actions>
                     <action name="com.example.externallinkage.RemoteDeleteLink" alias="DeleteRemoteIssueLink" roles-required="use">
                        <view name="input">/secure/views/issue/deletelink.jsp</view>
                        <view name="error">/secure/views/issue/deletelink.jsp</view>
                    </action>
              </actions>
       </webwork1>   

</atlassian-plugin>

答案 1 :(得分:0)

就我而言,它根本没有与atlassian-plugin.xml连接。你也可以附上pom.xml吗?如果不是完整的,仅依赖性部分。

如果您使用atlas-create-jira-plugin和/或atlas-create-jira-plugin-module生成pom,则可能根本无法使用它。 我的变化存在差异,这也解决了您遇到的堆栈跟踪问题:

-        <dependency>
-            <groupId>com.atlassian.plugins.rest</groupId>
-            <artifactId>atlassian-rest-common</artifactId>
-            <version>2.9.2</version>
-        </dependency>
+        <dependency>
+            <groupId>com.atlassian.jira</groupId>
+            <artifactId>jira-rest-plugin</artifactId>
+            <version>${jira.version}</version>
+            <scope>provided</scope>
+        </dependency>

希望它有所帮助。