java整合jenkins(一)

最近一直处于离职的状态,也没有面试。有些清净。但是我特别想研究一下jenkins。并把它跟java往起来拉一拉。

1.首先就是启动jenkins了。

我写了一个简单的脚本 java -jar jenkins.war --httpPort=9001

java整合jenkins(一)_第1张图片

jenkins启动之后,需要登陆到jenkins,一般根据提示进入那个initpassword的地方寻找初始的密码,然后修改登录账户和密码即可。比较重要的一点是修改jenkins的系统配置:设置全局配置为允许用户注册、允许跨域。

为啥要设置这两个?

答:因为我们要在java代码上实现jenkins的注册功能,所以要允许用户注册。允许跨域?首先jenkins的跨域是通过jenkins-crumb的字段进行校验的,如果我们不采用跨域的方式,会使得我们在java端的代码会写很多,其实我也是这么想的,至于他的校验方式,我也是猜猜猜。但是你开启允许跨域之后,在发送jenkins的报文中肯定没有jenkins-crumb这个参数了。所以说,我们还是采用这种简单的允许跨域的模式吧。

 java整合jenkins(一)_第2张图片

 

2.捕获jenkins注册的请求

 捕获的方法肯定是用用浏览器了。比如像我这样:

java整合jenkins(一)_第3张图片

于是乎,我们知道了请求的url,和上送的报文。所以,我们可以通过spring提供的restTemplate 来发送这个请求,这样。我们就可以通过java创建jenkins用户了。

3.java模拟发送jenkins创建用户的请求

@RestController
@ApiModel
public class test {

	@GetMapping(value="/test-jenkins")
	@ApiOperation(value="测试jenkins",notes="发送短信")
	public void sendSms() throws Exception{
		//smsService.sendMsg();
		RestTemplate restTemplate=new RestTemplate();
		String username="zhuxinyao";
		String password="zhuxinyao";
		String email="[email protected]";
		String jenkinsurl="http://127.0.0.1:9001/securityRealm/createAccount";
		MultiValueMap param=new LinkedMultiValueMap<>();
		param.add("username", username);
		param.add("password1", password);
		param.add("password2", password);
		param.add("fullname", username);
		param.add("email", email);
		HttpHeaders header=new HttpHeaders();
		header.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
		HttpEntity> entity=new HttpEntity<>(param,header);
		ResponseEntity resEntity=restTemplate.exchange(jenkinsurl, HttpMethod.POST,entity,String.class);
		boolean contains=response.getBody().contains(username);
		if(!contains){
			throw new Exception();
		}
		System.out.println(contains);
	}
}

 我们在swagger发送请求,然后返回200。然后去查看jenkins的用户:

java整合jenkins(一)_第4张图片

总结:虽然这个技术很简单,但其实很有对以后分析问题很有帮助。希望可以一天多努力一点点。 

 

你可能感兴趣的:(脚手架问题集合)