Heim > Backend-Entwicklung > PHP-Tutorial > PHP CURL CURLOPT-Parameterbeschreibung (curl_setopt)

PHP CURL CURLOPT-Parameterbeschreibung (curl_setopt)

高洛峰
Freigeben: 2023-03-04 07:56:01
Original
1561 Leute haben es durchsucht

CURLOPT_RETURNTRANSFER-Optionen:

curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);

Bei Erfolg wird nur das Ergebnis zurückgegeben und nichts automatisch ausgegeben.

Gib FALSE zurück, wenn es fehlschlägt

curl_setopt($ch, CURLOPT_RETURNTRANSFER,0); Oder verwenden Sie diese Option nicht:

Gib nur TRUE zurück, wenn es erfolgreich ist, und gebe den zurückgegebenen Inhalt automatisch aus .

Gibt FALSE zurück, wenn ein Fehler auftritt

Einige Parameter der Funktion „curl_setopt()“ der CURL-Methode in PHP.

bool curl_setopt (int ch, string option, gemischter Wert)curl_setopt() legt Optionen für eine CURL-Sitzung fest. Der Optionsparameter ist die gewünschte Einstellung und der Wert ist der von dieser Option angegebene Wert.

Die Werte der folgenden Optionen werden als lange Ganzzahlen verwendet (angegeben im Optionsparameter): CURLOPT_INFILESIZE: Wenn Sie eine Datei auf die Remote-Site hochladen, teilt diese Option PHP mit, dass Sie es sind Hochladen der Dateigröße.
• CURLOPT_VERBOSE: Wenn Sie möchten, dass CURL jedes unerwartete Ereignis meldet, legen Sie diese Option auf einen Wert ungleich Null fest.
• CURLOPT_HEADER: Wenn Sie einen Header in die Ausgabe einschließen möchten, legen Sie diese Option auf einen Wert ungleich Null fest.
• CURLOPT_NOPROGRESS: Wenn Sie nicht möchten, dass PHP einen Fortschrittsbalken für CURL-Übertragungen anzeigt, setzen Sie diese Option auf einen Wert ungleich Null. Hinweis: PHP setzt diese Option automatisch auf einen Wert ungleich Null. Sie sollten diese Option nur zu Debugging-Zwecken ändern.
• CURLOPT_NOBODY: Wenn Sie den Körperteil nicht in die Ausgabe einbeziehen möchten, setzen Sie diese Option auf einen Wert ungleich Null.
• CURLOPT_FAILONERROR: Wenn Sie möchten, dass PHP nicht angezeigt wird, wenn ein Fehler auftritt (HTTP-Code-Rückgabe größer oder gleich 300), legen Sie diese Option auf einen Wert ungleich Null fest. Das Standardverhalten besteht darin, eine normale Seite zurückzugeben und den Code zu ignorieren.
• CURLOPT_UPLOAD: Wenn Sie möchten, dass PHP sich auf das Hochladen vorbereitet, setzen Sie diese Option auf einen Wert ungleich Null.
• CURLOPT_POST: Wenn Sie möchten, dass PHP einen regulären HTTP-POST durchführt, setzen Sie diese Option auf einen Wert ungleich Null. Dieser POST ist vom gewöhnlichen Typ application/x-www-from-urlencoded und wird hauptsächlich von HTML-Formularen verwendet.
• CURLOPT_FTPLISTONLY: Setzen Sie diese Option auf einen Wert ungleich Null und PHP listet die Verzeichnisnamen von FTP auf.
• CURLOPT_FTPAPPEND: Setzen Sie diese Option auf einen Wert ungleich Null und PHP wendet die Remote-Datei an, anstatt sie zu überschreiben.
• CURLOPT_NETRC: Setzen Sie diese Option auf einen Wert ungleich Null und PHP sucht in Ihrer ~./netrc-Datei nach dem Benutzernamen und Passwort der Remote-Site, zu der Sie eine Verbindung herstellen möchten.
• CURLOPT_FOLLOWLOCATION: Setzen Sie diese Option auf einen Header ungleich Null (z. B. „Standort:“), und der Server sendet ihn als Teil des HTTP-Headers (beachten Sie, dass dies rekursiv ist. PHP sendet etwa „Standort:“). " Kopf).
• CURLOPT_PUT: Setzen Sie diese Option auf einen Wert ungleich Null, um eine Datei über HTTP hochzuladen. Um diese Datei hochzuladen, müssen die Optionen CURLOPT_INFILE und CURLOPT_INFILESIZE gesetzt sein.
• CURLOPT_MUTE: Setzen Sie diese Option auf einen Wert ungleich Null, und PHP wird für die CURL-Funktion völlig stumm sein.
• CURLOPT_TIMEOUT: Legen Sie eine lange Ganzzahl als maximale Anzahl von Sekunden fest.
• CURLOPT_LOW_SPEED_LIMIT: Legen Sie eine lange Ganzzahl fest, um zu steuern, wie viele Bytes übertragen werden.
• CURLOPT_LOW_SPEED_TIME: Legen Sie eine lange Ganzzahl fest, um zu steuern, wie viele Sekunden die durch CURLOPT_LOW_SPEED_LIMIT angegebene Anzahl von Bytes übertragen werden soll.
• CURLOPT_RESUME_FROM: Übergeben Sie einen langen ganzzahligen Parameter, der die Byte-Offset-Adresse enthält (das Startformular, zu dem Sie übertragen möchten).
• CURLOPT_SSLVERSION: Übergeben Sie einen langen Parameter, der die SSL-Version enthält. Standardmäßig erledigt PHP seine eigene harte Arbeit, für mehr Sicherheit müssen Sie es manuell festlegen.
• CURLOPT_TIMECONDITION: Übergeben Sie einen langen Parameter, um anzugeben, wie mit dem Parameter CURLOPT_TIMEVALUE umgegangen werden soll. Sie können diesen Parameter auf TIMECOND_IFMODSINCE oder TIMECOND_ISUNMODSINCE setzen. Dies gilt nur für HTTP.
• CURLOPT_TIMEVALUE: Übergeben Sie eine Anzahl von Sekunden vom 1.1.1970 bis heute. Diese Zeit wird als angegebener Wert von der Option CURLOPT_TIMEVALUE oder vom Standardwert TIMECOND_IFMODSINCE verwendet.

