ฉันจะขอใช้การรับรองความถูกต้องพื้นฐาน HTTP กับ PHP curl ได้อย่างไร


225

ฉันกำลังสร้างไคลเอนต์บริการเว็บ REST ใน PHP และตอนนี้ฉันใช้ curl เพื่อขอใช้บริการ

ฉันจะใช้ curl เพื่อขอรับรองความถูกต้อง (http พื้นฐาน) ได้อย่างไร ฉันต้องเพิ่มส่วนหัวด้วยตัวเองหรือไม่?

คำตอบ:


392

คุณต้องการสิ่งนี้:

curl_setopt($ch, CURLOPT_USERPWD, $username . ":" . $password);  

Zend มีไคลเอนต์ REST และ zend_http_client และฉันแน่ใจว่า PEAR มี wrapper บางประเภท แต่มันง่ายพอที่จะทำด้วยตัวเอง

ดังนั้นคำขอทั้งหมดอาจมีลักษณะดังนี้:

$ch = curl_init($host);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/xml', $additionalHeaders));
curl_setopt($ch, CURLOPT_HEADER, 1);
curl_setopt($ch, CURLOPT_USERPWD, $username . ":" . $password);
curl_setopt($ch, CURLOPT_TIMEOUT, 30);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $payloadName);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
$return = curl_exec($ch);
curl_close($ch);

สิ่งนี้ทำงานได้ดีกว่าจากนั้นตั้งค่าผู้ใช้และรหัสผ่านแยกต่างหาก
Kit Ramos

125

CURLOPT_USERPWDส่ง base64 ของuser:passwordสตริงโดยทั่วไปด้วยส่วนหัว http ดังนี้

Authorization: Basic dXNlcjpwYXNzd29yZA==

ดังนั้นนอกเหนือจากCURLOPT_USERPWDคุณยังสามารถใช้HTTP-Requestตัวเลือกส่วนหัวเช่นเดียวกับด้านล่างกับส่วนหัวอื่น ๆ :

$headers = array(
    'Content-Type:application/json',
    'Authorization: Basic '. base64_encode("user:password") // <---
);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

วิธีการส่งผ่านส่วนหัวรับรองความถูกต้องที่กำหนดเองนี้แทนที่จะใช้CURLOPT_USERPWDทำงานให้ฉัน
aalaap

40

วิธีที่ง่ายที่สุดและดั้งเดิมคือการใช้ CURL โดยตรง

สิ่งนี้ใช้ได้กับฉัน:

<?php
$login = 'login';
$password = 'password';
$url = 'http://your.url';
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_USERPWD, "$login:$password");
$result = curl_exec($ch);
curl_close($ch);  
echo($result);

7

แตกต่างจาก SOAP REST ไม่ใช่โปรโตคอลที่ได้มาตรฐานดังนั้นจึงค่อนข้างยากที่จะมี "REST Client" อย่างไรก็ตามเนื่องจาก RESTful บริการส่วนใหญ่ใช้ HTTP เป็นโปรโตคอลพื้นฐานของพวกเขาคุณควรจะสามารถใช้ไลบรารี HTTP ใด ๆ นอกจาก cURL แล้ว PHP ยังมีลูกแพร์ด้วย:

HTTP_Request2

ซึ่งแทนที่

HTTP_Request

ตัวอย่างวิธีการตรวจสอบสิทธิ์พื้นฐาน HTTP

// This will set credentials for basic auth
$request = new HTTP_Request2('http://user:password@www.example.com/secret/');

นอกจากนี้ยังสนับสนุน Digest Auth

// This will set credentials for Digest auth
$request->setAuth('user', 'password', HTTP_Request2::AUTH_DIGEST);

โดยลูกค้าส่วนที่เหลือฉันหมายถึงสิ่งที่เป็นนามธรรมออกไปบางส่วนของรายละเอียดในระดับต่ำของการใช้ curl สำหรับ http รับโพสต์วางลบ ฯลฯ ซึ่งเป็นสิ่งที่ฉันทำโดยการสร้างระดับ php ของตัวเองเพื่อทำสิ่งนี้; ฉันสงสัยว่ามีคนทำสิ่งนี้แล้ว
ว่างเปล่า

1
ใช่แล้ว HTTP_Request_2 อาจเป็นที่สนใจของคุณ มันสรุปสิ่งที่น่าเกลียดที่สุดของ cUrl ใน PHP ในการตั้งค่าวิธีการที่คุณใช้ให้ setMethod (HTTP_Request2 :: METHOD_ *) ด้วย PUT และ POST เพื่อตั้งค่าเนื้อความของคำขอคุณเพียงแค่ setBody (<< เป็นตัวแทนของ xml, json ฯลฯ ที่นี่ >>) การรับรองความถูกต้องอธิบายไว้ข้างต้น นอกจากนี้ยังมี abstractions สำหรับการตอบกลับ HTTP (สิ่งที่ cUrl ขาดจริง ๆ )
nategood

