[英]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.