PHP CURL DELETEリクエスト


100

PHPとcURLを使用してDELETE httpリクエストを実行しようとしています。

私は多くの場所でそれを行う方法を読みましたが、何もうまくいかないようです。

これが私のやり方です:

public function curl_req($path,$json,$req)
{
    $ch = curl_init($this->__url.$path);
    $data = json_encode($json);
    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $req);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json','Content-Length: ' . strlen($data)));
    $result = curl_exec($ch);
    $result = json_decode($result);
    return $result;
}

次に、先に進み、関数を使用します。

public function deleteUser($extid)
{
    $path = "/rest/user/".$extid."/;token=".$this->__token;
    $result = $this->curl_req($path,"","DELETE");
    return $result;

}

これにより、HTTP内部サーバーエラーが発生します。GETとPOSTで同じcurl_reqメソッドを使用する他の関数では、すべてがうまくいきます。

だから私は何が間違っているのですか?


3
内部サーバーエラーは、リクエストを受信するスクリプトに問題があったことを意味します。
ブラッド

ありがとうブラッド-私は知っている、それはDELETEリクエストとして送信しないためだと思います。Firefox用のRESTクライアントプラグインを使用し、DELETEを使用してまったく同じリクエストを送信すると、正常に動作します。したがって、cURLがリクエストをDELETEとして送信していないように見えます。
Bolli


マルクに感謝しますが、彼は私と同じことをしているように見えますか?PHPでDELETEリクエストを送信することは不可能ですか?cURLを使用しない別の方法がある場合は、それを使用することもできます。
Bolli

回答:


216

ようやく自分で解決しました。他の誰かがこの問題を抱えている場合、これが私の解決策です:

新しいメソッドを作成しました:

public function curl_del($path)
{
    $url = $this->__url.$path;
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "DELETE");
    $result = curl_exec($ch);
    $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
    curl_close($ch);

    return $result;
}

アップデート2

これは一部の人々を助けるように見えるので、JSONデコードされたオブジェクトでHTTP応答を返す私の最後のcurl DELETEメソッドを次に示します。

  /**
 * @desc    Do a DELETE request with cURL
 *
 * @param   string $path   path that goes after the URL fx. "/user/login"
 * @param   array  $json   If you need to send some json with your request.
 *                         For me delete requests are always blank
 * @return  Obj    $result HTTP response from REST interface in JSON decoded.
 */
public function curl_del($path, $json = '')
{
    $url = $this->__url.$path;
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "DELETE");
    curl_setopt($ch, CURLOPT_POSTFIELDS, $json);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    $result = curl_exec($ch);
    $result = json_decode($result);
    curl_close($ch);

    return $result;
}

この削除カールコードを保持し、その値をajaxから渡すphp(method:delete)へのajax呼び出しを行う方法を教えてください。
user1788736 2013

@ user1788736私はAjaxが得意ではありませんが、このメソッドを実行するPHPファイルを作成し、Ajaxを使用して、POSTを使用してそのPHPファイルにデータを送信できます。上記の方法がわかりにくいと思われる場合は、もう一度見てください。$ urlは、通信する必要のあるサーバー(someserver.com)であり、$ pathは、URLの後のもの(/ something /)です。これらを分割した唯一の理由は、動的パスを使用して常に同じサーバーに送信する必要があるためです。それが理にかなっていると思います。
Bolli 2013

ヘッダーは必要ありませんか?
er.irfankhan11

私は同じコードを使用していますが、Paypalはhttp code:204を返します。これは削除が成功したことを意味します。しかし、私は常に400を受け取りました。
er.irfankhan11

1
私のクラスのプライベート変数である@kuttoozz リクエストを行うために必要なURLです。api.someurl.comのようなもので、$ pathはそのURL(/ something /)の後に続きます。その値をURLに変更するか削除して、完全なURLを$ path変数に含めることができます。それは理にかなっていますか?
Bolli 2017年

19

GET、POST、DELETE、PUTを呼び出すために、すべての種類のリクエストで、1つの共通の関数を作成しました

