欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

多说评论实时同步回数据库

程序员文章站 2022-05-03 20:09:55
...
多说评论实时同步回数据库,依赖Http库,随便找一个就行

/**
* 多说 实时同步评论回本地数据库 API
*/
namespace Home\Controller;
use Think\Controller;
class DuoshuoController extends Controller {
public function duoshuo(){

if (check_signature($_POST)) {

$Comment = M('comment');
$where['name'] = array('in','last_log_id');
$last_log_id = M('setting')->where($where)->getField('value');
Vendor('CurlHTTP.Http');

$limit = 20;

$params = array(
'limit' => $limit,
'order' => 'asc',
);


$posts = array();

if (!$last_log_id)
$last_log_id = 0;

$params['since_id'] = $last_log_id;
$params['short_name'] = C(DUOSHUO_SHORT_NAME);
$params['secret'] = C(DUOSHUO_SECRET);
$http_client = new \Http();
$response = $http_client->request('http://api.duoshuo.com/log/list.json', $params ,'GET');

$response = json_decode($response,true);

if (!isset($response['response'])) {
//处理错误,错误消息$response['message'], $response['code']
file_log("签名错误");
} else {
//遍历返回的response,你可以根据action决定对这条评论的处理方式。
foreach($response['response'] as $k => $log){
switch($log['action']){
case 'create':
foreach ($log['meta'] as $key => $value) {
$create[$key]['post_id'] = $log['meta']['post_id'];
$create[$key]['thread_id'] = $log['meta']['thread_id'];
$create[$key]['author_id'] = $log['meta']['author_id'];
$create[$key]['author_name'] = $log['meta']['author_name'];
$create[$key]['author_email'] = $log['meta']['author_email'];
$create[$key]['author_url'] = $log['meta']['author_url'];
$create[$key]['author_key'] = $log['meta']['author_key'];
$create[$key]['ip'] = $log['meta']['ip'];
$create[$key]['created_at'] = $log['meta']['created_at'];
$create[$key]['message'] = $log['meta']['message'];
$create[$key]['status'] = $log['meta']['status'];
$create[$key]['type'] = $log['meta']['type'];
if($log['meta']['parent_id'] != ""){
$create[$key]['parent_id'] = $log['meta']['parent_id'];
}
$create[$key]['thread_key'] = $log['meta']['thread_key'];
$create[$key]['user_id'] = $log['user_id'];
$create[$key]['date'] = $log['date'];
}
break;
case 'approve':
//这条评论是通过的评论
foreach ($log['meta'] as $key => $value) {
$approve[$key]['post_id'] .= $value.",";
}
break;
case 'spam':
//这条评论是标记垃圾的评论
foreach ($log['meta'] as $key => $value) {
$spam[$key]['post_id'] .= $value.",";
}
break;
case 'delete':
//这条评论是删除的评论
foreach ($log['meta'] as $key => $value) {
$delete[$key]['post_id'] .= $value.",";
}
break;
case 'delete-forever':
//彻底删除的评论
foreach ($log['meta'] as $key => $value) {
$delete_forever[$key]['post_id'] .= $value.",";
}
break;
default:
break;
}
// 更新处理数据
switch($log['action']){
case 'create':
foreach ($create as $key => $value) {
if($value != ""){
$Comment->add($value);
}
break;
}
case 'approve':
//这条评论是通过的评论
foreach ($approve as $key => $value) {
if($value != ""){
$Comment->where(array('post_id'=>array('in',''. substr($value['post_id'], 0,-1) .'')))->setField('status','approved');
}
}
break;
case 'spam':
//这条评论是标记垃圾的评论
foreach ($spam as $key => $value) {
if($value != ""){
$Comment->where(array('post_id'=>array('in',''. substr($value['post_id'], 0,-1) .'')))->setField('status','spam');
}
}
break;
case 'delete':
//这条评论是删除的评论
foreach ($delete as $key => $value) {
if($value != ""){
$Comment->where(array('post_id'=>array('in',''. substr($value['post_id'], 0,-1) .'')))->setField('status','delete');
}
}
break;
case 'delete-forever':
//彻底删除的评论
foreach ($delete_forever as $key => $value) {
if($value != ""){
$Comment->where(array('post_id'=>array('in',''. substr($value['post_id'], 0,-1) .'')))->delete();
}
}
break;
default:
break;
}
//更新last_log_id,记得维护last_log_id。(如update你的数据库)
if (strlen($log['log_id']) > strlen($last_log_id) || strcmp($log['log_id'], $last_log_id) > 0) {
M('setting')->where(array('name'=>"last_log_id"))->setField('value',$log['log_id']);
}
}
}

}

}
}
/**
*
* 多说检查签名
*
*/
function check_signature($input){

$signature = $input['signature'];
unset($input['signature']);

ksort($input);
$baseString = http_build_query($input, null, '&');
$expectSignature = base64_encode(hmacsha1($baseString, C(DUOSHUO_SECRET)));
if ($signature !== $expectSignature) {
return false;
}
return true;
}


// from: http://www.php.net/manual/en/function.sha1.php#39492
// Calculate HMAC-SHA1 according to RFC2104
// http://www.ietf.org/rfc/rfc2104.txt
// 多说
function hmacsha1($data, $key) {
if (function_exists('hash_hmac'))
return hash_hmac('sha1', $data, $key, true);

$blocksize=64;
if (strlen($key)>$blocksize)
$key=pack('H*', sha1($key));
$key=str_pad($key,$blocksize,chr(0x00));
$ipad=str_repeat(chr(0x36),$blocksize);
$opad=str_repeat(chr(0x5c),$blocksize);
$hmac = pack(
'H*',sha1(
($key^$opad).pack(
'H*',sha1(
($key^$ipad).$data
)
)
)
);
return $hmac;
}
配置

//多说
'DUOSHUO_SECRET'=>'78bd15a3d4fb3000657741a1319bbbbe',
'DUOSHUO_SHORT_NAME'=>'muxu',

参考 http://dev.duoshuo.com/threads/50037b11b66af78d0c000009


网站/微信/App/技术交流:QQ群 74976648

AD:真正免费,域名+虚机+企业邮箱=0元