最近一直处于离职的状态,也没有面试。有些清净。但是我特别想研究一下jenkins。并把它跟java往起来拉一拉。
1.首先就是启动jenkins了。
我写了一个简单的脚本 java -jar jenkins.war --httpPort=9001
jenkins启动之后,需要登陆到jenkins,一般根据提示进入那个initpassword的地方寻找初始的密码,然后修改登录账户和密码即可。比较重要的一点是修改jenkins的系统配置:设置全局配置为允许用户注册、允许跨域。
为啥要设置这两个?
答:因为我们要在java代码上实现jenkins的注册功能,所以要允许用户注册。允许跨域?首先jenkins的跨域是通过jenkins-crumb的字段进行校验的,如果我们不采用跨域的方式,会使得我们在java端的代码会写很多,其实我也是这么想的,至于他的校验方式,我也是猜猜猜。但是你开启允许跨域之后,在发送jenkins的报文中肯定没有jenkins-crumb这个参数了。所以说,我们还是采用这种简单的允许跨域的模式吧。
2.捕获jenkins注册的请求
捕获的方法肯定是用用浏览器了。比如像我这样:
于是乎,我们知道了请求的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="zhuxinyao@yxsj.com.cn";
String jenkinsurl="http://127.0.0.1:9001/securityRealm/createAccount";
MultiValueMap<String,Object> 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<MultiValueMap<String,Object>> entity=new HttpEntity<>(param,header);
ResponseEntity<String> 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的用户:
总结:虽然这个技术很简单,但其实很有对以后分析问题很有帮助。希望可以一天多努力一点点。