繁体   English   中英

通过Perl脚本登录Jenkins

[英]Logging into Jenkins via Perl script

我可以使用以下程序更改构建的描述。 这会将构建的描述更改为“FOO FOO FOO”。 不幸的是,我的登录不起作用。 现在,这个测试Jenkins构建服务器没有安全性。 但是,在我们的常规Jenkins服务器上,您需要登录才能更改构建的描述:

#! /usr/bin/env perl

use 5.12.0;
use warnings;

use LWP::UserAgent;
use HTTP::Request::Common qw(POST);
use Data::Dumper;

use constant {
    JENKINS_BASE            => "http://build.vegibank.com/",
    USER_ID                 => "buildguy",
    PASSWORD                => "swordfish",
};

use constant {
    LOGIN_URL               => JENKINS_BASE . '/j_acegi_security_check',
    JOB_URL                 => JENKINS_BASE . '/job',
    SUBMIT_DESCRIPTION      => 'submitDescription',
};

my $job_number = 4;
my $job_name   = "proginator-2.0";
my $description = "FOO FOO FOO";

my $user_agent = LWP::UserAgent->new or die qq(Can't get User Agent);

#
# My Login Stuff (but it doesn't do anything w/ security off
#

my $response = $user_agent->request (
    POST LOGIN_URL,
    [
        j_username => USER_ID,
        j_password => PASSWORD,
    ],
);

$response = $user_agent->request (
    POST "@{[JOB_URL]}/$job_name/$job_number/@{[SUBMIT_DESCRIPTION]}",
    [
        description => "$description",
    ],
);

我正在尝试连接到Jenkins登录会话,但我不相信我做得很对。 当我尝试登录时,我得到一个302响应以及我的响应对象的以下转储:

$VAR1 = bless( {
     '_protocol' => 'HTTP/1.1',
     '_content' => '',
     '_rc' => '302',
     '_headers' => bless( {
            'connection' => 'close',
            'client-response-num' => 1,
            'set-cookie' => 'JSESSIONID=1D5DF6FAF8714B2ACA4D496FBFE6E983; Path=/jenkins/; HttpOnly',
            'location' => 'http://build.vegicorp.com/;jsessionid=1D5DF6FAF8714B2ACA4D496FBFE6E983',
            'date' => 'Mon, 13 May 2013 20:02:35 GMT',
            'client-peer' => '10.10.21.96:80',
            'content-length' => '0',
            'client-date' => 'Mon, 13 May 2013 20:02:35 GMT',
            'content-type' => 'text/plain; charset=UTF-8',
            'server' => 'Apache-Coyote/1.1'
    }, 'HTTP::Headers' ),
     '_msg' => 'Moved Temporarily',
     '_request' => bless( {
            '_content' => 'j_username=buildguy&j_password=swordfish',
            '_uri' => bless( do{\(my $o = 'http://build.vegicorp.com/j_acegi_security_check')}, 'URI::http' ),
            '_headers' => bless( {
                   'user-agent' => 'libwww-perl/6.03',
                   'content-type' => 'application/x-www-form-urlencoded',
                   'content-length' => 42
     }, 'HTTP::Headers' ),
            '_method' => 'POST',
            '_uri_canonical' => $VAR1->{'_request'}{'_uri'}
     }, 'HTTP::Request' )
}, 'HTTP::Response' );

我想我必须打一个有效的页面,因为我得到一个302代码,但我的字段可能不正确(或者我要去错误的页面)。

有人可以帮忙吗?

我的授权失败了因为......技术术语是什么? 哦,是的...... “做错了。”

在谷歌搜索并获得了大量无用的垃圾之后,我,在一个百灵鸟上,决定看看詹金斯网站是否可能有这方面的东西。 并且,它在名为Authenticating scripted clients的页面下正确执行。 事实上,他们甚至为脚本客户端提供了Perl LWP示例

哈哈,我太努力了。 似乎Jenkins将使用基本的HTTP身份验证机制,而且我不需要通过试图弄清楚他们的登录表单是如何工作的。 显然,Jenkins正在为您简化基本的身份验证机制,即使您的身份验证机制远非基本 ​​- 就像一个好的程序应该做的那样。

所以,我所要做的就是使用基本的身份验证机制。

my $browser = LWP::UserAgent->new or die qq(Cannot get User Agent);
my $request = HTTP::Request->new;
$request->authorization_basic(USER_ID, PASSWORD);
$request->method("GET");
$request->url("$jenkins_url");
my $response = $browser->request($request);
if ( not $response->is_success ) {
    die qq(Something went horribly wrong...);
}

我在登录成功时看到了重定向 - 它设置会话cookie并将您重定向到主页面。

您的帖子可能会失败,因为UA对象不会持久保存会话cookie。 根据文档,'默认是没有cookie_jar,即永远不会自动为请求添加“Cookie”标题。 尝试:

my $ua = LWP::UserAgent->new( cookie_jar => HTTP::Cookies->new() );

为描述更改帖子存储和重用会话。

(另外,凭证在你的标题转储中可见,可能想要编辑...编辑:我是一个白痴,他们也在你的常数中,很可能是假的。)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM