【问题标题】:post database data via curl to php通过 curl 将数据库数据发布到 php
【发布时间】:2016-04-21 06:54:20
【问题描述】:

我正在尝试创建一个读取数据库表并通过 curl 将该表的行发布到 php 表单的 php 文件。

以下代码通过 curl 将表格的第一行发布到 php 文件。它不会遍历表的所有行并逐步发布它们。

<?php

define('DB_HOST', 'localhost'); 
define('DB_NAME', 'dbname'); 
define('DB_USER','dbuser'); 
define('DB_PASSWORD','dbpass'); 
$con=mysql_connect(DB_HOST,DB_USER,DB_PASSWORD) or die("Failed to connect to MySQL: " . mysql_error()); 
$db=mysql_select_db(DB_NAME,$con) or die("Failed to connect to MySQL: " . mysql_error()); 


$result = mysql_query("SELECT name,contact,city FROM customers; ");

while ($row = mysql_fetch_assoc($result)) {


$parts = explode(" ", $row[name]);
$lastname = array_pop($parts);
$firstname = implode(" ", $parts);

$gmail = "@gmail.com";
$email = $firstname.$lastname.$gmail ;

$particip = "aaa" ;


$fields = array(
    'fname' => rawurlencode($firstname),
    'lname' => rawurlencode($lastname),
    'mbl' => rawurlencode($row[contact]),
    'email' => rawurlencode($email),
    'city' => rawurlencode($row[city]),
    'e' => rawurlencode($particip)  
);




//extract data from the post
//set POST variables


$url = 'http://example.com/form.php';


//url-ify the data for the POST
foreach($fields as $key=>$value) { $fields_string .= $key.'='.$value.'&'; }
rtrim($fields_string, '&');

//open connection
$ch = curl_init();

//set the url, number of POST vars, POST data
curl_setopt($ch,CURLOPT_URL, $url);
curl_setopt($ch,CURLOPT_POST, count($fields));
curl_setopt($ch,CURLOPT_POSTFIELDS, $fields_string);

//execute post
$result1 = curl_exec($ch);

echo $result1;

//close connection
curl_close($ch);



}
?>

更新:这些值被发布到表单 php 文件中。从顶行到底行。但只获取数据库条目中的第一行。

在发布数据库数据的第二行之前,有什么方法可以刷新 $url 吗?

【问题讨论】:

    标签: php database post curl


    【解决方案1】:
    $fields[] = array(
        'fname' => rawurlencode($firstname),
        'lname' => rawurlencode($lastname),
        'mbl' => rawurlencode($row[contact]),
        'email' => rawurlencode($email),
        'city' => rawurlencode($row[city]),
        'e' => rawurlencode($particip)  
    );
    

    试试这个方法

    【讨论】:

    • 这些值没有发布到表单中。得到 0 或空输出。
    • 将 curl 代码移到 while 循环之外,一旦尝试回显您正在创建的字符串 $fields_string 是否获得正确的值。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-02-14
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多