php微信上墙,php+ajax实现微信上墙

好久就想实现这个功能了,可是一直没心情,好在收到网易实习的offer,于是心情大好,实现了这个功能来和大家共享。大家可以先看效果吧:只要关注微信公众帐号say_magic,

然后打开网址http://saymaic.sinaapp.com/weixin/wall.php,在公众号里回复:上墙+您要说的话,您就会发现您说的话会同步到上面的网址上。

整个流程大概是这样:

公众号的后台接收到消息并将消息存入数据库,而前台呢,则使用js的setTimeout函数进行循环的使用ajax向后台get数据来获取数据库的最新数据,当明白整个原理后,就显得很简单,接下来看一下主要的代码:

wall.php(微信墙页面 )

include_once("sql.php");

?>

微信墙

#msgBox div {

padding: 19px;

margin-bottom: 20px;

background: #aaaaaa;

border: 2px solid #e3e3e3;

-webkit-border-radius: 4px;

-moz-border-radius: 4px;

border-radius: 4px;

-webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,0.05);

-moz-box-shadow: inset 0 1px 1px rgba(0,0,0,0.05);

box-shadow: inset 0 1px 1px rgba(0,0,0,0.05);

filter:alpha(opacity=60);

/* CSS3 standard */

opacity:0.4;

font-style:italic;

font-size:15px;

width:50%;

}

body{

background: url(bg_main.jpg);

}

$wxQuery = 'SELECT * FROM wx_note ORDER BY id DESC LIMIT 25';//把wx_msg更改掉

$wxResult =$mysql->query($wxQuery);

while ($wxRow=mysql_fetch_row($wxResult)) {

$lastID or $lastID = $wxRow[0];//0代表数据库中的id,这个要和你自己数据库相对应

$content = $wxRow[4];//4也是一样的

echo '

',$content,"
\n";

}

$lastID = (int)$lastID;

?>

var lastID = <?php echo $lastID; ?>;

function getMessages() {

$.ajax({

url: "message.php?lastID=" + lastID + "&v=" + (new Date()/1),

dataType: "json",

error: function(){

alert('Error loading JSON document');

},

success: function(data){//如果调用php成功

$.each(data,function(i,n){

message = '

' + n + '
';

$(message).prependTo('#msgBox').hide().slideDown('slow');

lastID = i;

});

}

});

window.setTimeout(getMessages, 5000);

}

getMessages();

mysql操作文件sql.php:

$hostname = '***********';

$dbuser = '***********';

$dbpass = '***************';

$dbname = '************';

$mysql = new mysql( $hostname,$dbuser,$dbpass,$dbname,'','');

class mysql {

private $db_host; //数据库主机

private $db_user; //数据库用户名

private $db_pwd; //数据库用户名密码

private $db_database; //数据库名

private $conn; //数据库连接标识;

private $result; //执行query命令的结果资源标识

private $sql; //sql执行语句

private $row; //返回的条目数

private $coding; //数据库编码,GBK,UTF8,gb2312

private $bulletin = true; //是否开启错误记录

private $show_error = false; //测试阶段,显示所有错误,具有安全隐患,默认关闭

private $is_error = false; //发现错误是否立即终止,默认true,建议不启用,因为当有问题时用户什么也看不到是很苦恼的

/*构造函数*/

public function __construct($db_host, $db_user, $db_pwd, $db_database, $conn, $coding) {

$this->db_host = $db_host;

$this->db_user = $db_user;

$this->db_pwd = $db_pwd;

$this->db_database = $db_database;

$this->conn = $conn;

$this->coding = $coding;

$this->connect();

}

/*数据库连接*/

public function connect() {

if ($this->conn == "pconn") {

//永久链接

$this->conn = mysql_pconnect($this->db_host, $this->db_user, $this->db_pwd);

} else {

//即使链接

$this->conn = mysql_connect($this->db_host, $this->db_user, $this->db_pwd);

}

if (!mysql_select_db($this->db_database, $this->conn)) {

if ($this->show_error) {

$this->show_error("数据库不可用:", $this->db_database);

}

}

//mysql_query("SET NAMES $this->coding");

}

/*数据库执行语句,可执行查询添加修改删除等任何sql语句*/

public function query($sql) {

if ($sql == "") {

$this->show_error("SQL语句错误:", "SQL查询语句为空");

}

$this->sql = $sql;

$result = mysql_query($this->sql, $this->conn);

if (!$result) {

//调试中使用,sql语句出错时会自动打印出来

if ($this->show_error) {

$this->show_error("错误SQL语句:", $this->sql);

}

} else {

$this->result = $result;

}

return $this->result;

}

}