6

หากประเภทการอนุญาตคือ Basic auth และข้อมูลที่โพสต์เป็น json ให้ทำดังนี้

<?php

$data = array("username" => "test"); // data u want to post                                                                   
$data_string = json_encode($data);                                                                                   
 $api_key = "your_api_key";   
 $password = "xxxxxx";                                                                                                                 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_URL, "https://xxxxxxxxxxxxxxxxxxxxxxx");    
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 20);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");  
curl_setopt($ch, CURLOPT_POST, true);                                                                   
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);                                                                  
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);     
curl_setopt($ch, CURLOPT_USERPWD, $api_key.':'.$password);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC); 
curl_setopt($ch, CURLOPT_HTTPHEADER, array(   
    'Accept: application/json',
    'Content-Type: application/json')                                                           
);             

if(curl_exec($ch) === false)
{
    echo 'Curl error: ' . curl_error($ch);
}                                                                                                      
$errors = curl_error($ch);                                                                                                            
$result = curl_exec($ch);
$returnCode = (int)curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);  
echo $returnCode;
var_dump($errors);
print_r(json_decode($result, true));

4

Yahoo มีบทช่วยสอนเกี่ยวกับการโทรไปยังบริการ REST โดยใช้ PHP:

ทำ Yahoo! บริการเว็บ REST โทรด้วย PHP

ฉันไม่ได้ใช้ด้วยตนเอง แต่ Yahoo คือ Yahoo และควรรับประกันคุณภาพอย่างน้อยในระดับหนึ่ง พวกเขาดูเหมือนจะไม่ครอบคลุมคำขอ PUT และ DELETE

นอกจากนี้ผู้ใช้ที่ให้ข้อมูลกับ curl_exec ()และอื่น ๆ มีข้อมูลที่ดีมากมาย


4

คุณเพียงแค่ต้องระบุตัวเลือก CURLOPT_HTTPAUTH และ CURLOPT_USERPWD:

$curlHandler = curl_init();

$userName = 'postman';
$password = 'password';

curl_setopt_array($curlHandler, [
    CURLOPT_URL => 'https://postman-echo.com/basic-auth',
    CURLOPT_RETURNTRANSFER => true,

    CURLOPT_HTTPAUTH => CURLAUTH_BASIC,
    CURLOPT_USERPWD => $userName . ':' . $password,
]);

$response = curl_exec($curlHandler);
curl_close($curlHandler);

หรือระบุส่วนหัว:

$curlSecondHandler = curl_init();

curl_setopt_array($curlSecondHandler, [
    CURLOPT_URL => 'https://postman-echo.com/basic-auth',
    CURLOPT_RETURNTRANSFER => true,

    CURLOPT_HTTPHEADER => [
        'Authorization: Basic ' . base64_encode($userName . ':' . $password)
    ],
]);

$response = curl_exec($curlSecondHandler);
curl_close($curlSecondHandler);

ตัวอย่าง Guzzle:

use GuzzleHttp\Client;
use GuzzleHttp\RequestOptions;

$userName = 'postman';
$password = 'password';

$httpClient = new Client();

$response = $httpClient->get(
    'https://postman-echo.com/basic-auth',
    [
        RequestOptions::AUTH => [$userName, $password]
    ]
);

print_r($response->getBody()->getContents());

ดูhttps://github.com/andriichuk/php-curl-cookbook#basic-auth


3

Guzzleของ Michael Dowling ที่ได้รับการดูแลอย่างดีเป็นวิธีที่ดี นอกเหนือจากอินเตอร์เฟสที่หรูหราการโทรแบบอะซิงโครนัสและการปฏิบัติตาม PSR แล้วทำให้ส่วนหัวการตรวจสอบสิทธิ์สำหรับการโทร REST นั้นง่าย

// Create a client with a base URL
$client = new GuzzleHttp\Client(['base_url' => 'http://myservices.io']);

// Send a request to http://myservices.io/status with basic authentication
$response = $client->get('/status', ['auth' => ['username', 'password']]);

ดูเอกสาร


3

สำหรับผู้ที่ไม่ต้องการใช้ curl:

//url
$url = 'some_url'; 

//Credentials
$client_id  = "";
$client_pass= ""; 

//HTTP options
$opts = array('http' =>
    array(
        'method'    => 'POST',
        'header'    => array ('Content-type: application/json', 'Authorization: Basic '.base64_encode("$client_id:$client_pass")),
        'content' => "some_content"
    )
);

//Do request
$context = stream_context_create($opts);
$json = file_get_contents($url, false, $context);

$result = json_decode($json, true);
if(json_last_error() != JSON_ERROR_NONE){
    return null;
}

print_r($result);

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.