php实现即时聊天(基于融云通讯)
程序员文章站
2022-05-14 11:21:21
...
php实现即时聊天(基于融云通讯),目前只是简单的事例。
今天看到了一个挺有意思的项目,即时聊天工具。虽然有QQ这样很普及的聊天工具了,但是自己搞一个还是挺有意思的。
本案例是基于融云通讯的,官网地址http://www.rongcloud.cn/,功能很多,我由于没有很好看的页面,直接用他们的插件,据我观察,插件只有最近联系人这个功能。那就先按照简单的案例先实现吧,喜欢的可以自己继续研究!
首先需要注册一个融云账号---然后自己去创建一个实例----查看各种KEY,具体的自己按照官网的指引去看吧。我给的例子是我的一个测试key,可以直接去用。依旧是tp5框架,自己不会配置tp5框架的,我就不说什么了。没有用数据库去实现用户信息,简单的实现功能,主要是给大家演示一下功能,勿喷啊。
配置各种key的config.php
Index.php
首先访问首页,没登录的话会跳转登录:
如果你用的是张三登录的话,记住:张三的id是1,很重要!用户名正确进行,密码乱输就行。登录之后,页面如下:
输入会话的ID,也就是用户ID,我们向李四说话,李四就是2,然后点击设置会话,会弹出如下页面:
开始聊天吧:
然后重新打开一个浏览器,一定是另外一个浏览器!登录,用李四去登录,你会看到:
看到张三给你发信息了,打开看看吧:
也可以回复:
哈哈是不是很有意思。当然我现在只实现了最最简单的功能,有兴趣的可以继续研究!
项目下载地址:https://github.com/nick-bai/talking,如果没看到的话,项目正在上传,稍后在看就可以看到了。对你有帮助的话,给我打个星。
今天看到了一个挺有意思的项目,即时聊天工具。虽然有QQ这样很普及的聊天工具了,但是自己搞一个还是挺有意思的。
本案例是基于融云通讯的,官网地址http://www.rongcloud.cn/,功能很多,我由于没有很好看的页面,直接用他们的插件,据我观察,插件只有最近联系人这个功能。那就先按照简单的案例先实现吧,喜欢的可以自己继续研究!
首先需要注册一个融云账号---然后自己去创建一个实例----查看各种KEY,具体的自己按照官网的指引去看吧。我给的例子是我的一个测试key,可以直接去用。依旧是tp5框架,自己不会配置tp5框架的,我就不说什么了。没有用数据库去实现用户信息,简单的实现功能,主要是给大家演示一下功能,勿喷啊。
配置各种key的config.php
//配置文件
return [
'APP_KEY' => 'e0x9wycfxxx5q',
'APP_SECRET' => 'F7sI8rkLtv'
];
他们给的key好短啊有没有,继续吧。我下载了官方给的SDK,已经引入到extend文件下了。可以直接调用了。开始主要的部分吧,聊天页面的主方法:Index.php
namespace app\index\controller;
use rongyun\ServerAPI;
use think\Controller;
class Index extends Controller
{
public function _initialize()
{
if( empty( cookie('uid') ) ){
$this->redirect( url('login/index') );
}
}
//聊天主方法
public function index()
{
$appKey = config('APP_KEY');
$appSecret = config('APP_SECRET');
$rongYun = new ServerAPI( $appKey, $appSecret );
$tx = "http://www.tk.com/static/images/1.jpg";
if( 2 == cookie('uid') ){
$tx = "http://www.tk.com/static/images/2.jpg";
}
$token = $rongYun->getToken( cookie('uid'), cookie('uname'), $tx );
$token = json_decode( $token, true )['token'];
$this->assign([
'token' => $token
]);
return $this->fetch();
}
//所有的用户信息
public function userInfo()
{
$return['userlist'] = [
['id' => 1, 'name' => '张三', 'portraitUri' => 'http://www.tk.com/static/images/1.jpg'],
['id' => 2, 'name' => '李四', 'portraitUri' => 'http://www.tk.com/static/images/2.jpg']
];
return json( $return );
}
//登录用户信息
public function onLine()
{
$return['data'] = [
['id' => '1', 'status' => true],
['id' => '2', 'status' => true]
];
return json( $return );
}
}
各种代码我都写死了,主要是演示效果的。好了,其余的代码,可以去我的github上去下载自己去官网对照这个看吧。我主要演示一下具体怎么跑起来。看一下login.php吧:
namespace app\index\controller;
use think\Controller;
class Login extends Controller
{
public function index()
{
return $this->fetch();
}
public function doLogin()
{
$param = input('param.');
if( '张三' == $param['uname'] ){
cookie('uid', 1);
cookie('uname', '张三');
}else if( '李四' == $param['uname'] ){
cookie('uid', 2);
cookie('uname', '李四');
}
$this->redirect( url('index/index') );
}
}
哈哈,我的登录只是为了区分用户(真的做项目可不是这样!)。可以看到吧,一个用户是张三,一个用户是李四。密码乱输就行。看一下演示效果吧:首先访问首页,没登录的话会跳转登录:
如果你用的是张三登录的话,记住:张三的id是1,很重要!用户名正确进行,密码乱输就行。登录之后,页面如下:
输入会话的ID,也就是用户ID,我们向李四说话,李四就是2,然后点击设置会话,会弹出如下页面:
开始聊天吧:
然后重新打开一个浏览器,一定是另外一个浏览器!登录,用李四去登录,你会看到:
看到张三给你发信息了,打开看看吧:
也可以回复:
哈哈是不是很有意思。当然我现在只实现了最最简单的功能,有兴趣的可以继续研究!
项目下载地址:https://github.com/nick-bai/talking,如果没看到的话,项目正在上传,稍后在看就可以看到了。对你有帮助的话,给我打个星。
上一篇: 正确的注销PHP SESSION