Jenkins关闭跨站请求伪造保护(CSRF)配置

概述:

        今天在调用jenkins接口构建项目的时候,发现一直报403错误,报错信息:Error 403 No valid crumb was included in the request ,去jenkins官网搜索一番,发现是jenkins未关闭csrf认证导致的,在Configure Global Security配置中:关闭Crumb保存之后发现还是报同样的错误,后来发现Jenkins版本自2.2xx版本之后,csrf认证在web界面里已经没法关闭了(关闭也不生效):

官网解释:[JENKINS-61375] Cannot disable CSRF - Jenkins Jira

未关闭前:

完整报错信息:

[2023-06-16 11:24:28][ERROR][jenkins_api.py:86:start_job_build]:执行jenkins_job构建出现异常,异常原因:Error in request. Possibly authentication failed [403]: Forbidden
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=ISO-8859-1"/>
<title>Error 403 No valid crumb was included in the request</title>
</head>
<body><h2>HTTP ERROR 403 No valid crumb was included in the request</h2>
<table>
<tr><th>URI:</th><td>/job/haomo-lucas-web-test/buildWithParameters</td></tr>
<tr><th>STATUS:</th><td>403</td></tr>
<tr><th>MESSAGE:</th><td>No valid crumb was included in the request</td></tr>
<tr><th>SERVLET:</th><td>Stapler</td></tr>
</table>
<hr/><a href="https://eclipse.org/jetty">Powered by Jetty:// 10.0.13</a><hr/>

</body>
</html>

解决方案:

在jenkins的启动配置中添加参数:

-Dhudson.security.csrf.GlobalCrumbIssuerConfiguration.DISABLE_CSRF_PROTECTION=true

(1)使用容器运行的Jenkins

(1)进入容器,找到/usr/local/bin/jenkins.sh
(2)在该文件中的:
exec java -Duser.home="$JENKINS_HOME" ${FUTURE_OPTS} "${java_opts_array[@]}" -jar ${JENKINS_WAR} "${jenkins_opts_array[@]}" "$@"  一行中,

增加:
-Dhudson.security.csrf.GlobalCrumbIssuerConfiguration.DISABLE_CSRF_PROTECTION=true


[root@ops_test ~]# docker exec -it jenkins-master /bin/bash
jenkins@d1fffdb3323:/$
jenkins@d1fffdb3323:/$ vi /usr/local/bin/jenkins.sh
#修改后内容如下:
......
exec java -Duser.home="$JENKINS_HOME" -Dhudson.security.csrf.GlobalCrumbIssuerConfiguration.DISABLE_CSRF_PROTECTION=true ${FUTURE_OPTS} "${java_opts_array[@]}" -jar ${JENKINS_WAR} "${jenkins_opts_array[@]}" "$@"

(3)配置完成后重启Jenkins容器

(2) 使用war包运行的Jenkins

直接在启动脚本里面添加
-Dhudson.security.csrf.GlobalCrumbIssuerConfiguration.DISABLE_CSRF_PROTECTION=true 参数

export JENKINS_HOME=/mnt/jenkins_home
nohup java -Dhudson.security.csrf.GlobalCrumbIssuerConfiguration.DISABLE_CSRF_PROTECTION=true -jar jenkins.war > /dev/null 2>&1 &

配置完成后,重新启动Jenkins

