CI框架实现cookie登陆的方法详解_php实例
本文实例讲述了CI框架实现cookie登陆的方法。分享给大家供大家参考,具体如下:
第一步:login.php
//登陆方法 public function login(){ //如果用户名和密码为空,则返回登陆页面 if(empty($_POST['username']) || empty($_POST['password'])){ $data['verifycode'] = rand(1000,9999);//生成一个四位数字的验证码 //将验证码放入session中,注意:参数是数组的格式 $this->session->set_userdata($data); //注意:CI框架默认模板引擎解析的模板文件中变量不需要$符号 //$this->parser->parse("admin/login",$data); //smarty模板变量赋值 $this->tp->assign("verifycode",$data['verifycode']); //ci框架在模板文件中使用原生态的PHP语法输出数据 //$this->load->view('login',$data);//登陆页面,注意:参数2需要以数组的形式出现 //显示smarty模板引擎设定的模板文件 $this->tp->display("admin/login.php"); }else{ $username = isset($_POST['username'])&&!empty($_POST['username'])?trim($_POST['username']):'';//用户名 $password = isset($_POST['password'])&&!empty($_POST['password'])?trim($_POST['password']):'';//密码 $verifycode = isset($_POST['verifycode'])&&!empty($_POST['verifycode'])?trim($_POST['verifycode']):'';//验证码 //做验证码的校验 if($verifycode == $this->session->userdata('verifycode')){ //根据用户名及密码获取用户信息,注意:参数2是加密的密码 $user_info=$this->user_model->check_user_login($username,md5($password)); if($user_info['user_id'] > 0){ //将用户id、username、password放入cookie中 //第一种设置cookie的方式:采用php原生态的方法设置的cookie的值 //setcookie("user_id",$user_info['user_id'],86500); //setcookie("username",$user_info['username'],86500); //setcookie("password",$user_info['password'],86500); //echo $_COOKIE['username']; //第二种设置cookie的方式:通过CI框架的input类库 $this->input->set_cookie("username",$user_info['username'],3600); $this->input->set_cookie("password",$user_info['password'],3600); $this->input->set_cookie("user_id",$user_info['user_id'],3600); //echo $this->input->cookie("password");//适用于控制器 //echo $this->input->cookie("username");//适用于控制器 //echo $_COOKIE['username'];//在模型类中可以通过这种方式获取cookie值 //echo $_COOKIE['password'];//在模型类中可以通过这种方式获取cookie值 //第三种设置cookie的方式:通过CI框架的cookie_helper.php函数库文件 //这种方式不是很灵验,建议大家采取第二种方式即可 //set_cookie("username",$user_info['username'],3600); //echo get_cookie("username"); //session登陆时使用:将用户名和用户id存入session中 //$data['username']=$user_info['username']; //$data['user_id']=$user_info['user_id']; //$this->session->set_userdata($data); //跳转到指定页面 //注意:site_url()与base_url()的区别,前者带index.php,后者不带index.php header("location:".site_url("index/index")); } }else{ //跳转到登陆页面 header("location:".site_url("common/login")); } } } }
第二步:User_model.php
//cookie登陆:检测用户是否登陆,如果cookie值失效,则返回false,如果cookie值未失效,则根据cookie中的用户名和密码从数据库中获取用户信息,如果能获取到用户信息,则返回查询到的用户信息,如果没有查询到用户信息,则返回0 public function is_login(){ //获取cookie中的值 if(empty($_COOKIE['username']) || empty($_COOKIE['password'])){ $user_info = false; }else{ $user_info=$this->check_user_login($_COOKIE['username'],$_COOKIE['password']); } return $user_info; } //根据用户名及加密密码从数据库中获取用户信息,如果能获取到,则返回获取到的用户信息,否则返回false,注意:密码为加密密码 public function check_user_login($username,$password){ //这里大家要注意:$password为md5加密后的密码 //$this->db->query("select * from "); //快捷查询类的使用:能为我们提供快速获取数据的方法 //此数组为查询条件 //注意:关联数组 $arr=array( 'username'=>$username,//用户名 'password'=>$password,//加密密码 'status'=>1 //账户为开启状态 ); //在database.php文件中已经设置了数据表的前缀,所以此时数据表无需带前缀 $query = $this->db->get_where("users",$arr); //返回二维数组 //$data=$query->result_array(); //返回一维数组 $user_info=$query->row_array(); if(!empty($user_info)){ return $user_info; }else{ return false; } }
第三步:其它控制器:
public function __construct(){ //调用父类的构造函数 parent::__construct(); $this->load->library('tp'); //smarty模板解析类 $this->load->helper('url'); //url函数库文件 $this->load->model("user_model");//User_model模型类实例化对象 $this->cur_user=$this->user_model->is_login(); if($this->cur_user === false){ header("location:".site_url("common/login")); }else{ //如果已经登陆,则重新设置cookie的有效期 $this->input->set_cookie("username",$this->cur_user['username'],3600); $this->input->set_cookie("password",$this->cur_user['password'],3600); $this->input->set_cookie("user_id",$this->cur_user['user_id'],3600); } $this->load->library('pagination');//分页类库 $this->load->model("role_model");//member_model模型类 $this->load->model("operation_model");//引用operation_model模型 $this->load->model("object_model");//引用object_model模型 $this->load->model("permission_model");//引用permission_model模型 }
更多关于CodeIgniter相关内容感兴趣的读者可查看本站专题:《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《php优秀开发框架总结》、《ThinkPHP入门教程》、《ThinkPHP常用方法总结》、《Zend FrameWork框架入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于CodeIgniter框架的PHP程序设计有所帮助。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











일부 플레이어는 출시 시 PS4 또는 PS5에서 이상한 문제를 경험하고 있습니다. 예를 들어, PlayStation Network 로그인에 실패했지만 인터넷 연결은 양호할 때 문제가 발생할 수 있습니다. 로그인 정보를 입력할 때 오류가 발생할 수 있으며 PSParty 채팅에 참여하지 못할 수도 있습니다. 비슷한 문제가 발생하는 경우 이 가이드가 문제 해결에 도움이 될 수 있습니다. PlayStationNetworkSign-in 옆에 'AnErrorHaveAreAre'라는 오류 메시지가 표시되며 '실패'라고 표시됩니다. IP 주소 가져오기, 인터넷 연결 및 연결 속도와 같은 다른 매개변수는 성공적이었습니다. 그렇다면 여기서 무엇이 문제가 될 수 있습니까? 내가 너에게 일자리를 줄게

AADSTS7000112 오류로 인해 Microsoft 계정을 사용하여 앱에 로그인하지 못해 불편을 겪을 수 있습니다. 이 문서에서는 이 문제를 해결하고 정상적인 로그인 환경을 복원하는 데 도움이 되는 솔루션을 제공합니다. 로그인: 죄송합니다. 로그인하는 데 문제가 있습니다. AADSTS7000112: 애플리케이션이 비활성화되었습니다. 다행히도 몇 가지 간단한 제안 사항을 따르면 오류를 수정할 수 있습니다. 오류 코드 AADSTS7000112는 무엇입니까? 오류 코드 AADSTS7000112는 Microsoft의 Azure Active Directory 연결에 문제가 있음을 나타냅니다. 일반적으로 이는 로그인을 시도하는 Microsoft 애플리케이션이 차단되었기 때문일 수 있습니다.

컴퓨터의 쿠키는 사용된 브라우저 및 운영 체제에 따라 브라우저의 특정 위치에 저장됩니다. 1. Google Chrome, C:\Users\YourUsername\AppData\Local\Google\Chrome\User Data\Default\Cookies에 저장됨 등.

쿠키는 일반적으로 브라우저의 쿠키 폴더에 저장되며, 브라우저의 쿠키 파일은 일반적으로 바이너리 또는 SQLite 형식으로 저장됩니다. 쿠키 파일을 직접 열면 일부 왜곡되거나 읽을 수 없는 내용이 나타날 수 있으므로 사용하는 것이 가장 좋습니다. 쿠키를 보고 관리하기 위해 귀하의 브라우저에서 제공하는 쿠키 관리 인터페이스.
![GeForce Experience 로그인이 정지됨 [수정]](https://img.php.cn/upload/article/000/887/227/171084420790568.png?x-oss-process=image/resize,m_fill,h_207,w_330)
이 문서에서는 Windows 11/10의 GeForceExperience 로그인 충돌 문제를 해결하는 방법을 안내합니다. 일반적으로 이는 불안정한 네트워크 연결, 손상된 DNS 캐시, 오래되거나 손상된 그래픽 카드 드라이버 등으로 인해 발생할 수 있습니다. GeForceExperience 로그인 블랙 스크린 수정 시작하기 전에 인터넷 연결과 컴퓨터를 다시 시작하세요. 때로는 문제가 일시적인 문제로 인해 발생하는 경우도 있습니다. NVIDIA GeForce Experience 로그인 검은색 화면 문제가 계속 발생하는 경우 다음 제안 사항을 따르십시오. 인터넷 연결을 확인하십시오. 다른 인터넷 연결로 전환하십시오.

휴대폰의 쿠키는 모바일 장치의 브라우저 애플리케이션에 저장됩니다. 1. iOS 장치의 경우 쿠키는 Safari 브라우저의 설정 -> Safari -> 고급 -> 웹사이트 데이터에 저장됩니다. 2. Android 장치의 경우 쿠키가 저장됩니다. 설정 -> 사이트 설정 -> 크롬 브라우저의 쿠키 등에서

Wegame은 Tencent 게임과 함께 사용되는 소프트웨어로, 게임을 시작하고 가속을 얻을 수 있습니다. 최근 많은 사용자가 이 메시지에 직면했을 때 로그인 작업이 너무 자주 발생한다는 메시지를 경험했습니다. 성공적으로 해결하셨나요? 이 소프트웨어 튜토리얼에서 이에 대해 함께 알아보겠습니다. Wegame 로그인 작업이 너무 자주 발생하면 어떻게 해야 하나요? 방법 1: 1. 먼저 네트워크 연결이 정상적인지 확인하세요. (브라우저를 열어 인터넷에 접속할 수 있는지 확인해 볼 수 있습니다.) 2. 네트워크 장애인 경우 라우터를 다시 시작하고 네트워크 케이블을 다시 연결한 후 컴퓨터를 다시 시작하여 문제를 해결해 보세요. 방법 2: 1. 네트워크에 문제가 없다면 &를 선택하세요.

Enterprise WeChat의 이메일 주소에 로그인하는 방법 Enterprise WeChat 앱에서 이메일 주소로 로그인할 수 있지만 대부분의 사용자는 이메일 주소로 로그인하는 방법을 모릅니다. 관심 있는 사용자를 위해 편집자가 가져온 Enterprise WeChat 이메일 주소로 로그인하세요. 기업용 WeChat 사용 튜토리얼 기업용 WeChat 이메일에 로그인하는 방법 1. 먼저 기업용 WeChat 앱을 열고 메인 페이지 하단의 [Workbench]로 이동한 후 클릭하여 특별 영역으로 이동합니다. 2. 그런 다음 Workbench에서; 해당 영역에서 [기업 메일함] 서비스를 선택합니다. 3. 그런 다음 기업 이메일 기능 페이지로 이동하여 하단의 [바인딩] 또는 [이메일 변경]을 클릭합니다. 4. 마지막으로 해당 페이지에서 [QQ 계정]과 [비밀번호]를 입력합니다. 아래에 표시된 이메일에 로그인하세요.
