簡體   English   中英

如何在codeigniter中獲取ip地址?

[英]how to get ip address in codeigniter?

我正在執行以下代碼進行登錄嘗試,我想獲取本地計算機的 IP 地址。

if ( !$this->session->userdata('login_attempts') )
{
   $this->session->set_userdata('login_attempts', 0);
}
$attempts = ($this->session->userdata('login_attempts') + 1);
$this->session->set_userdata('login_attempts', $attempts);
// Check if the session.
if ( $this->session->userdata('login_attempts') > 4 )
{
    echo 'hi....login attempt is over';
}
// Failed. So, update the session    

echo $ip = $_SERVER['REMOTE_ADDR'];
// $ip_address = $this->input->ip_address1();
// return $ip_address;
echo $this->input->ip_address();
if ( ! $this->input->valid_ip($ip))
{
    echo 'Not Valid';
}
else
{
    echo 'Valid';
}
$this->db->update('loginattempts',array( 'login_attempts' =>$this->session->userdata('login_attempts') , 'lastLogin' =>date('Y-m-d H:i:s'),'ip'=>$ip = $_SERVER['REMOTE_ADDR'] ),array('login_id' =>1) );
echo ('hi....login attempt is'.$this->session->userdata('login_attempts'));

}

但它顯示我本地機器的 ip 地址不正確。

使用$this->input->ip_address();

Codeigniter 輸入用戶指南 (ip_address)

另外,不要重復方程。 在另一行回顯:

$ip = $this->input->ip_address();
echo $ip;

控制器

$data['ip'] = $this->input->ip_address();

看法

<?= $ip ;?>

要獲取遠程 IP 地址,在 PHP 中,您可以使用$_SERVER['REMOTE_ADDR'] ,CodeIgniter 在幕后做同樣的事情。

使用下面的任何人.. 與 $_SERVER['REMOTE_ADDR'] 一樣

$_SERVER['HTTP_X_FORWARDED_FOR']

$_SERVER['HTTP_CF_CONNECTING_IP']

為了安全起見,我們應該使用 codeigniter 函數,我們應該使用$this->input->ip_address(); , 這將給客戶端 ip

如果要訪問服務器變量,請像這樣使用

$this->input->server(array('HTTP_CF_CONNECTING_IP', 'HTTP_X_FORWARDED_FOR')));

供參考,請查看https://www.codeigniter.com/user_guide/libraries/input.html

這是在mysql中插入登錄日志用戶時的簡單示例代碼;

               $ip=file_get_contents('https://api.ipify.org');
                
                  $sql = array(
                      'email_user' => $email,
                      'full_name'  => $full_name,
                      'last_login' => $date,
                      'ipaddress'  => $ip
                      );
                $this->db->insert('$table', $sql);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM