gpt4 book ai didi

php - 通过 jQuery + Ajax 将带有 Google reCaptcha v2 token 的图像文件发送到 PHP

转载 作者:行者123 更新时间:2023-12-04 09:30:57 31 4
gpt4 key购买 nike

我想使用 Google reCaptcha v2 验证通过 AJAX 发布和上传图像。但我面临一个问题,即我无法在 Ajax 中使用 google recaptcha token 发送带有标题文本的图像。据我所知,我编写了两个函数,但都不起作用。我做的函数是代码片段。
请帮助我如何使用 PHP/jQuery/AJAX 中的 reCaptcha token 在 Ajax 中发送带有文本的图像。

$(document).ready(function() {
$("form#addbanner").unbind("submit").bind("submit", function(e) {
//debugger;
e.preventDefault();
grecaptcha.ready(function() {
grecaptcha.execute('MY_RECAPTCHA_CODE', {
action: 'add_web_banner'
}).then(function(token) {
/*let formData = {
imagehere : $('input[name="imagehere"]').val(),
bannertitle : $('input[name="bannertitle"]').val(),
action : 'add_web_banner',
type: 'add_web_banner'
};*/ //not working

/*let formData = {
var formData = new FormData($("form#addWeb-Banner")[0]);
formData.append('token': token);
};*/ //not working

//*POST Image sent in (binary way), I dont want to use JSON in types*//

$.ajax({
type: 'POST',
data: formData,
cache: false,
success: function(response) {
hide_loader();
if (response.status == "success") {
$("form#addWeb-Banner")[0].reset();
alert("Great");
} else {
alert("Ops!");
}
},
});
});
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form class="bs-example form-horizontal AddWebBanner" id="addbanner" enctype="multipart/form-data" method="POST">
<div class="form-group col-sm-6">
<label class="col-lg-4 control-label">Upload Image</label>
<div class="col-lg-8">
<input type="file" class="form-control" title="Upload Photo" id="BannerImage" name="imagehere" accept="image/png,image/jpg,image/jpeg" />
</div>
</div>

<div class="form-group col-sm-6">
<label class="col-lg-4 control-label">Caption of Banner</label>
<div class="col-lg-8">
<input type="text" class="form-control" title="Caption of Banner" name="bannertitle" />
</div>
</div>

<div class="form-group">
<div class="col-md-12 col-lg-12">
<button type="submit" name="submit" class="btn btn-sm btn-default pull-right" id="addBannerBtn">POST</button>
</div>
</div>
</form>

最佳答案

将您的 HTML 和 formData 更改为以下内容
给一个 id 选择器你的标题横幅。

<input type="text" class="form-control" id="caption_banner" title="Caption of Banner" name="bannertitle" />
使用 formData 存储像这样然后通过 ajax 发送 formData
var formData = new FormData();

//Append Image
formData.append('file', $('#BannerImage')[0].files[0]);

//Append banner caption
formData.append('caption', $('#caption_banner').val());
您也可以使用 jQuery .serialize通过ajax将数据发送到后端的方法
var formData = $('form#addbanner').serialize()

关于php - 通过 jQuery + Ajax 将带有 Google reCaptcha v2 token 的图像文件发送到 PHP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62846200/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com