说明:1,运行环境 laravel 5.3 php7+nginx+mysql
2,使用安装包 https://github.com/goodspb/laravel5-ucenter 上面有对接方法
对接过程遇见的问题:1,问题:在laravel配置了UCenter的config之后,在UCenter的用户中心还是通信失败。解决:laravel的路由配置不正确
2,问题:laravel无法对接UCenter的数据库。解决:在PHP7中已经废弃的函数mysql_connect(),GitHub的作者依然在使用,然后手动改成了mysqli_connect(),所有牵扯到的函数增加一个 " i "即可。在文件src/uc_client/lib/db.class.php
3,问题:php7无法调用自己的函数。解决:在UCenterApi中第70行左右 改成 $actions = $get['action']; return self::$actions($get, $post);
UCenter在laravel的用法:1,引用:use Goodspb\Laravel5Ucenter\Ucenter;2,$ucresult = Ucenter::execute('uc_user_checkname',[$username]);
UCenter接口(以下都是用户接口)
1,uc_user_register() integer uc_user_register(string username , string password , string email [, integer questionid , string answer , string regip])
描述:本接口函数用于新用户注册。用户名、密码、Email为一个用户在UCenter的基本数据,提交后UCenter会按照注册设置和词语过滤的规则检测用户名和Email的格式时候正确合法,如果正确返回注册后的用户ID,否则返回相应的错误信息
参数
参数名 | 类型 | 是否必需 | 说明 |
username | string | 是 | 用户名 |
password | string | 是 | 密码 |
string | 是 | 电子邮箱 | |
questionid | integer | 否 | 安全提问索引 |
answer | string | 否 | 安全提问答案 |
regip | string | 否 | 注册ip |
返回值
返回值类型 | 说明 |
integer |
大于0:返回用户ID,表示用户注册成功 -1:用户名不合法 -2:包含不允许注册的词语 -3:用户名已经存在 -4:Email格式有误 -5:Email不允许注册 -6:该Email已经被注册 |
2,uc_user_login() array uc_user_login(string username , string password [, bool isuid , bool checkques , integer questionid , string answer])
描述:本接口函数用户用户登录验证,用户名及密码正确无误则返回用户在UCenter的基本数据,否则返回相应的错误信息。如果应用程序是升级过来的,并且当前登录用户和已有的用户重名,那么返回数组中[4]的值将返回1.
参数
参数名 | 类型 | 是否必需 | 说明 | 备注 |
username | string | 是 | 用户名/用户ID/用户 Email | |
password | string | 是 | 密码 | |
isuid | bool | 否 | 是否使用用户ID登录 |
1:使用用户ID登录 2:使用用户Email登录 0:(默认值)使用用户名登录 |
checkques | bool | 否 | 是否验证安全提问 |
1:验证安全提问 0:(默认值)不验证安全提问 |
questionid | intger | 否 | 安全提问索引 | |
answer | string | 否 | 安全提问索引 |
返回值:返回值类型:array 。说明:成功返回用户信息,失败返回错误代码 。数组结构看下方说明
key | 类型 | value |
0 | integer |
大于0:返回用户ID,表示用户登录成功 -1:用户不存在或者被删除 -2:密码错误 -3:安全问题错误 |
1 | string | 用户名 |
2 | string | 密码 |
3 | string | |
4 | bool | 用户名是否重名 |
3,uc_get_user array uc_get_user(string username[,bool isuid])
描述:本接口函数用于获取用户在UCenter的基本数据,如果用户不存在,返回值为integer的数值0。
参数:
参数名 | 类型 | 是否必需 | 说明 | 备注 |
username | string | 是 | 用户名 | |
isuid | bool | 否 | 是否使用用户名ID获取 |
1:使用用户ID获取 0:(默认值)使用用户名获取 |
返回值:返回值类型:array 。说明:成功返回用户信息,失败返回错误代码 。数组结构看下方说明
key | 类型 | value |
0 | integer | 用户ID |
1 | string | 用户名 |
2 | string |
4,uc_user_edit integer uc_user_enit(string username,string oldpwd,string newpw,string Email[,bool ignoreoldpw,integer questionid,string answer])
描述:本接口函数用户更新用户资料。更新资料需要验证用户的原密码是否正确,除非指定ignoreoldpw为1.如果只修改Email不修改密码,可让newpw为空;同理如果只修改密码不修改Email,可让Email为空。
参数:
参数名 | 类型 | 是否必需 | 说明 | 备注 |
username | string | 是 | 用户名 | |
oldpw | string | 是 | 旧密码 | |
newpw | string | 是 | 新密码,如不修改为空 | |
string | 是 | Email,如不修改为空 | ||
ignoreoldpw | bool | 否 | 是否忽略旧密码 |
1:忽略,更改资料不需要验证密码 0:(默认值)不忽略,更改资料需要验证密码 |
questionid | integer | 否 | 安全提问索引 | |
answer | string | 否 | 安全提问答案 |
返回值:
返回值类型 | 说明 |
integer |
1:更新成功 0:没有做任何修改 -1:旧密码不正确 -4:Email格式有误 -5:Email不允许注册 -6:该Email已经被注册 -7:没有做任何修改 -8:该用户受保护无权限更改 |
参考文件链接:http://codex.wordpress.org.cn/UCenter接口
剩余问题:在网站和论坛对接的同步登陆的时候,论坛同步登陆了,网站不能没有登录信息,在设置cookie域和cookie路径的时候。不知道怎么设置。