0

我正在尝试向 Jenkins API 提交 POST 以创建新作业。我遵循了 API 文档并使用 Postman 来提出特定请求。

当我发出请求时,服务器返回ERROR 500并出现以下错误:

<html><head><title>Error 500</title></head>

状态码:500

异常:无法读取 /var/lib/jenkins/jobs/Tes234t6.dev/config.xml
堆栈跟踪:
hudson.util.IOException2:无法读取 /var/lib/jenkins/jobs/Tes234t6.dev/config.xml
    在 hudson.XmlFile.read(XmlFile.java:145)
    在 hudson.model.Items.load(Items.java:220)
    在 hudson.model.ItemGroupMixIn.createProjectFromXML(ItemGroupMixIn.java:235)
    在 hudson.model.ItemGroupMixIn.createTopLevelItem(ItemGroupMixIn.java:167)
    在 jenkins.model.Jenkins.doCreateItem(Jenkins.java:2876)
    在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    在 java.lang.reflect.Method.invoke(Method.java:616)
    在 org.kohsuke.stapler.Function$InstanceFunction.invoke(Function.java:288)
    在 org.kohsuke.stapler.Function.bindAndInvoke(Function.java:151)
    在 org.kohsuke.stapler.Function.bindAndInvokeAndServeResponse(Function.java:90)
    在 org.kohsuke.stapler.MetaClass$1.doDispatch(MetaClass.java:111)
    在 org.kohsuke.stapler.NameBasedDispatcher.dispatch(NameBasedDispatcher.java:53)
    在 org.kohsuke.stapler.Stapler.tryInvoke(Stapler.java:677)
    在 org.kohsuke.stapler.Stapler.invoke(Stapler.java:770)
    在 org.kohsuke.stapler.Stapler.invoke(Stapler.java:583)
    在 org.kohsuke.stapler.Stapler.service(Stapler.java:214)
    在 javax.servlet.http.HttpServlet.service(HttpServlet.java:45)
    在 winstone.ServletConfiguration.execute(ServletConfiguration.java:248)
    在 winstone.RequestDispatcher.forward(RequestDispatcher.java:333)
    在 winstone.RequestDispatcher.doFilter(RequestDispatcher.java:376)
    在 hudson.util.PluginServletFilter$1.doFilter(PluginServletFilter.java:95)
    在 hudson.util.PluginServletFilter.doFilter(PluginServletFilter.java:87)
    在 winstone.FilterConfiguration.execute(FilterConfiguration.java:194)
    在 winstone.RequestDispatcher.doFilter(RequestDispatcher.java:366)
    在 hudson.security.csrf.CrumbFilter.doFilter(CrumbFilter.java:48)
    在 winstone.FilterConfiguration.execute(FilterConfiguration.java:194)
    在 winstone.RequestDispatcher.doFilter(RequestDispatcher.java:366)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:84)
    在 hudson.security.UnwrapSecurityExceptionFilter.doFilter(UnwrapSecurityExceptionFilter.java:51)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 org.acegisecurity.ui.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:124)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 org.acegisecurity.providers.anonymous.AnonymousProcessingFilter.doFilter(AnonymousProcessingFilter.java:125)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 org.acegisecurity.ui.rememberme.RememberMeProcessingFilter.doFilter(RememberMeProcessingFilter.java:142)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 org.acegisecurity.ui.AbstractProcessingFilter.doFilter(AbstractProcessingFilter.java:271)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 org.acegisecurity.ui.basicauth.BasicProcessingFilter.doFilter(BasicProcessingFilter.java:174)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 jenkins.security.ApiTokenFilter.doFilter(ApiTokenFilter.java:64)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 org.acegisecurity.context.HttpSessionContextIntegrationFilter.doFilter(HttpSessionContextIntegrationFilter.java:249)
    在 hudson.security.HttpSessionContextIntegrationFilter2.doFilter(HttpSessionContextIntegrationFilter2.java:67)
    在 hudson.security.ChainedServletFilter$1.doFilter(ChainedServletFilter.java:87)
    在 hudson.security.ChainedServletFilter.doFilter(ChainedServletFilter.java:76)
    在 hudson.security.HudsonFilter.doFilter(HudsonFilter.java:164)
    在 winstone.FilterConfiguration.execute(FilterConfiguration.java:194)
    在 winstone.RequestDispatcher.doFilter(RequestDispatcher.java:366)
    在 org.kohsuke.stapler.compression.CompressionFilter.doFilter(CompressionFilter.java:50)
    在 winstone.FilterConfiguration.execute(FilterConfiguration.java:194)
    在 winstone.RequestDispatcher.doFilter(RequestDispatcher.java:366)
    在 hudson.util.CharacterEncodingFilter.doFilter(CharacterEncodingFilter.java:81)
    在 winstone.FilterConfiguration.execute(FilterConfiguration.java:194)
    在 winstone.RequestDispatcher.doFilter(RequestDispatcher.java:366)
    在 winstone.RequestDispatcher.forward(RequestDispatcher.java:331)
    在 winstone.RequestHandlerThread.processRequest(RequestHandlerThread.java:227)
    在 winstone.RequestHandlerThread.run(RequestHandlerThread.java:150)
    在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
    在 java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
    在 java.util.concurrent.FutureTask.run(FutureTask.java:166)
    在 winstone.BoundedExecutorService$1.run(BoundedExecutorService.java:77)
    在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)
    在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    在 java.lang.Thread.run(Thread.java:679)