function CallAPI($method, $api, $data) {
    $url = "http://localhost:82/slimdemo/RESTAPI/" . $api;
    $curl = curl_init($url);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);

    switch ($method) {
        case "GET":
            curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data));
            curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "GET");
            break;
        case "POST":
            curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data));
            curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST");
            break;
        case "PUT":
            curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data));
            curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "PUT");
            break;
        case "DELETE":
            curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "DELETE"); 
            curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data));
            break;
    }
    $response = curl_exec($curl);
    $data = json_decode($response);

    /* Check for 404 (file not found). */
    $httpCode = curl_getinfo($curl, CURLINFO_HTTP_CODE);
    // Check the HTTP Status code
    switch ($httpCode) {
        case 200:
            $error_status = "200: Success";
            return ($data);
            break;
        case 404:
            $error_status = "404: API Not found";
            break;
        case 500:
            $error_status = "500: servers replied with an error.";
            break;
        case 502:
            $error_status = "502: servers may be down or being upgraded. Hopefully they'll be OK soon!";
            break;
        case 503:
            $error_status = "503: service unavailable. Hopefully they'll be OK soon!";
            break;
        default:
            $error_status = "Undocumented error: " . $httpCode . " : " . curl_error($curl);
            break;
    }
    curl_close($curl);
    echo $error_status;
    die;
}

CALL Deleteメソッド

$data = array('id'=>$_GET['did']);
$result = CallAPI('DELETE', "DeleteCategory", $data);

CALL Postメソッド

$data = array('title'=>$_POST['txtcategory'],'description'=>$_POST['txtdesc']);
$result = CallAPI('POST', "InsertCategory", $data);

CALL Getメソッド

$data = array('id'=>$_GET['eid']);
$result = CallAPI('GET', "GetCategoryById", $data);

CALL Putメソッド

$data = array('id'=>$_REQUEST['eid'],m'title'=>$_REQUEST['txtcategory'],'description'=>$_REQUEST['txtdesc']);
$result = CallAPI('POST', "UpdateCategory", $data);

よくやった。注:削除のhttp応答コードは204です
。20x

0

wsse認証を使用した自分のクラスリクエスト

class Request {

    protected $_url;
    protected $_username;
    protected $_apiKey;

    public function __construct($url, $username, $apiUserKey) {
        $this->_url = $url;     
        $this->_username = $username;
        $this->_apiKey = $apiUserKey;
    }

    public function getHeader() {
        $nonce = uniqid();
        $created = date('c');
        $digest = base64_encode(sha1(base64_decode($nonce) . $created . $this->_apiKey, true));

        $wsseHeader = "Authorization: WSSE profile=\"UsernameToken\"\n";
        $wsseHeader .= sprintf(
            'X-WSSE: UsernameToken Username="%s", PasswordDigest="%s", Nonce="%s", Created="%s"', $this->_username, $digest, $nonce, $created
        );

        return $wsseHeader;
    }

    public function curl_req($path, $verb=NULL, $data=array()) {                    

        $wsseHeader[] = "Accept: application/vnd.api+json";
        $wsseHeader[] = $this->getHeader();

        $options = array(
            CURLOPT_URL => $this->_url . $path,
            CURLOPT_HTTPHEADER => $wsseHeader,
            CURLOPT_RETURNTRANSFER => true, 
            CURLOPT_HEADER => false             
        );                  

        if( !empty($data) ) {
            $options += array(
                CURLOPT_POSTFIELDS => $data,
                CURLOPT_SAFE_UPLOAD => true
            );                          
        }

        if( isset($verb) ) {
            $options += array(CURLOPT_CUSTOMREQUEST => $verb);                          
        }

        $ch = curl_init();
        curl_setopt_array($ch, $options);
        $result = curl_exec($ch);                   

        if(false === $result ) {
            echo curl_error($ch);
        }
        curl_close($ch);

        return $result; 
    }
}

array_mergeの+ = instaeadを使用
Adriwan Kenoby

それはおそらく機能しますが、問題に対する不必要に複雑な解決策です。
サミュエルリンドブロム2018

0

スイッチ($ method){ケース "GET":curl_setopt($ curl、CURLOPT_CUSTOMREQUEST、 "GET"); ブレーク; ケース "POST":curl_setopt($ curl、CURLOPT_CUSTOMREQUEST、 "POST"); ブレーク; ケース "PUT":curl_setopt($ curl、CURLOPT_CUSTOMREQUEST、 "PUT"); ブレーク; ケース "DELETE":curl_setopt($ curl、CURLOPT_CUSTOMREQUEST、 "DELETE"); ブレーク; }


-19
    $json empty

public function deleteUser($extid)
{
    $path = "/rest/user/".$extid."/;token=".$this->__token;
    $result = $this->curl_req($path,"**$json**","DELETE");
    return $result;

}

ありがとう。この特定のREST呼び出しでは、JSON部分を空にする必要があるため、これは問題ありません。とにかくありがとう
Bolli

$json emptyここはどういう意味ですか?とにかく、この関数内ではスコープ内にないので、の使用$jsonは何もしません。
ハーフタイム:

この回答を削除するように依頼しましたが、モデレーターはノーと言っています。とにかく、この回答の投稿者は2014年以降サインインしていません。
ハーフタイム:
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.