?>

不断从数据库获取最新数据的文件message.php.

header('Content-Type:text/html; charset=UTF-8');//utf-8,使中文不会变成乱码

/**************************************************************

*

*使用特定function对数组中所有元素做处理

*@paramstring&$array要处理的字符串

*@paramstring$function要执行的函数

*@return boolean$apply_to_keys_also是否也应用到key上

*@access public

*

*************************************************************/

function arrayRecursive(&$array, $function, $apply_to_keys_also = false)

{

static $recursive_counter = 0;

if (++$recursive_counter > 1000) {

die('possible deep recursion attack');

}

foreach ($array as $key => $value) {

if (is_array($value)) {

arrayRecursive($array[$key], $function, $apply_to_keys_also);

} else {

$array[$key] = $function($value);

}

if ($apply_to_keys_also && is_string($key)) {

$new_key = $function($key);

if ($new_key != $key) {

$array[$new_key] = $array[$key];

unset($array[$key]);

}

}

}

$recursive_counter--;

}

function JSON($array) {

arrayRecursive($array, 'urlencode', true);

$json = json_encode($array);

return urldecode($json);

}

$lastID = (int) $_GET['lastID'];

include_once("sql.php");

$backValue=array();

$wxQuery = "SELECT * FROM wx_note WHERE id > ".$lastID." ORDER BY id LIMIT 3";

$wxResult = $mysql->query($wxQuery);

while ($wxRow=mysql_fetch_row($wxResult)) {

$recordID = $wxRow[0];

$content = $wxRow[4];

//$xml=$content;

$backValue[$recordID ] = $content;

}

echo JSON($backValue);

?>

最后,如果需要的话,还有背景图片:

http://www.saymagic.cn/weixin/bg_main.jpg

.

当然,这里说的只是后端的部分,在处理微信消息上,你还需要把收到的消息存入数据库,这应该没什么难度,就不放代码了。这里一定要记得和刚才操作的方法中的数据格式相对应,这是最容易出错的了。好的,如果有什么疑问的话,欢迎留言。

版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2018最新微信微信上墙婚庆会议大屏幕3D签到抽奖摇一摇微信上墙源码。这是我在淘宝上面花了200大洋买的,php版本5.4以上,亲测可用,上墙,抽奖,摇一摇。都可以使用。绝对没有问题。之前在网上花了2天时间也找了一些类似的,有免费下载的,也有包括在csdn上面用5个资源分下载类似的,发现都不能用,至少我在本地或有服务器上都没有调试成功,看了一下他们的代码,发现代码用的是公众号帐号和密码,来模拟微信登陆来获取用户信息。微信已经在2016年就已经停止模似登陆了,登陆微信公众号,必须要扫描后,管理员确认后才可登陆。所以,那些代码都不能用。有些有csdn上传的这些代码基本上不能用(可能2015年前可以用,但是现在不能用),感觉太不负责任了,都是骗积分的。当时因为公司年会要弄个微信上墙及现在抽奖活动,找这个代码也很辛苦,相信大家也一样辛苦,所以,把代码放出来,供大家下载学习使用。这个代码,我是在淘宝上买的,本身内置了第三方的微信公众号授权,所以,如果你的公众号没有微信认证也可以用,直接扫码就可以发送微信上墙弹幕,不会出现第三方公众号信息。如果你的微信公众号认证了,就用自己的,后台可以配置,填写你的公众号appid和appsecret即可。好了,不多说了,大家下 载使用,如果不能用,我退积分。不清楚的,大家可以在评论区留言。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值