Die Werte der folgenden Optionen werden als Zeichenfolgen behandelt:
• CURLOPT_URL: Dies ist die URL-Adresse, die Sie mit PHP abrufen möchten. Sie können diese Option auch während der Initialisierung mit der Funktion „curl_init()“ festlegen.
• CURLOPT_USERPWD: Übergeben Sie eine Zeichenfolge in der Form [Benutzername]:[Passwort] und verwenden Sie PHP, um eine Verbindung herzustellen.
• CURLOPT_PROXYUSERPWD: Übergeben Sie eine Zeichenfolge im Format [Benutzername]:[Passwort], um eine Verbindung zum HTTP-Proxy herzustellen.
• CURLOPT_RANGE: Übergeben Sie einen Bereich, den Sie angeben möchten. Es sollte im Format „X-Y“ vorliegen, wobei X oder Y ausgeschlossen sind. HTTP-Übertragungen unterstützen auch mehrere durch Kommas getrennte Intervalle (X-Y, N-M).
• CURLOPT_POSTFIELDS: Übergeben Sie eine Zeichenfolge, die alle Daten enthält, als HTTP-„POST“-Operation.
• CURLOPT_REFERER: Eine Zeichenfolge, die einen „Referer“-Header in der HTTP-Anfrage enthält.
• CURLOPT_USERAGENT: Eine Zeichenfolge, die einen „User-Agent“-Header in der HTTP-Anfrage enthält.
• CURLOPT_FTPPORT: Übergeben Sie eine IP-Adresse, die die vom FTP-Befehl „POST“ verwendete IP-Adresse enthält. Diese POST-Anweisung weist den Remote-Server an, eine Verbindung zu der von uns angegebenen IP-Adresse herzustellen. Diese Zeichenfolge kann eine IP-Adresse, ein Hostname, ein Netzwerkschnittstellenname (unter UNIX) oder „-“ (verwenden Sie die Standard-IP-Adresse des Systems) sein.
• CURLOPT_COOKIE: Übergeben Sie eine Header-Verbindung, die ein HTTP-Cookie enthält.
• CURLOPT_SSLCERT: Übergeben Sie eine Zeichenfolge, die das Zertifikat im PEM-Format enthält.
• CURLOPT_SSLCERTPASSWD: Übergeben Sie ein Passwort, das das erforderliche Passwort zur Verwendung des CURLOPT_SSLCERT-Zertifikats enthält.
• CURLOPT_COOKIEFILE: Übergeben Sie eine Zeichenfolge mit dem Namen der Datei, die Cookie-Daten enthält. Diese Cookie-Datei kann im Netscape-Format vorliegen oder ein Stapel von in der Datei gespeicherten HTTP-Headern sein.
• CURLOPT_CUSTOMREQUEST: Übergeben Sie bei einer HTTP-Anfrage ein Zeichen, das von GET oder HEAD verwendet werden soll. Übergeben Sie eine Zeichenfolge, die anstelle von GET oder HEAD verwendet werden soll, wenn Sie eine HTTP-Anfrage ausführen. Hinweis: Stellen Sie sicher, dass Ihr Server Order unterstützt, um dies noch nicht zu tun. Die folgenden Optionen erfordern eine Dateibeschreibung (erhalten mit der Funktion fopen()):
• CURLOPT_FILE: Diese Datei ist die Ausgabedatei, in der Sie die Übertragung platzieren. Der Standardwert ist STDOUT sei die Ausgabedatei, die Sie übertragen.
• CURLOPT_WRITEHEADER: Diese Datei enthält den Header-Teil Ihrer Ausgabe.
• CURLOPT_STDERR: In dieser Datei werden Fehler anstelle von „stderr“ geschrieben. Beispiel zum Abrufen von Seiten, die eine Anmeldung erfordern. Die aktuelle Methode besteht darin, sich jedes Mal einmal anzumelden.

Beispiel 1:

$cookie_jar = tempnam('./tmp','cookie');
$ch = curl_init(); curl_setopt($ch,CURLOPT_URL, 'http://******');
curl_setopt($ch, CURLOPT_POST, 1);
$request = 'email_address=&password=&action=';
curl_setopt($ch, CURLOPT_POSTFIELDS, $request); //把返回来的cookie信息保存在$cookie_jar文件中
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_jar); //设定返回的数据是否自动显示
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //设定是否显示头信息
curl_setopt($ch, CURLOPT_HEADER, false); //设定是否输出页面内容
curl_setopt($ch, CURLOPT_NOBODY, false);
curl_exec($ch);
curl_close($ch); //get data after login
Nach dem Login kopieren
Beispiel 2:

