栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

「PHP开发APP接口实战014」手机号快速登录二

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

「PHP开发APP接口实战014」手机号快速登录二

创建数据模型
  1. 在 /app/models 目录下创建基础数据模型文件 baseModel.php,添加代码:

get( 'database.prefix', 'ini' );        if ( $tableName == '' ) {
            $tableName = parent::getSource();
        }        return $prefix . $tableName;
    }    
    public function add( $item ) {        try {            $this->create( $item );            return $this->getWriteConnection()->lastInsertId( $this->getSource() );
        } catch ( Exception $e ) {

        }        return 0;
    }

}
  1. 重写函数 getSource, 自动添加表名前缀。

  2. 新增添加数据函数 add ,将直接返回新增数据行ID。

  1. 在 /app/models 目录下创建用户数据模型文件 User.php,添加代码:

user_status ) {                throw new Exception( '帐号未激活' );
            }            // 设置最后登录时间
            if ( ! $model->update( [ 'user_uptime' => time() ] ) ) {                throw new Exception( '更新帐号失败' );
            }
            $user['user_token'] = $model->user_token;
        } else {
            $user['user_token'] = Authentication::instance()->generateToken();            // 初始化帐号数据
            $item = [                'user_mobile'  => $user_mobile,                'user_token'   => $user['user_token'],                'user_status'  => 1, // 创建帐号时自动激活状态
                'user_addtime' => time(),                'user_uptime'  => time(),
            ];            if ( ! $this->add( $item ) ) {                throw new Exception( '创建帐号失败' );
            }
        }        return $user;
    }
}
  1. 每一个数据模型对应一个数据表:

  • 数据表命名规则, 使用小写字母或数字,两个单词之前用英文下划线“_”分隔。如非必要,尽量不要以数字开头。

  • 使用对应的数据表名,去除表名前缀和下划线,并将以“_”分隔的单词首字母大写,作为数据模型文件名和类名。

  1. 这里没有严格按照官方文档,对每个字段都预定义一个对应的属性字段。(并不影响使用)

  2. 函数 login 实现了:

  • 验证手机号是否已注册帐号

  • 已经注册且状态为激活,更新登陆时间,并返回 user_token

  • 未注册,自动创建帐号,并返回 user_token

  • 或返回对应错误信息

实现登陆接口

打开 /app/controllers/UserController.php 文件, 完善函数loginAction:

    
    public function loginAction() {        // 验证请求方法是否是POST
        $this->isPost();        // 验证请求参数
        XValidationUser::instance()->login( $this->getPost() );        // 获取登录信息
        $user = User::instance()->login( $this->getPost( 'user_mobile' ) );        if ( $user ) {
            Output::instance( $this->response )->success( (object) $user );
        } else {
            Output::instance( $this->response )->fail( '登录失败' );
        }
    }

到了这一步,函数 loginAction 其实就比较简单了:

  1. 调用POST请求方法验证函数

  2. 调用请求参数验证函数

  3. 调用获取登录信息数据函数

  4. 输出用户信息(这里只输出了 user_token 字段,可根据实际需要,返回相应的数据)

PS: 这次,我将前面讲的验证模块和数据模块,都改成了单例模式。大家可下载代码查看。

示例代码下载
链接:https://pan.baidu.com/s/1-Myzt8JDQHExjKz2KJxhPQ 密码:l3lh



作者:一念觀心
链接:https://www.jianshu.com/p/5eb576580c4c

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/229436.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号