引起:com.thoughtworks.xstream.io.StreamException: : 在开始标记之前只允许空白内容,而不是 - (位置:看到 START_DOCUMENT -...@1:1)
    在 com.thoughtworks.xstream.io.xml.XppReader.pullNextEvent(XppReader.java:124)
    在 com.thoughtworks.xstream.io.xml.AbstractPullReader.readRealEvent(AbstractPullReader.java:148)
    在 com.thoughtworks.xstream.io.xml.AbstractPullReader.readEvent(AbstractPullReader.java:141)
    在 com.thoughtworks.xstream.io.xml.AbstractPullReader.move(AbstractPullReader.java:118)
    在 com.thoughtworks.xstream.io.xml.AbstractPullReader.moveDown(AbstractPullReader.java:103)
    在 com.thoughtworks.xstream.io.xml.XppReader.<init>(XppReader.java:63)
    在 com.thoughtworks.xstream.io.xml.AbstractXppDriver.createReader(AbstractXppDriver.java:54)
    在 com.thoughtworks.xstream.io.xml.AbstractXppDriver.createReader(AbstractXppDriver.java:65)
    在 com.thoughtworks.xstream.XStream.fromXML(XStream.java:925)
    在 hudson.XmlFile.read(XmlFile.java:143)
    ... 66 更多
原因:org.xmlpull.v1.XmlPullParserException:在开始标记之前只允许空白内容,而不是 - (位置:看到 START_DOCUMENT -...@1:1)
    在 org.xmlpull.mxp1.MXParser.parseProlog(MXParser.java:1519)
    在 org.xmlpull.mxp1.MXParser.nextImpl(MXParser.java:1395)
    在 org.xmlpull.mxp1.MXParser.next(MXParser.java:1093)
    在 com.thoughtworks.xstream.io.xml.XppReader.pullNextEvent(XppReader.java:109)
    ... 75 更多


由 Stapler 于 2013 年 6 月 7 日星期五 10:47:55 EDT 生成

我查看了我的 config.xml 文件,文件顶部没有空格。除此之外,我不确定它在说什么。我已经用谷歌搜索并查看了 SO,但没有找到与在 CLI 之外使用此 API 相关的任何内容。任何人有任何成功地做到这一点的经验或指针吗?

这是我向 API 发出的发布请求:

POST /createItem?name=Tes234t6.dev HTTP/1.1
Host: XXX.XXX.XXX.XXX:8080
Content-Type: text/xml
Authorization: Basic cm9vdDpjcm9zYnlhZG0xbg==
Cache-Control: no-cache

----WebKitFormBoundaryE19zNvXGzXaLvS5C
Content-Disposition: form-data; name="config.xml"; filename="config.xml"
Content-Type: text/xml


----WebKitFormBoundaryE19zNvXGzXaLvS5C
4

2 回答 2

0

事实证明,尽管 Jenkins API 说要发布“config.xml”,但您实际上并没有发送文件,而是发布了 xml 数据本身。

我这样做的方法是使用 chrome 的 Postman 插件,并将我的 config.xml 文件的内容直接添加到 RAW 输入中。这对我有用。

希望这可以减轻其他人的一些挫败感。

于 2013-06-07T21:18:52.460 回答
0

我也偶然发现了这个问题,但您的解决方案对我们不起作用。所以,如果有人在这里用谷歌搜索这个问题是另一种可能的解决方案。

我们的Jenkins前面有一个Apache(通过 AJP 连接)。使用 Jeknins 版本(或更低版本)时,一切正常。升级到或更高版本后,我们在尝试通过 REST-API 创建作业时遇到上述错误。这种情况并非一直发生,而是在 20 个创造就业机会中的 1 个中发生。1.5341.535

事实证明,这只发生在通过 Apache 调用 REST-API(然后使用 ajp 转发给 Jeknins)时。解决方案是直接对 Jenkins 进行 REST 调用。


注意:jenkins1.535及以上版本使用的是 Jetty 8。

于 2014-04-03T08:46:00.833 回答