关闭后,再次查看配置,关闭成功后如下图所示:

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 下面是一段使用Javascript调用Jenkins job并考虑Jenkins CSRF保护和CORS配置的示例代码: ```javascript var xhr = new XMLHttpRequest(); xhr.open("POST", "http://jenkins-server/job/job_name/build", true); xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xhr.setRequestHeader("Jenkins-Crumb", crumb); xhr.withCredentials = true; xhr.onreadystatechange = function() { if (xhr.readyState === XMLHttpRequest.DONE && xhr.status === 201) { console.log("Build triggered successfully."); } }; xhr.send("param1=value1&param2=value2"); ``` 在上面的代码中,`crumb` 变量是 Jenkins Crumb,需要通过其他方式获取(如请求 `http://jenkins-server/crumbIssuer/api/json` 获取)。而请求的参数(如 "param1=value1&param2=value2")是根据具体的 Jenkins job 所需要的参数来定义的。 需要注意的是,Jenkins的CORS配置需要在Jenkins服务器上进行,才能正常调用。如果CORS配置未正确配置,在使用上述代码可能会收到类似“No 'Access-Control-Allow-Origin' header is present on the requested resource”的错误消息。 ### 回答2: 要在Javascript中调用Jenkins job,需要考虑JenkinsCSRF保护和CORS配置。首先,CSRF保护Jenkins默认启用的,它会要求每个请求都包含一个有效的crumb token。而CORS配置是为了避免请求的限制。 以下是一段使用Javascript调用Jenkins job的示例代码,同时处理了CSRF保护和CORS配置问题: ```javascript // 1. 获取CSRF token function getCSRFToken(callback) { var xhr = new XMLHttpRequest(); xhr.open('GET', '/crumbIssuer/api/json', true); // crumbIssuer接口用于获取CSRF token xhr.onload = function() { if (xhr.status === 200) { var response = JSON.parse(xhr.responseText); var crumb = response.crumb; var crumbToken = response.crumbRequestField; callback(crumb, crumbToken); } }; xhr.send(); } // 2. 发送请求执行Jenkins job function executeJenkinsJob() { getCSRFToken(function(crumb, crumbToken) { var xhr = new XMLHttpRequest(); var url = '<Jenkins Job的URL>'; xhr.open('POST', url, true); xhr.setRequestHeader(crumbToken, crumb); // 添加CSRF token到header xhr.withCredentials = true; // 允许发送包含凭据的请求,以便进行身份验证 xhr.onload = function() { if (xhr.status === 200) { console.log('Jenkins job执行成功!') } else { console.error('Jenkins job执行失败!'); } }; xhr.onerror = function() { console.error('请求失败!'); }; xhr.send(); }); } executeJenkinsJob(); ``` 在上述代码中,`getCSRFToken`函数用于获取JenkinsCSRF token,并将token和crumbRequestField传递给回调函数。然后,在`executeJenkinsJob`函数中,我们通过创建一个XMLHttpRequest对象,设置请求的URL、headers,并发送请求来执行Jenkins job。设置`xhr.withCredentials`为true是为了让浏览器发送包含凭据的请求,以进行身份验证。 值得注意的是,如果需要域调用Jenkins job,还需要在Jenkins服务器上进行CORS配置,允许来自指定域的请求。具体配置可参考Jenkins的CORS插件文档或相关文档。 ### 回答3: 下面是一个使用JavaScript调用Jenkins job的示例代码,同时考虑了Jenkins CSRF Protection和CORS配置: ``` // 导入必要的模块 const fetch = require('node-fetch'); const btoa = require('btoa'); // 定义Jenkins的URL和认证信息 const jenkinsUrl = 'http://jenkins.example.com'; const username = 'your_username'; const password = 'your_password'; // 定义要调用的Jenkins job的信息 const jobName = 'your_job_name'; const buildParameters = { param1: 'value1', param2: 'value2' }; // 执行调用Jenkins job的函数 async function executeJenkinsJob() { try { // 获取CSRF Crumb const csrfCrumb = await fetch(`${jenkinsUrl}/crumbIssuer/api/json`, { method: 'GET', headers: { 'Authorization': `Basic ${btoa(`${username}:${password}`)}` } }).then(res => res.json()); // 配置CORS请求头 const headers = { 'Authorization': `Basic ${btoa(`${username}:${password}`)}`, 'Jenkins-Crumb': csrfCrumb.crumb }; // 构建请求URL const buildUrl = `${jenkinsUrl}/job/${jobName}/buildWithParameters?${new URLSearchParams(buildParameters).toString()}`; // 发起POST请求执行Jenkins job const response = await fetch(buildUrl, { method: 'POST', headers: headers }); // 检查请求响应状态码 if (response.ok) { console.log('Jenkins job执行成功!'); } else { console.error('Jenkins job执行失败!'); } } catch (error) { console.error('执行Jenkins job时发生错误:', error); } } // 调用executeJenkinsJob函数 executeJenkinsJob(); ``` 在这个示例代码中,我们首先使用`node-fetch`模块发送HTTP请求,通过GET请求获取JenkinsCSRF Crumb。然后,我们构建带有适当请求头的POST请求,以调用Jenkins job并传递构建参数。最后,我们根据响应状态码判断Jenkins job的执行结果。 请注意,示例代码中的`jenkinsUrl`、`username`和`password`变量需要根据实际情况进行修改。此外,这个示例代码在Node.js环境下运行,如果在浏览器中运行,可能需要进行一些额外的配置

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值