正文
昨天群里有人问到dux主题的评论处输入QQ号直接获取名称和头像是怎么实现的,我看了一下dux主题,发现并没有集成这个功能,倒是emlog的dux主题内置了这个功能,本来想移植过来wordpress的,但是发现emlog和wp的评论模块不一样,几乎要重写整个样式和js才能实现,我果断的放弃了,然后就想到了QQ空间的接口,可以直接获取QQ头像和名称,下面分享给小伙伴们。
HTML代码
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>在线获取QQ用户名和头像</title>
</head>
<body>
<div> QQ <input type="text" name="" id="qqnum" value="" /></div><br>
<div> 昵称 <input type="text" name="" id="comname" value="" /></div><br>
<div> 邮箱 <input type="text" name="" id="commail" value="" /></div><br>
<div id="avatar"></div>
<script src="https://cdn.bootcss.com/jquery/1.11.1/jquery.min.js"></script>
<script>
$("#qqnum").blur(function() {
var qq = $("#qqnum").val();
$("#commail").val(qq + "@qq.com");
$.ajax({
type: "get",
url: "https://v1.ikxin.com/api/qqname.php?a=getqqnickname&qq=" + qq,
dataType: "jsonp",
jsonp: "callback",
jsonpCallback: "portraitCallBack",
success: function(data) {
$("#comname").val(data[qq][6]);
},
error: function() {
$("#comname").val("获取失败");
}
});
$.ajax({
type: "get",
url: "https://v1.ikxin.com/api/qqname.php?a=getqqavatar&qq=" + qq,
dataType: "jsonp",
jsonp: "callback",
jsonpCallback: "qqavatarCallBack",
success: function(data) {
$("#avatar").html("<img src='" + data[qq] + "'>");
},
error: function() {
alert("获取失败");
}
});
})
</script>
</body>
</html>
PHP代码
<?php
header("content-Type: text/html; charset=UTF-8");
$a = @$_GET['a'] ? $_GET['a'] : '';
if(empty($a)){
header("Location: ../");
exit;
}
// 获取QQ昵称
if($a == "getqqnickname"){
$qq = isset($_GET['qq']) ? addslashes(trim($_GET['qq'])) : '';
if(!empty($qq) && is_numeric($qq) && strlen($qq) > 4 && strlen($qq) < 13){
$qqnickname = file_get_contents('http://users.qzone.qq.com/fcg-bin/cgi_get_portrait.fcg?uins='.$qq);
if($qqnickname){
$qqnickname = mb_convert_encoding($qqnickname, "UTF-8", "GBK");
echo $qqnickname;
}
}
}
// 获取QQ头像
if($a == "getqqavatar"){
$qq = isset($_GET['qq']) ? addslashes(trim($_GET['qq'])) : '';
if(!empty($qq) && is_numeric($qq) && strlen($qq) > 4 && strlen($qq) < 13){
$qqavatar_1 = file_get_contents('http://ptlogin2.qq.com/getface?appid=52958812&imgtype=4&uin='.$qq);
$qqavatar = str_replace('http', 'https', $qqavatar_1);
if($qqavatar){
echo str_replace('pt.setHeader', 'qqavatarCallBack', $qqavatar);
}
}
}
注意
获取到的QQ头像是http模式