在Wordpress中提交表单后,在后台运行功能

如何解决在Wordpress中提交表单后,在后台运行功能

我具有使用Ajax提交表单的功能。提交后,我得到了答复。

function myform() {
   //run script here

   // get the results and show in the console that the form submission was successful 
   echo json_encode($results);

   // now call another function to process a script in the background after response
   my_background_function();


}

现在的问题是,如果提交表单,则仅在完成功能my_background_function()后才会显示响应。

成功提交表单后如何运行“ my_background_function()”?

第一个功能中的整个代码是在mailchimp中创建组,并在databade中创建自定义数据表

// Import Subscriber batch
function maybe_insert_new_interest_groups() {
    //upload_file_callback();

    // Get Mailchimp Details
    $mcApi = $GLOBALS['mcApi'];
    $mcList = $GLOBALS['mcList'];
    $mcDC = $GLOBALS['mcDC'];
    $mcFolder = $GLOBALS['mcFolder'];
    
    // Get current user
    $current_user = $GLOBALS['current_user'];


    // get entered form data
    parse_str( $_POST['form_data'],$form_data );
    $postarr = array();
    $postarr = array_merge( $postarr,$form_data );

    $InterestCategoryID = get_option(LUBUVNA_PREFIX.'mc_interest_category');
    $groups = $form_data[LUBUVNA_PREFIX.'mc_interest_groups'];

    if ( !empty($groups) && !empty($InterestCategoryID) ){

        $addGroups = 'https://'. $mcDC . '.api.mailchimp.com/3.0/lists/' . $mcList . '/interest-categories' . '/' . $InterestCategoryID . '/interests';

        $lubuvnaIDstest = explode(",",$groups);

        $dataToUpdate = '';
        foreach($lubuvnaIDstest as $row) {
            
            $dataToUpdate = array (
                'name' => $row
            ); 


            $dataToUpdate = json_encode($dataToUpdate);
            $curl = curl_init();
            curl_setopt_array($curl,array(    
                CURLOPT_URL => $addGroups,CURLOPT_RETURNTRANSFER => true,CURLOPT_TIMEOUT => 30,CURLOPT_CUSTOMREQUEST => "POST",CURLOPT_POSTFIELDS => $dataToUpdate,CURLOPT_HTTPHEADER => array(
                    "authorization: apikey $mcApi"
                ),));
    
            $addedGroups = curl_exec($curl);
            $errorGroups = curl_error($curl);
            curl_close($curl);

        }

        $json = json_encode($addedGroups);
        $array = json_decode($addedGroups);


        $optionGroups = update_option( LUBUVNA_PREFIX.'mc_interest_groups',$groups );


    }


    
    global $wpdb;

    // needed for creating database table
    $charset_collate = $wpdb->get_charset_collate();
    // Table name
    $table_name = $wpdb->prefix . "lubuvna_subscribers";



    $sqlDrop = "DROP TABLE IF EXISTS $table_name";
    $wpdb->query($sqlDrop);



    // Get group names values - replace space with '_' and lowercase
    $listsValuesDel = get_option(LUBUVNA_PREFIX.'mc_interest_groups');
    $journalName = preg_replace('/\s+/','_',$listsValuesDel);
    $final_group_name = strtolower($journalName);
    $lubuvnaListsDel = explode(',',$final_group_name);
    $destinationsDel = '';
    
    // foreach value filter and output
    foreach($lubuvnaListsDel as $row){

        $destinationsDel .= 'gr_'."$row".' varchar(255),';
    }

    // create the table if it doesn't exist
    if($wpdb->get_var("show tables like '$table_name'") != $table_name) {

        $sql = "CREATE TABLE `{$wpdb->base_prefix}lubuvna_subscribers` (
        ID bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT,first_name varchar(255),last_name varchar(255),email varchar(255),phone varchar(255),birthday varchar(255),gender varchar(255),customer_type varchar(255),id_company_number varchar(255),street_address varchar(255),address_line_2 varchar(255),city varchar(255),state_area varchar(255),zip varchar(255),customer_from varchar(255),$destinationsDel
        last_visit varchar(255),send_sms varchar(255),send_email varchar(255),join_date varchar(255),post_author bigint(20),post_date DATETIME DEFAULT CURRENT_TIMESTAMP,post_modified DATETIME DEFAULT CURRENT_TIMESTAMP,post_status varchar(20) DEFAULT 'publish',PRIMARY KEY  (ID)
        ) $charset_collate;";

        require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
        dbDelta( $sql );
        $success = empty( $wpdb->last_error );

        $groupNames = array();
        // foreach group response in array
        foreach($lubuvnaListsDel as $row){
            $groupNames[] = $row;
        }

        // Response data
        $callback_database['status'] = '200';
        $callback_database['title'] = __("Table created","translate-newsletter");
        $callback_database['detail'] = __("Datatable and all groups were created successfully","translate-newsletter");
        $callback_database['groups'] = $groupNames;

    } else {

        $callback_database['status'] = '400';
        $callback_database['title'] = __("Table wans't created","translate-newsletter");

        if($wpdb->get_var("show tables like '$table_name'") == $table_name) {
        
            $callback_database['errors'][]['message'] = __("Datatable exists,thats why it wasn't created","translate-newsletter");
        
        } else {
        
            $callback_database['errors'][]['message'] = __("the Datatable wasn't created,contact page administrator","translate-newsletter");
        
        }

    }
    

    $callback_database_results = json_encode($callback_database,true);

    $response1 = json_decode($addedGroups,true);
    $response2 = json_decode($callback_database_results,true);
    $mergedResponses = array_merge( $response1,$response2 );

    $responseResults = json_encode($mergedResponses);


    echo $responseResults;
    exit(maybe_insert_new_merged_fields());
   
}
add_action( 'wp_ajax_new_interest_groups','maybe_insert_new_interest_groups' );



// the function that should run after the first function
function maybe_insert_new_merged_fields() {
   // some stuff here
}
//add_action( 'wp_ajax_new_merged_fields','maybe_insert_new_merged_fields' );

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res