$ch2 = curl_init();
curl_setopt($ch2, CURLOPT_URL, 'http://*****');
curl_setopt($ch2, CURLOPT_HEADER, false);
curl_setopt($ch2, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch2, CURLOPT_COOKIEFILE, $cookie_jar);
$orders = curl_exec($ch2);
echo '';
echo strip_tags($orders);
echo '';
curl_close($ch2); 实践证明很稳定:)
Nach dem Login kopieren
Beispiel 3:

set_time_limit(0);
function _rand() {
$length=26;
$chars = "0123456789abcdefghijklmnopqrstuvwxyz";
$max = strlen($chars) - 1;
mt_srand((double)microtime() * 1000000);
$string = '';
for($i = 0; $i < $length; $i++) {
$string .= $chars[mt_rand(0, $max)];
}
return $string;
}
$HTTP_SESSION=_rand();
echo $HTTP_SESSION;
$HTTP_Server="www.baidu.com";
$HTTP_URL="/";
$ch = curl_init();
curl_setopt ($ch,CURLOPT_URL,"http://".$HTTP_Server.$HTTP_URL);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);
curl_setopt($ch,CURLOPT_USERAGENT,"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)");
//curl_setopt($ch,CURLOPT_COOKIE,$HTTP_SESSION);
$res = curl_exec($ch);
curl_close ($ch);
print_r($res);
Nach dem Login kopieren
Flash-Forum-Code:

1. Cookie-Erfassungsprogramm:

