亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Wordpress WpForm自定義提交按鈕調用外部API(Json)

Wordpress WpForm自定義提交按鈕調用外部API(Json)

PHP
一只名叫tom的貓 2023-05-12 15:40:43
我想更改提交按鈕以能夠觸發 ajax 或任何可以將 POST 請求發送到另一臺服務器的東西(因為我想在另一臺服務器上管理從 wordpress 提交的所有數據)。Wordpress 只是帶有 webform 的簡單 UI 頁面,用于創建記錄并發送到另一臺服務器。我對PHP一無所知。我如何設法修改代碼以實現它?不要擔心 CORS 問題,因為我可以處理
查看完整描述

1 回答

?
慕后森

TA貢獻1802條經驗 獲得超5個贊

這就是你所需要的。


在您的主題 functions.php 文件中,您需要添加此 WPForms 操作,這將在您完成并提交表單時觸發。


add_action( 'wpforms_process_complete', 'sendingDataToJava', 10, 4 );


? ?function sendingDataToJava( $fields, $entry, $form_data, $entry_id) {


? ? //Specify WPForm ID you have there


? ? //if form ID is 1

? ? if (form_data[id] == 1) {


? ? ? $api_url = 'http://some java end point.com';

? ? ? $body = array(

? ? ? ? 'name'? ? ? ? ? ? ? ? => $fields['1']['value'],

? ? ? ? 'email'? ? ? ? ? ? ? ?=> $fields['2']['value'],

? ? ? ? 'phone'? ? ? ? ? ? ? ?=> $fields['3']['value'],


? ? ? ?);

? ? ? ?$request = wp_remote_post( $api_url, array( 'body' => $body ) );


? ? ?}

}

您將必須以您使用的形式查看 $fields id,并相應地在上面進行更改。您還需要弄清楚如何獲取 Java 端點文件中的數據。


其他方式


另一種方法是通過在 functions.php 中添加此操作來發出 ajax 請求


add_action( 'wp_ajax_foobar', 'sendingDataToJava' );

add_action( 'wp_ajax_nopriv_foobar', 'sendingDataToJava' );

function sendingDataToJava() {

? ? // do something


? ? // avoids extra 0 at the end of the response

? ? die(); /

}

在您的主題 JS 文件中添加此代碼


jQuery(document).ready(function($) {


? ?$('#form_button_id').click( function() {


? ? ? //

? ? ? var data = {

? ? ? ? ?name: $('#field_1').val(),

? ? ? ? ?email: $('#field_2').val(),

? ? ? ? ?phone: $('#field_3').val()

? ? ? };


? ? ? var ajaxurl = 'http://some java end point.com';

? ? ? jQuery.post(ajaxurl, data, function(response) {

? ? ? ? ?alert('Data Sent to Sent +' response);

? ? ? }

? ? ? );

? ?}

? ?);

}

);


查看完整回答
反對 回復 2023-05-12
  • 1 回答
  • 0 關注
  • 219 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號