mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-14 20:40:49 +08:00
fix https detect
This commit is contained in:
@@ -100,6 +100,14 @@ final class Nexus
|
|||||||
$this->logSequence++;
|
$this->logSequence++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function getFirst(string $result): string
|
||||||
|
{
|
||||||
|
if (str_contains($result, ",")) {
|
||||||
|
return strstr($result, ",", true);
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
public function getRequestSchema()
|
public function getRequestSchema()
|
||||||
{
|
{
|
||||||
$schema = $this->retrieveFromServer(['HTTP_X_FORWARDED_PROTO', 'REQUEST_SCHEME', 'HTTP_SCHEME']);
|
$schema = $this->retrieveFromServer(['HTTP_X_FORWARDED_PROTO', 'REQUEST_SCHEME', 'HTTP_SCHEME']);
|
||||||
@@ -109,18 +117,19 @@ final class Nexus
|
|||||||
$schema = 'https';
|
$schema = 'https';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return $schema;
|
return $this->getFirst($schema);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getRequestHost(): string
|
public function getRequestHost(): string
|
||||||
{
|
{
|
||||||
$host = $this->retrieveFromServer(['HTTP_HOST', 'host', ], true);
|
$host = $this->retrieveFromServer(['HTTP_HOST', 'host', 'HTTP_X_FORWARDED_HOST'], true);
|
||||||
return (string)$host;
|
return $this->getFirst(strval($host));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getRequestIp()
|
public function getRequestIp(): string
|
||||||
{
|
{
|
||||||
return $this->retrieveFromServer(['HTTP_CF_CONNECTING_IP', 'HTTP_X_FORWARDED_FOR', 'x-forwarded-for', 'HTTP_REMOTE_ADDR', 'REMOTE_ADDR'], true);
|
$ip = $this->retrieveFromServer(['HTTP_CF_CONNECTING_IP', 'HTTP_X_FORWARDED_FOR', 'x-forwarded-for', 'HTTP_REMOTE_ADDR', 'REMOTE_ADDR'], true);
|
||||||
|
return $this->getFirst($ip);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function retrieveFromServer(array $fields, bool $includeHeader = false)
|
private function retrieveFromServer(array $fields, bool $includeHeader = false)
|
||||||
@@ -134,12 +143,6 @@ final class Nexus
|
|||||||
}
|
}
|
||||||
foreach ($fields as $field) {
|
foreach ($fields as $field) {
|
||||||
$result = $servers[$field] ?? null;
|
$result = $servers[$field] ?? null;
|
||||||
if ($result && in_array($field, ['HTTP_X_FORWARDED_FOR', 'x-forwarded-for'])) {
|
|
||||||
$result = preg_split('/[,\s]+/', $result);
|
|
||||||
}
|
|
||||||
if (is_array($result)) {
|
|
||||||
$result = Arr::first($result);
|
|
||||||
}
|
|
||||||
if ($result !== null && $result !== '') {
|
if ($result !== null && $result !== '') {
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user