[list]

  • 预先加载数据库操作类和Session类 即在autoload.php中,$autoload['libraries'] = array('database', 'session');
  • a. 注: 使用session , 要设定 encryption key : config.php中:  $config['encryption_key'] = '!@#$%^&*()';

  • 登录表单页(view) : login_view.php
  • 注: 由于该页面使用了CI的form标签, 所以需要在渲染该页面前加载form_helper, 即: 在config/autoload.php, 文件中加入: $autoload['helper'] = array('url', 'form');

    Html代码  
    1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    2. <html lang="utf-8">
    3. <head>
    4. <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    5. <title>Login</title>
    6. <style>div{display: block;} .errors{color: red;}</style>
    7. </head>
    8. <body>
    9. <h1>Please Login</h1>
    10. <?php echo form_open('admin');?>
    11. <p>
    12. <?php
    13. echo form_label('Email: ', 'email');
    14. echo form_input('email', set_value('email'), 'id="email" autofocus'); // set_value 如果密码输入有误, 返回时,默认写入值
    15. ?>
    16. </p>
    17. <p>
    18. <?php
    19. echo form_label('Password: ', 'password');
    20. echo form_input('password', '', 'id="password"');
    21. ?>
    22. </p>
    23. <p>
    24. <?php echo form_submit('submit','Login');?>
    25. </p>
    26. <?php echo form_close();?>
    27. <div class="errors"><?php echo validation_errors();?></div>
    28. </body>
    29. </html>
  • 控制器 : admin.php
  • Php代码  
    1. <?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
    2. class Admin extends CI_Controller {
    3. function __construct(){
    4. parent::__construct();
    5. }
    6. public function index(){
    7. // 在welcome的action中添加如下代码,即可用户登录情况
    8. /**
    9. * public function __costruct(){
    10. *      session_start();
    11. *      parent::_construct();
    12. *
    13. *      if(!$this->session->userdata('username')) redirect('admin');
    14. * }
    15. */
    16. if ($this->session->userdata('username')) {
    17. redirect('welcome');
    18. }
    19. $this->load->library('form_validation'); // 使用CI的表单验证, 如下:
    20. $this->form_validation->set_rules('email', 'Email', 'valid_email|required');
    21. $this->form_validation->set_rules('password', 'Password', 'min_length[4]|required');
    22. if($this->form_validation->run() !== false){
    23. // then validate password. Get from the Db.
    24. $this->load->model('admin_model');
    25. $res = $this->admin_model->verify_users(
    26. $this->input->post('email'),
    27. $this->input->post('password')
    28. );
    29. if($res !== false){
    30. print_r($res);
    31. $this->session->set_userdata('username', $this->input->post('email'));
    32. redirect('welcome');
    33. }
    34. }
    35. $this->load->view('login_view');
    36. }
    37. public function logout(){
    38. $this->session->sess_destroy();
    39. $this->load->view('login_view');
    40. }
    41. }
  • 模型层admin_model.php
  • 注: 由于使用了数据库, 在这里必须首先加载数据库连接: 即: 在config/autoload.php, 文件中加入: $autoload['libraries'] = array('database');

    Php代码  
    1. <?php
    2. class Admin_model extends CI_Model{
    3. function verify_users($email, $password){
    4. $q = $this->db
    5. ->where('email', $email)
    6. ->where('password', sha1($password))
    7. ->limit(1)->get('users');
    8. if($q->num_rows > 0){
    9. return $q->row();
    10. }
    11. return false;
    12. }
    13. }

    [/list]

    ci用户登录的更多相关文章

    1. javaweb学习总结(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册

      一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

    2. JavaWeb学习 (二十一)————基于Servlet+JSP+JavaBean开发模式的用户登录注册

      一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

    3. 基于Servlet+JSP+JavaBean开发模式的用户登录注册

      http://www.cnblogs.com/xdp-gacl/p/3902537.html 一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBea ...

    4. javaweb(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册

      一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

    5. PHP验证用户登录例子-学习笔记

      1.基本流程: 2.UML类图: 3.PHP代码: 3.1 index.php <?php /** * Created by PhpStorm. * User: andy * Date: 16- ...

    6. Ubuntu设置root用户登录图形界面

      Ubuntu默认的是root用户不能登录图形界面的,只能以其他用户登录图形界面.这样就很麻烦,因为权限的问题,不能随意复制删除文件,用gedit编辑文件时经常不能保存,只能用vim去编辑. 解决的办法 ...

    7. ASP.NET MVC5+EF6+EasyUI 后台管理系统(19)-权限管理系统-用户登录

      系列目录 我们之前做了验证码,登录界面,却没有登录实际的代码,我们这次先把用户登录先完成了,要不权限是讲不下去了 把我们之前的表更新到EF中去 登录在Account控制器,所以我们要添加Account ...

    8. Asp.Net Core 项目实战之权限管理系统(5) 用户登录

      0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

    9. android安卓Sqlite数据库实现用户登录注册

      看了很多别人写的安卓SQlite数据的操作代码,一点也不通俗易懂,我觉得我写的不错,而且安卓项目也用上了,所以在博客园里保存分享一下!建立一个类 并继承SQLiteOpenHelper public ...

    随机推荐

    1. Rollei SL66 使用说明

      根据记忆,并用不规范的语言描述我对sl66的使用心得:一.上卷1.用摇把顺时针转到12点位置,再退回3点位置:2.安插刀:3.后背上方按钮向右拨,打开后背:4.取出,装卷,再放入:5.转动后背上旋钮, ...

    2. python--模块导入与执行

      定义:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 一.模块注意: 1.所有的模块都应该自觉的往上写 2.调用模块的时候都是最先在本地找 3.写模块的顺序是 ...

    3. 使用lombok时@Setter @Getter无效

      原文链接 : https://blog.csdn.net/marion158/article/details/87893480 lombok是一个帮助简化代码的工具,通过注解的形式例如@Setter ...

    4. python 2 学习历程(一)

      在用户输入字符串的时候,有时会带有一些其他的字符,例如常见的空格 除非在网页或者某个位置声明了空格也算字符,或者一些账号等安全程度较高的环节,多了一个空格很少有人会注意到,并且愿意即时改正它们,那么这 ...

    5. C# Func和匿名方法 简单使用

      今天敲代码遇见一个问题,解决中用到了C#的Func和匿名方法,发现挺好用的 定义一个这样的方法可以避免重复写try catch 这里用到了Func<int,string> ,它其实就是一个 ...

    6. sqlmap结合burpsuite对post请求进行注入测试

      1. 浏览器打开目标地址 http://testasp.vulnweb.com/Login.asp 2. 配置burp代理(127.0.0.1:8080)以拦截请求 3. 点击login表单的subm ...

    7. Java ----单个list 删除元素

      转载:https://www.cnblogs.com/lostyears/p/8809336.html 方式一:使用Iterator的remove()方法 public class Test { pu ...

    8. JavaWeb学习篇之----自定义标签&&JSTL标签库详解

      今天来看一下自定义标签的内容,自定义标签是JavaWeb的一部分非常重要的核心功能,我们之前就说过,JSP规范说的很清楚,就是Jsp页面中禁止编写一行Java代码,就是最好不要有Java脚本片段,下面 ...

    9. NX二次开发-关闭信息窗口UF_UI_close_listing_window

      #include <uf.h> #include <uf_ui.h> UF_initialize(); //打开信息窗口 UF_UI_open_listing_window() ...

    10. Android获取Root权限之后的静默安装实现代码示例分析

      转:http://blog.csdn.net/jiankeufo/article/details/43795015 Adroid开发中,我们有时会遇到一些特殊功能的实现,有些功能并没有太高技术难度,但 ...