QQ互联申请及配置
今天要说的只是针对QQ互联的操作,其他的互联请参考相关网站。
第一步:需要申请API接口的两码
自行登录QQ互联https://connect.qq.com/index.html,然后按照要求申请就OK啦。
过几天你会收到一封审核通过的邮件:
第二步:互联开始
首先假设我的网站有一个登陆按钮,那么这个按钮指向哪里呢?
所以第一个就是我们需要找的登陆,这里的话我是放在common控制器下的loginqq方法,所以我的按钮写的是:
<a href="{:U('Common/loginqq',array("type"=>"qq"))}" class="from" >QQ访问</a>
需要注意的是:你网站第一次申请的时候,请用QQ的图标来代替文字,不然申请不通过的
对应的函数代码:
//QQ登陆
public function loginqq($type = null) {
empty($type) && $this->error('参数错误');
import('Org.ThinkSDK.ThinkOauth');
$sns = ThinkOauth::getInstance($type);
redirect($sns->getRequestCodeURL());
}
因为需要第三方类库,所以在头部需要use一下 use ThinkOauth;
第三方类库请到上一篇文章或者下载区找。
第三步:设置配置参数
因为你的参数需要传递给服务器,这样才能远程获取返回的token,用openid和token才能拿到用户的信息。
<?php
/**
* 等三方登陆插件配置
* @date: 2017年12月20日
* @author: yumaster
* @return:
*/
$SITE_URL = "http://yumaster.net/";
define('URL_CALLBACK', "" . $SITE_URL . "Home/Common/callback?type=");
return array(
#腾讯QQ登录配置
'THINK_SDK_QQ' => array(
'APP_KEY' => '101445751', # APP ID
'APP_SECRET' => '85df045b8b38bbad049a9874337ee5b6', # KEY
'CALLBACK' => URL_CALLBACK . 'qq',
),
),
);
所以这个配置是需要自己在网站添加的,我的做法是单独的sdk.php,然后再config.php中 'LOAD_EXT_CONFIG' 加载进来的
需要注意的是:
1.你的网站要填写正确的回调地址,保证要和QQ互联上填写的一样,修改其中一个之后,另一个也要及时修改。否则很难找到这个原因
2.填写在QQ互联的地址是不需要填写参数的,所以这里后面的 ?type=qq 在QQ互联的后台是没有的
3.在传递参数的时候是不允许 yumaster.net/Home/Common/callback/type/qq 这样的写法是错的,需要用 ? 来实现
到这里之后,我们可以在类库中打印出来查看我们的信息是否填写正确,在 ThinkPHP/Library/Org/ThinkSDK/ThinkOauth.class.php 的169行添加:
dump($params);die;
来打印自己的参数是否传递进去,实际上可以不用操作,直接看是不是报错就可以了。
第四步:增加回调函数
在上面我们写的回调地址对应的写上回调方法:common/callback
//QQ登陆回调
public function callback($type = null, $code = null) {
//防止乱码
header("Content-type: text/html; charset=utf-8");
(empty($type) || empty($code)) && $this->error('参数错误');
import('Org.ThinkSDK.ThinkOauth');
$sns = ThinkOauth::getInstance($type);
$extend = null;
//腾讯微博
if ($type == 'tencent') {
$extend = array('openid' => $this->_get('openid'), 'openkey' => $this->_get('openkey'));
}
$tokenArr = $sns->getAccessToken($code, $extend);
/**
* $tokenArr 返回的参数
* array(4) {
* ["access_token"] => string(32) "EF689CF1CEC547B2C3EA7F1367A3D1E8"
* ["expires_in"] => string(7) "7776000"
* ["refresh_token"] => string(32) "1DA94062299F40B1B7686EDB18D3CCE5"
* ["openid"] => string(32) "A100C2E7A02D9AE2E2AD72442275C34C" 用户唯一识别标志
*}
*/
$openid = $tokenArr['openid'];
$token = $tokenArr['access_token'];
if ($openid) {
$field = strtolower($type);
$data = $sns->call('user/get_user_info');
//dump($data);die;
/**
* $data 返回参数
* array(18) {
* ["ret"] => int(0)
* ["msg"] => string(0) ""
* ["is_lost"] => int(0)
* ["nickname"] => string(21) "土伦" 昵称
* ["gender"] => string(3) "男" 性别
* ["province"] => string(0) ""
* ["city"] => string(0) ""
* ["year"] => string(4) "1996" 出生年
* ["figureurl"] => string(73) "http://qzapp.qlogo.cn/qzapp/101445751/A100C2E7A02D9AE2E2AD72442275C34C/30" 空间头像
* ["figureurl_1"] => string(73) "http://qzapp.qlogo.cn/qzapp/101445751/A100C2E7A02D9AE2E2AD72442275C34C/50"
* ["figureurl_2"] => string(74) "http://qzapp.qlogo.cn/qzapp/101445751/A100C2E7A02D9AE2E2AD72442275C34C/100"
* ["figureurl_qq_1"] => string(69) "http://q.qlogo.cn/qqapp/101445751/A100C2E7A02D9AE2E2AD72442275C34C/40" QQ头像
* ["figureurl_qq_2"] => string(70) "http://q.qlogo.cn/qqapp/101445751/A100C2E7A02D9AE2E2AD72442275C34C/100"
* ["is_yellow_vip"] => string(1) "0"
* ["vip"] => string(1) "0"
* ["yellow_vip_level"] => string(1) "0"
* ["level"] => string(1) "0"
* ["is_yellow_year_vip"] => string(1) "0"
*}
*/
$num = M('qq')->where(array("q_img"=>$data["figureurl_qq_2"]))->getField("q_num");
if($num){
$txt = array(
"q_name"=>$data['nickname'],
"q_img"=>$data["figureurl_qq_2"],
"q_ip"=>get_client_ip(),
"q_time"=>time(),
"q_num"=>1,
);
M('qq')->add($data);
}else{
M('qq')->where(array("q_img"=>$data["figureurl_qq_2"]))->setInc("q_num");
}
session("nickname",$data["nickname"]);
session("nickimg",$data["figureurl_qq_2"]);
$this->redirect('Index/index');
} else {
echo "<script>alert('系统出错;请稍后再试!');document.location.href='" . __APP__ . "';</script>";
}
}
在回调的时候我们可以写更多的操作和验证,这里我就简单的判断用户是不是在数据库中,在就访问次数+1,不在就存入数据库。大致上就是这些了。
QQ互联申请及配置的更多相关文章
- 对163k地方门户网站系统QQ互联功能修改
163k地方门户网站QQ互联申请时遇到的问题: "禁止开发商强制用户重新注册或绑定其他帐号" 原因是用户登录完QQ还需要注册帐号或者绑定原有帐号 163k地方门户网站的QQ互联登录 ...
- QQ互联开发-01-开发者注册和网站应用申请
首先需要申请网站应用 要想使用QQ互联,首先需要先注册一个开发者账号,使用QQ号码可以注册,注册后,就可以创建网站应用了: 通过下面地址:https://connect.qq.com/,我们去登录QQ ...
- QQ互联OAuth2.0 .NET SDK 发布以及网站QQ登陆示例代码(转)
OAuth: OAuth(开放授权)是一个开放标准,允许用户授权第三方网站访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方网站或分享他们数据的所有内容. QQ登录OAuth2 ...
- QQ互联OAuth2.0 .NET SDK 发布以及网站QQ登陆示例代码
OAuth: OAuth(开放授权)是一个开放标准,允许用户授权第三方网站访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方网站或分享他们数据的所有内容. QQ登录OAuth2 ...
- 登陆整合实现-QQ互联认证(ASP.NET版本)
原文:登陆整合实现-QQ互联认证(ASP.NET版本) 首先 我们创建一个qq.ashx的页面,这个页面会跳转到QQ的请求界面 代码如下: QQSettingConfig qqSettingConfi ...
- 解决qq互联回调地址错误redirect uri is illegal(100010)的方法,不同于网上大部分方法
我是在用ecshop自己搭建的一个网店系统安装了第三方登录的插件,包括qq登录插件.网上大部分情况都是discuz论坛的这个回调地址出错及解决办法.所以在我出错的时候参考他们的办法并不管用.但是在后面 ...
- Destoon QQ互联一键登录审核不通过的解决方案
在QQ互联上申请帐号之后提交了审核, 后台填写APPID和KEY之后自己申请的QQ号可以正常登录,但QQ互联审核的时候一直审核不通过说是“您的网站审核未通过,原因是“点击QQ登录按钮提示登录失败或出现 ...
- 一元云购qq互联回调地址错误解决办法
经过追踪,点击登录后调用 system/modules/api/下面的qqlogin.action.class.php 里面又调用了qq 互联php接口样例里的QC.php的QC类的方法qq_logi ...
- .Net QQ互联教程
qq互联只需要备案即可申请,申请成功后可以到qq互联官网查看教程,本站开始想使用js的教程但是由于本站需要绑定本站的账号用js教程无法完成,所以使用原始的oauth2.0来完成. 申请qq互联接口 q ...
随机推荐
- 2017广东工业大学程序设计竞赛决赛-tmk买礼物
tmk买礼物 Description 今天是校赛的日子,为了庆祝这么喜庆的日子,TMK打算买些礼物给女票LSH庆祝一下. TMK进入了雪梨超市,然后刚踏入的一瞬间,店主就对TMK说:“恭喜你成为了本店 ...
- 不怕你配置不对,就怕你看的资料不对!MIM 与 SharePoint 同步完全配置指南。
为了更好的同步 User Profile,在 SharePoint 2010 中首次引入了 FIM (ForeFront Identity Manager) 用于编辑 User Profile 的同期 ...
- js 函数声明和函数表达式
在ECMAScript中,创建函数的最常用的两个方法是函数表达式和函数声明,因为ECMA规范只明确了一点:函数声明必须带有标示符(Identifier)(就是大家常说的函数名称),而函数表达式则可以省 ...
- css中单位 px、em 的区别【转载】
原文:http://www.admin10000.com/document/6267.html 在国内网站中,包括三大门户,以及“引领”中国网站设计潮流的蓝色理想,ChinaUI等都是使用了p ...
- html5客户端本地存储之sessionStorage及storage事件
首先您可以看一下<JavaScript本地存储实践(html5的localStorage和ie的userData)>sessionStorage和上文中提到的localStorage非常相 ...
- Python把给定的列表转化成二叉树
在LeetCode上做题时,有很多二叉树相关题目的测试数据是用列表给出的,提交的时候有时会出现一些数据通不过,这就需要在本地调试,因此需要使用列表来构建二叉树,方便自己调试.LeetCode上二叉树结 ...
- Jxl创建Excel文件和解析Excel文件
import java.io.File; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; im ...
- 动态加载js css 插件
简介 动态加载js,css在现在以及将来肯定是很重要的.目前来看前端代码编写的业务量已经远远超过后端编写的.随着对用户体验度逐渐增强,前端业务复杂,加载速度变得很慢很慢.为了解决这个问题,目前出现的两 ...
- word建立统一的表格样式
插入一个表格,一般border都是一样粗细,不美观, 这里推荐一种样式如下图(外框和首行都加粗,比较好看) 设置方法: 1.选中表格,上方出现设计选项卡 2.表格样式,点击"新建样式表&qu ...
- 移动端效果之LoadMore
写在前面 列表一直是展示数据的一个重要方式,在手机端的列表展示又和PC端展示不同,毕竟手机端主要靠滑.之前手机端之前一直使用的IScroll,但是IScroll本身其实有很多兼容性BUG,想改动一下需 ...