$URL="http://www.yoururl.com/bbs/login.asp?action=chk";
//填入论坛的登陆页面地址
$ch = curl_init();
curl_setopt($ch,CURLOPT_URL,$URL);
curl_setopt($ch,CURLOPT_REFERER,"http://www.hxfoods.com/bbs/login.asp");
//设置,访问页面的来源地址
curl_setopt($ch,CURLOPT_POST,1);
curl_setopt($ch,CURLOPT_POSTFIELDS,&#39;username=→→敢死队→&password=168168&#39;);
//分析登陆页面,把用户名,密码分别对应起来
curl_setopt ($ch, CURLOPT_HEADER,true);
//使能显示http头,
curl_exec($ch);
if (curl_errno($ch))
{
print curl_error($ch);
}
else
{
curl_close($ch);
}
Nach dem Login kopieren
2. Reinigen Sie das Gebäude:

set_time_limit(0);
//设置程序执行时间无限制
$i=10000;
//耍10000次
for($j=0;$j<$i;$j++)
{
$URL="http://www.yoururl.com/bbs/savepost.asp";
//这个地址是回复表单里面action的url地址
$ch = curl_init();
curl_setopt($ch,CURLOPT_URL,$URL);
curl_setopt($ch,CURLOPT_REFERER,"http://www.hxfoods.com/bbs/dispbbs.asp?boardid=14&replyid=672709&id=127437&page=1&skin=0&Star=53");
//设置来源地址,如果不设置,论坛服务器有可能有验证不允许回复
curl_setopt($ch,CURLOPT_COOKIESESSION,true);
//能保存cookie
curl_setopt($ch,CURLOPT_COOKIE,"DvForum=userid=24122&usercookies=0&userhidden=2&password=w0reu3g775VrY745&userclass=%96%7C&username=%A1%FA%A1%FA%B8%D2%CB%C0%B6%D3%A1%FA&StatUserID=2194783945 ");
//这儿就是设置cookie了
curl_setopt($ch,CURLOPT_POST,1);
curl_setopt($ch,CURLOPT_NOBODY,1);
//不显示内容,因为有很多论坛回复后要自动跳转。
curl_setopt($ch,CURLOPT_POSTFIELDS,&#39;Body=gfdfgdfgasdfgdfgdfgdfg& followup=672709&RootID=127437&star=58&TotalUseTable=Dv_bbs3& amp;UserName=→→敢死队→&signflag=1&total=65535&#39;);
//把你分析的回复表单的参数分别赋值
curl_setopt ($ch, CURLOPT_HEADER,true);
curl_exec($ch);
if (curl_errno($ch))
{
print curl_error($ch);
}
else
{
curl_close($ch);
}
}
Nach dem Login kopieren
curl_close – Eine Curl-Sitzung schließen

curl_copy_handle – Alle Inhalte und Parameter einer Curl-Verbindungsressource kopieren
curl_errno – Eine numerische Zahl mit Fehlerinformationen für die aktuelle Sitzung zurückgeben
curl_error – Zurückgeben Eine Zeichenfolge mit Fehlerinformationen für die aktuelle Sitzung
curl_exec – Eine Curl-Sitzung ausführen
curl_getinfo – Informationen über ein Curl-Verbindungsressourcenhandle abrufen
curl_init – Eine Curl-Sitzung initialisieren
curl_multi_add_handle – Stapelsitzungen zum Hinzufügen von Curls eine separate Curl-Handle-Ressource
curl_multi_close – Eine Batch-Handle-Ressource schließen
curl_multi_exec – Ein Curl-Batch-Handle analysieren
curl_multi_getcontent – ​​Den Textstrom der erhaltenen Ausgabe zurückgeben
curl_multi_info_read – Die aktuell analysierte Curl-bezogene Übertragung abrufen information
curl_multi_init – Eine Curl-Batch-Handle-Ressource initialisieren
curl_multi_remove_handle – Eine Handle-Ressource in der Curl-Batch-Handle-Ressource entfernen
curl_multi_select – Alle mit der cURL-Erweiterung verknüpften Sockets abrufen, die dann „ausgewählt“ werden können
curl_setopt_array – Sitzungsparameter für einen Curl in Form eines Arrays festlegen
curl_setopt – Sitzungsparameter für einen Curl festlegen
curl_version – Curl-bezogene Versionsinformationen abrufen
curl_init() Die Funktion der Funktion ist zum Initialisieren einer Curl-Sitzung. Der einzige Parameter der Funktion „curl_init()“ ist optional und stellt eine URL-Adresse dar.
Die Funktion „curl_exec()“ wird zum Ausführen einer Curl-Sitzung verwendet. Der einzige Parameter ist das von der Funktion „curl_init()“ zurückgegebene Handle.
Die Funktion „curl_close()“ wird zum Schließen einer Curl-Sitzung verwendet. Der einzige Parameter ist das von der Funktion „curl_init()“ zurückgegebene Handle.

$ch = curl_init("http://www.baidu.com/");

curl_exec($ch);
curl_close($ch);
curl_version() Funktion Die Funktion dient zum Abrufen von Curl-bezogenen Versionsinformationen. Es ist unklar, was sie tut Um eine Curl-Verbindung zu erhalten, verfügt die Funktion „curl_getinfo()“ über zwei Parameter. Der erste Parameter ist der Curl-Ressourcen-Handle und der zweite Parameter sind die folgenden Konstanten:

$ch = curl_init("http://www.baidu.com/");
print_r(curl_getinfo($ch));
Optionale Konstanten umfassen:
CURLINFO_EFFECTIVE_URL
Die letzte gültige URL-Adresse
CURLINFO_HTTP_CODE
Der zuletzt empfangene HTTP-Code
CURLINFO_FILETIME
Die Zeit, um das Dokument aus der Ferne abzurufen. Wenn es nicht abgerufen werden kann, ist der Rückgabewert „-1“
CURLINFO_TOTAL_TIME
Zeitaufwand für die letzte Übertragung
CURLINFO_NAMELOOKUP_TIME
Zeitaufwand für die Namensauflösung
CURLINFO_CONNECT_TIME
Zeitaufwand für den Verbindungsaufbau
CURLINFO_PRETRANSFER_TIME
Zeitaufwand vom Verbindungsaufbau bis zur Vorbereitung der Übertragung Die Zeit
CURLINFO_STARTTRANSFER_TIME
Die Zeit, die vom Verbindungsaufbau bis zum Beginn der Übertragung benötigt wird
CURLINFO_REDIRECT_TIME
Die Zeit, die für die Umleitung benötigt wird, bevor die Transaktionsübertragung beginnt
CURLINFO_SIZE_UPLOAD
Die Gesamtmenge der hochgeladenen Daten Daten
CURLINFO_SIZE_DOWNLOAD
Gesamtwert der heruntergeladenen Daten
CURLINFO_SPEED_DOWNLOAD
Durchschnittliche Download-Geschwindigkeit
CURLINFO_SPEED_UPLOAD
Durchschnittliche Upload-Geschwindigkeit
CURLINFO_HEADER_SIZE
Größe des Header-Teils
C URLIN FO_HEADER_OUT
Angeforderte Zeichenfolge senden
CURLINFO_REQUEST_SIZE
Die angeforderte Größe in der HTTP-Anfrage
CURLINFO_SSL_VERIFYRESULT
Ergebnis der SSL-Zertifizierungsüberprüfung, die durch Festlegen von CURLOPT_SSL_VERIFYPEER angefordert wurde
CURLINFO_CONTENT_LENGTH_DOWNLOAD
Von -Länge: Die im Feld abgelesene Länge des heruntergeladenen Inhalts
CURLINFO_CONTENT_LENGTH_UPLOAD
Beschreibung der Größe des hochgeladenen Inhalts
CURLINFO_CONTENT_TYPE

Der „Inhaltstyp“-Wert des heruntergeladenen Inhalts, NULL bedeutet das Der Server hat keinen gültigen „Content -Type: Header“ gesendet

Die Funktion „curl_setopt()“ wird verwendet, um Sitzungsparameter für einen Curl festzulegen. Die Funktion „curl_setopt_array()“ wird verwendet, um Sitzungsparameter für einen Curl in Form eines Arrays festzulegen.

$ch = curl_init();
$fp = fopen("example_homepage.txt", "w");
curl_setopt($ch, CURLOPT_FILE, $fp);
$options = array(
CURLOPT_URL => &#39;http://www.baidu.com/&#39;,
CURLOPT_HEADER => false
);
curl_setopt_array($ch, $options);
curl_exec($ch);
curl_close($ch);
fclose($fp);
Nach dem Login kopieren

可设置的参数有:
CURLOPT_AUTOREFERER
自动设置header中的referer信息
CURLOPT_BINARYTRANSFER
在启用CURLOPT_RETURNTRANSFER时候将获取数据返回
CURLOPT_COOKIESESSION
启用时curl会仅仅传递一个session cookie,忽略其他的cookie,默认状况下curl会将所有的cookie返回给服务端。session cookie是指那些用来判断服务器端的session是否有效而存在的cookie。
CURLOPT_CRLF
启用时将Unix的换行符转换成回车换行符。
CURLOPT_DNS_USE_GLOBAL_CACHE
启用时会启用一个全局的DNS缓存,此项为线程安全的,并且默认为true。
CURLOPT_FAILONERROR
显示HTTP状态码,默认行为是忽略编号小于等于400的HTTP信息
CURLOPT_FILETIME
启用时会尝试修改远程文档中的信息。结果信息会通过curl_getinfo()函数的CURLINFO_FILETIME选项返回。
CURLOPT_FOLLOWLOCATION
启用时会将服务器服务器返回的“Location:”放在header中递归的返回给服务器,使用CURLOPT_MAXREDIRS可以限定递归返回的数量。
CURLOPT_FORBID_REUSE
在完成交互以后强迫断开连接,不能重用。
CURLOPT_FRESH_CONNECT
强制获取一个新的连接,替代缓存中的连接。
CURLOPT_FTP_USE_EPRT
TRUE to use EPRT (and LPRT) when doing active FTP downloads. Use FALSE to disable EPRT and LPRT and use PORT only.
Added in PHP 5.0.0.
CURLOPT_FTP_USE_EPSV
TRUE to first try an EPSV command for FTP transfers before reverting back to PASV. Set to FALSE to disable EPSV.
CURLOPT_FTPAPPEND
TRUE to append to the remote file instead of overwriting it.
CURLOPT_FTPASCII
An alias of CURLOPT_TRANSFERTEXT. Use that instead.
CURLOPT_FTPLISTONLY
TRUE to only list the names of an FTP directory.
CURLOPT_HEADER
启用时会将头文件的信息作为数据流输出。
CURLOPT_HTTPGET
启用时会设置HTTP的method为GET,因为GET是默认是,所以只在被修改的情况下使用。
CURLOPT_HTTPPROXYTUNNEL
启用时会通过HTTP代理来传输。
CURLOPT_MUTE
讲curl函数中所有修改过的参数恢复默认值。
CURLOPT_NETRC
在连接建立以后,访问~/.netrc文件获取用户名和密码信息连接远程站点。
CURLOPT_NOBODY
启用时将不对HTML中的body部分进行输出。
CURLOPT_NOPROGRESS
启用时关闭curl传输的进度条,此项的默认设置为true
CURLOPT_NOSIGNAL
启用时忽略所有的curl传递给php进行的信号。在SAPI多线程传输时此项被默认打开。
CURLOPT_POST
启用时会发送一个常规的POST请求,类型为:application/x-www-form-urlencoded,就像表单提交的一样。
CURLOPT_PUT
启用时允许HTTP发送文件,必须同时设置CURLOPT_INFILE和CURLOPT_INFILESIZE
CURLOPT_RETURNTRANSFER
讲curl_exec()获取的信息以文件流的形式返回,而不是直接输出。
CURLOPT_SSL_VERIFYPEER
FALSE to stop cURL from verifying the peer's certificate. Alternate certificates to verify against can be specified with the CURLOPT_CAINFO option or a certificate directory can be specified with the CURLOPT_CAPATH option. CURLOPT_SSL_VERIFYHOST may also need to be TRUE or FALSE if CURLOPT_SSL_VERIFYPEER is disabled (it defaults to 2). TRUE by default as of cURL 7.10. Default bundle installed as of cURL 7.10.
CURLOPT_TRANSFERTEXT
TRUE to use ASCII mode for FTP transfers. For LDAP, it retrieves data in plain text instead of HTML. On Windows systems, it will not set STDOUT to binary mode.
CURLOPT_UNRESTRICTED_AUTH
在使用CURLOPT_FOLLOWLOCATION产生的header中的多个locations中持续追加用户名和密码信息,即使域名已发生改变。
CURLOPT_UPLOAD
启用时允许文件传输
CURLOPT_VERBOSE
启用时会汇报所有的信息,存放在STDERR或指定的CURLOPT_STDERR中
CURLOPT_BUFFERSIZE
每次获取的数据中读入缓存的大小,这个值每次都会被填满。
CURLOPT_CLOSEPOLICY
不是CURLCLOSEPOLICY_LEAST_RECENTLY_USED就是CURLCLOSEPOLICY_OLDEST,还存在另外三个,但是curl暂时还不支持。.
CURLOPT_CONNECTTIMEOUT
在发起连接前等待的时间,如果设置为0,则不等待。
CURLOPT_DNS_CACHE_TIMEOUT
设置在内存中保存DNS信息的时间,默认为120秒。
CURLOPT_FTPSSLAUTH
The FTP authentication method (when is activated): CURLFTPAUTH_SSL (try SSL first), CURLFTPAUTH_TLS (try TLS first), or CURLFTPAUTH_DEFAULT (let cURL decide).
CURLOPT_HTTP_VERSION
设置curl使用的HTTP协议,CURL_HTTP_VERSION_NONE(让curl自己判断),CURL_HTTP_VERSION_1_0(HTTP/1.0),CURL_HTTP_VERSION_1_1(HTTP/1.1)

CURLOPT_HTTPAUTH

Die verwendete HTTP-Überprüfungsmethode, die optionalen Werte sind: CURLAUTH_BASIC, CURLAUTH_DIGEST, CURLAUTH_GSSNEGOTIATE, CURLAUTH_NTLM, CURLAUTH_ANY, CURLAUTH_ANYSAFE. Sie können den Operator „|“ verwenden, um mehrere Werte zu trennen, und Curl lässt den Server den mit auswählen die beste Unterstützung. CURLAUTH_BASIC |. CURLAUTH_GSSNEGOTIATE |. CURLAUTH_GSSNEGOTIATE |. CURLAUTH_NTLM 🎜>Einstellungen Dateigröße hochladen

CURLOPT_LOW_SPEED_LIMIT
Wenn die Übertragungsgeschwindigkeit geringer als CURLOPT_LOW_SPEED_LIMIT ist, verwendet PHP CURLOPT_LOW_SPEED_TIME, um zu bestimmen, ob die Übertragung abgebrochen werden soll, weil sie zu langsam ist.
CURLOPT_LOW_SPEED_TIME
Die Anzahl der Sekunden, die die Übertragung unter CURLOPT_LOW_SPEED_LIMIT liegen sollte, damit PHP die Übertragung als zu langsam betrachtet und die Übertragung abbricht.
CURLOPT_MAXCONNECTS
Die maximal zulässige Anzahl von Verbindungen wird verwendet, um zu bestimmen, welche Verbindungen gestoppt werden sollen.
CURLOPT_MAXREDIRS
Geben Sie die maximale Anzahl von HTTP-Weiterleitungen an CURLOPT_FOLLOWLOCATION. Für die Proxy-Authentifizierung werden derzeit nur CURLAUTH_BASIC und CURLAUTH_NTLM unterstützt.
CURLOPT_PROXYPORT
Die Portnummer des Proxys, zu dem eine Verbindung hergestellt werden soll, kann auch in CURLOPT_PROXY_SOCKS5 festgelegt werden.
CURLOPT_RESUME_FROM
Übergeben Sie a Byte-Offset beim Fortsetzen der Übertragung (wird zum Fortsetzen der Übertragung verwendet)
CURLOPT_SSL_VERIFYHOST
1, um das Vorhandensein eines gemeinsamen Namens im SSL-Peer-Zertifikat zu überprüfen
2, um das Vorhandensein eines gemeinsamen Namens zu überprüfen und auch zu überprüfen dass es mit dem angegebenen Hostnamen übereinstimmt.
CURLOPT_SSLVERSION
Die zu verwendende SSL-Version (2 oder 3) Standardmäßig versucht PHP, dies selbst zu bestimmen, obwohl dies in einigen Fällen manuell eingestellt werden muss.
CURLOPT_TIMECONDITION
Wenn es nach einer bestimmten durch CURLOPT_TIMEVALUE angegebenen Zeit bearbeitet wurde, verwenden Sie CURL_TIMECOND_IFMODSINCE, um die Seite zurückzugeben. Wenn es nicht geändert wurde und CURLOPT_HEADER wahr ist, geben Sie einen „304 Not Modified“-Header zurück, CURLOPT_HEADER ist falsch, verwenden Sie CURL_TIMECOND_ISUNMODSINCE Der Standardwert ist CURL_TIMECOND_IFMODSINCE
CURLOPT_TIMEOUT
Legen Sie die maximale Anzahl von Sekunden fest, die Curl ausführen darf
CURLOPT_TIMEVALUE
Legen Sie die Zeit fest, die von CURLOPT_TIMECONDITION Poke verwendet wird. Standardmäßig wird CURL_TIMECOND_IFMODSINCE verwendet
CURLOPT_CAINFO
Die Name einer Datei, die ein oder mehrere Zertifikate enthält, mit denen der Peer überprüft werden soll. Dies ist nur in Kombination mit CURLOPT_SSL_VERIFYPEER sinnvoll.
CURLOPT_CAPATH
Ein Verzeichnis, das mehrere CA-Zertifikate enthält.
CURLOPT_COOKIE
Legen Sie den Inhalt des „Set-Cookie:“-Teils der HTTP-Anfrage fest.
CURLOPT_COOKIEFILE
Der Name der Datei, die Cookie-Informationen enthält. Diese Cookie-Datei kann im Netscape-Format oder im HTTP-Stil sein.
CURLOPT_COOKIEJAR
Nach dem Schließen der Verbindung wird der Name der Datei zum Speichern von Cookie-Informationen angezeigt.
CURLOPT_CUSTOMREQUEST
Eine benutzerdefinierte Anforderungsmethode, die bei einer HTTP-Anfrage anstelle von „GET“ oder „HEAD“ verwendet wird. Dies ist nützlich für „DELETE“ oder andere, undurchsichtigere HTTP-Anfragen wie „GET“, „POST“, „CONNECT“ usw. Geben Sie hier keine ganze HTTP-Anfragezeile ein Beispielsweise wäre die Eingabe von „GET /index .html HTTP/1.0rnrn“ falsch.
Hinweis: Tun Sie dies nicht, ohne zuvor sicherzustellen, dass der Server die benutzerdefinierte Anforderungsmethode unterstützt.
CURLOPT_EGBSOCKET
Wie CURLOPT_RANDOM_FILE, außer einem Dateinamen für einen Entropy Gathering Daemon-Socket.
CURLOPT_ENCODING
Der Inhalt des „Accept-Encoding:“-Teils des Headers ist: „identity“, „deflate“, „gzip“. Wenn auf eine leere Zeichenfolge festgelegt, bedeutet dies, dass alle Kodierungsformate unterstützt werden
CURLOPT_FTPPORT
Der Wert, der verwendet wird, um die IP-Adresse zu erhalten, die für die FTP-Anweisung „POST“ verwendet werden soll Remote-Server zur Verbindung mit unserer angegebenen IP-Adresse. Die Zeichenfolge kann eine einfache IP-Adresse, ein Hostname, ein Netzwerkschnittstellenname (unter Unix) oder einfach ein einfaches „-“ sein, um die Standard-IP-Adresse des Systems zu verwenden.
CURLOPT_INTERFACE
Der in der externen Netzwerkschnittstelle verwendete Name, der ein Schnittstellenname, eine IP oder ein Hostname sein kann.
CURLOPT_KRB4LEVEL
Einstellung der Sicherheitsstufe KRB4 (Kerberos 4), die einer der folgenden Werte sein kann: „klar“, „sicher“, „vertraulich“, „privat“. Der Standardwert ist „privat“. Wenn er auf Null gesetzt ist, bedeutet dies, dass die KRB4-Sicherheit jetzt nur bei der FTP-Übertragung verwendet werden kann.
CURLOPT_POSTFIELDS
Die „POST“-Operation in HTTP. Wenn Sie eine Datei übertragen möchten, benötigen Sie einen Dateinamen, der mit @
CURLOPT_PROXY
beginnt. Stellen Sie den HTTP-Proxyserver über
CURLOPT_PROXYUSERPWD
ein, um eine Verbindung zum Proxyserver herzustellen. Das Format lautet „[Benutzername]“ :[Passwort]“ Benutzername und Passwort.
CURLOPT_RANDOM_FILE
Legen Sie den Dateinamen fest, um den von SSL verwendeten Zufallszahlen-Seed zu speichern
CURLOPT_RANGE
Um den HTTP-Übertragungsbereich festzulegen, können Sie einen Übertragungsbereich in der Form „X-Y“ festlegen. Wenn mehrere HTTP-Übertragungen vorhanden sind, verwenden Sie Kommas, um mehrere Werte zu trennen, z. B. „X-Y, N-M“.
CURLOPT_REFERER
Legen Sie den Wert des Teils „Referer:“ im Header fest.
CURLOPT_SSL_CIPHER_LIST
Eine Liste von Verschlüsselungen, die für SSL verwendet werden sollen. Beispielsweise sind RC4-SHA und TLSv1 gültige Verschlüsselungslisten.
CURLOPT_SSLCERT
Übergeben Sie eine Zeichenfolge, die das Zertifikat im PEM-Format enthält.
CURLOPT_SSLCERTPASSWD
Übergeben Sie einen Pass mit dem Passwort, das für die Verwendung des CURLOPT_SSLCERT-Zertifikats erforderlich ist.
CURLOPT_SSLCERTTYPE
Das Format des Zertifikats ist „PEM“ (Standard), „DER“ und „ENG“.
CURLOPT_SSLENGINE
Die Kennung für die Krypto-Engine des privaten SSL-Schlüssels angegeben in CURLOPT_SSLKEY.
CURLOPT_SSLENGINE_DEFAULT
Die Kennung für die Krypto-Engine, die für asymmetrische Kryptooperationen verwendet wird.
CURLOPT_SSLKEY
Der Name einer Datei, die einen privaten SSL-Schlüssel enthält.
CURLOPT_SSLKEYPASSWD
Das Geheimnis Passwort erforderlich, um den in CURLOPT_SSLKEY angegebenen privaten SSL-Schlüssel zu verwenden.
Hinweis: Da diese Option ein vertrauliches Passwort enthält, denken Sie daran, das darin enthaltene PHP-Skript sicher aufzubewahren.
CURLOPT_SSLKEYTYPE
Der Schlüsseltyp des privaten In CURLOPT_SSLKEY angegebene SSL-Schlüssel. Unterstützte Schlüsseltypen sind „PEM“ (Standard), „DER“ und „ENG“.
CURLOPT_URL
Die abzurufende URL-Adresse kann auch in der Funktion „curl_init()“ festgelegt werden PHP.
CURLOPT_USERAGENT
Enthält eine „User-Agent“-Header-Zeichenfolge in der HTTP-Anfrage.
CURLOPT_USERPWD
Übergeben Sie den für eine Verbindung erforderlichen Benutzernamen und das Passwort im Format: „[Benutzername]:[Passwort]“.
CURLOPT_HTTP200ALIASES
Die Einstellung verarbeitet HTTP 200-Antworten nicht mehr in Form von Fehlern und das Format ist ein Array.
CURLOPT_HTTPHEADER
Legen Sie im Header ein Array von Übertragungsinhalten fest.
CURLOPT_POSTQUOTE
Ein Array von FTP-Befehlen, die vor der FTP-Anfrage auf dem Server ausgeführt werden sollen.
CURLOPT_QUOTE
Ein Array von FTP-Befehlen, die vor der FTP-Anfrage auf dem Server ausgeführt werden sollen.
CURLOPT_FILE
Legen Sie den Speicherort der Ausgabedatei fest. Der Wert ist ein Ressourcentyp. Der Standardwert ist STDOUT (Browser).
CURLOPT_INFILE
Die Dateiadresse, die beim Hochladen von Dateien gelesen werden muss. Der Wert ist ein Ressourcentyp.
CURLOPT_STDERR
Legen Sie eine Fehlerausgabeadresse fest. Der Wert ist ein Ressourcentyp und ersetzt den Standardwert STDERR.
CURLOPT_WRITEHEADER
Legen Sie die Dateiadresse fest, in die der Header-Teil geschrieben wird, und der Wert ist ein Ressourcentyp.
CURLOPT_HEADERFUNCTION
Legen Sie eine Rückruffunktion fest. Der erste ist das Ressourcenhandle von Curl und der zweite sind die Ausgabeheaderdaten. Die Ausgabe von Header-Daten muss auf dieser Funktion basieren, die die Größe der geschriebenen Daten zurückgibt.
CURLOPT_PASSWDFUNCTION
Legen Sie eine Rückruffunktion mit drei Parametern fest. Der erste ist das Curl-Ressourcenhandle, der zweite ist eine Passwortabfrage und der dritte Parameter ist die maximal zulässige Passwortlänge. Gibt den Wert des Passworts zurück.
CURLOPT_READFUNCTION
Legen Sie eine Rückruffunktion mit zwei Parametern fest. Der erste ist das Ressourcenhandle von Curl und der zweite sind die Lesedaten. Das Lesen von Daten muss auf dieser Funktion basieren. Gibt die Größe der gelesenen Daten zurück, z. B. 0 oder EOF.
CURLOPT_WRITEFUNCTION
Legen Sie eine Rückruffunktion mit zwei Parametern fest. Der erste ist das Ressourcenhandle von Curl und der zweite sind die geschriebenen Daten. Das Schreiben von Daten muss auf dieser Funktion basieren. Geben Sie die genaue Größe der geschriebenen Daten zurück

Die Funktion von curl_copy_handle() besteht darin, alle Inhalte und Parameter einer Curl-Verbindungsressource zu kopieren

$ch = curl_init("http://www . baidu.com/");
$another = curl_copy_handle($ch);
curl_exec($another);
curl_close($another);
curl_error() Funktion soll ein A zurückgeben Zeichenfolge, die Fehlermeldungen für die aktuelle Sitzung enthält.
Die Funktion von curl_errno() besteht darin, eine numerische Zahl zurückzugeben, die Fehlerinformationen der aktuellen Sitzung enthält.
Die Funktion „curl_multi_init()“ wird zum Initialisieren einer Curl-Batch-Handle-Ressource verwendet.
Die Funktion „curl_multi_add_handle()“ wird verwendet, um einzelne Curl-Handle-Ressourcen zur Curl-Batch-Sitzung hinzuzufügen. Die Funktion „curl_multi_add_handle()“ verfügt über zwei Parameter. Der erste Parameter stellt eine Curl-Batch-Handle-Ressource dar und der zweite Parameter stellt eine separate Curl-Handle-Ressource dar.
Die Funktion der Funktion „curl_multi_exec()“ besteht darin, ein Curl-Batch-Handle zu analysieren. Die Funktion „curl_multi_exec()“ verfügt über zwei Parameter. Der erste Parameter stellt eine Batch-Handle-Ressource dar, und der zweite Parameter ist ein Referenzwertparameter, der den Rest angibt Die Anzahl der einzelnen Curl-Handle-Ressourcen, die verarbeitet werden müssen.
Die Funktion „curl_multi_remove_handle()“ stellt das Entfernen einer Handle-Ressource in der Curl-Batch-Handle-Ressource dar. Die Funktion „curl_multi_remove_handle()“ verfügt über zwei Parameter. Der erste Parameter stellt eine Curl-Batch-Handle-Ressource dar und der zweite Parameter stellt eine separate Curl dar Ressource behandeln.
Die Funktion „curl_multi_close()“ wird zum Schließen einer Batch-Handle-Ressource verwendet.

$ch1 = curl_init();
$ch2 = curl_init();
curl_setopt($ch1, CURLOPT_URL, "http://www.baidu.com/");
curl_setopt($ ch1, CURLOPT_HEADER, 0);
curl_setopt($ch2, CURLOPT_URL, "http://www.google.com/");
curl_setopt($ch2, CURLOPT_HEADER, 0);
$mh = curl_multi_init();
curl_multi_add_handle($mh,$ch1);
curl_multi_add_handle($mh,$ch2);
do {
curl_multi_exec($mh,$flag);
} while ($flag > 0);
curl_multi_remove_handle($mh,$ch1);
curl_multi_remove_handle($mh,$ch2);
curl_multi_close($mh);
Die Rolle von curl_multi_getcontent() Funktion Gibt den Textstrom der erhaltenen Ausgabe zurück, wenn CURLOPT_RETURNTRANSFER gesetzt ist.
Die Funktion „curl_multi_info_read()“ wird verwendet, um die relevanten Übertragungsinformationen des aktuell analysierten Curls abzurufen.
curl_multi_select()
Alle mit der cURL-Erweiterung verknüpften Sockets abrufen, die dann „ausgewählt“ werden können

Weitere Artikel zur PHP CURL CURLOPT-Parameterbeschreibung (curl_setopt) finden Sie unter PHP chinesische Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage