随着技术的发展;现代的网站;越来越趋于应用形式了;
不再是像以前那样需要用户刷新页面;获取数据了;
服务器端可以主动向用户推送数据;更加及时性了;
比较突出的就是即时通讯在线聊天;
今个;我们要打造的就是类似于网页版微信的功能;
示例项目:https://github.com/baijunyao/thinkphp-bjyadmin
一:注册融云账号
如果我们不是以即时通讯为主营业务;那么建议使用第三方的服务;这里以融云为例;
注册融云;创建应用;获得App Key和App Secret;
二:设置配置项
/Application/Common/Conf/config.php
1
2
3
4
5
|
'RONG_IS_DEV' => true, //是否是在开发中 'RONG_DEV_APP_KEY' => '8luwapkvu3xwl' , //融云开发环境下的key 仅供测试使用 'RONG_DEV_APP_SECRET' => '1Aw1D7F6Td25' , //融云开发环境下的SECRET 仅供测试使用 'RONG_PRO_APP_KEY' => '' , //融云生产环境下的key 'RONG_PRO_APP_SECRET' => '' , //融云生产环境下的SECRET |
将key和sercet替换为自己应用;
三:集成php部分sdk
引入融云sdk:/ThinkPHP/Library/Org/Xb/RongCloud.class.php
公共函数:/Application/Common/Common/function.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
/** * 根据配置项获取对应的key和secret * @return array key和secret */ function get_rong_key_secret(){ // 判断是需要开发环境还是生产环境的key if (C( 'RONG_IS_DEV' )) { $key =C( 'RONG_DEV_APP_KEY' ); $secret =C( 'RONG_DEV_APP_SECRET' ); } else { $key =C( 'RONG_PRO_APP_KEY' ); $secret =C( 'RONG_PRO_APP_SECRET' ); } $data = array ( 'key' => $key , 'secret' => $secret ); return $data ; } /** * 获取融云token * @param integer $uid 用户id * @return integer token */ function get_rongcloud_token( $uid ){ // 从数据库中获取token $token =D( 'OauthUser' )->getToken( $uid ,1); // 如果有token就返回 if ( $token ) { return $token ; } // 获取用户昵称和头像 $user_data =M( 'Users' )->field( 'username,avatar' )->getById( $uid ); // 用户不存在 if ( empty ( $user_data )) { return false; } // 获取头像url格式 $avatar =get_url( $user_data [ 'avatar' ]); // 获取key和secret $key_secret =get_rong_key_secret(); // 实例化融云 $rong_cloud = new \Org\Xb\RongCloud( $key_secret [ 'key' ], $key_secret [ 'secret' ]); // 获取token $token_json = $rong_cloud ->getToken( $uid , $user_data [ 'username' ], $avatar ); $token_array =json_decode( $token_json ,true); // 获取token失败 if ( $token_array [ 'code' ]!=200) { return false; } $token = $token_array [ 'token' ]; $data = array ( 'uid' => $uid , 'type' =>1, 'nickname' => $user_data [ 'username' ], 'head_img' => $avatar , 'access_token' => $token ); // 插入数据库 $result =D( 'OauthUser' )->addData( $data ); if ( $result ) { return $token ; } else { return false; } } /** * 更新融云头像 * @param integer $uid 用户id * @return boolear 操作是否成功 */ function refresh_rongcloud_token( $uid ){ // 获取用户昵称和头像 $user_data =M( 'Users' )->field( 'username,avatar' )->getById( $uid ); // 用户不存在 if ( empty ( $user_data )) { return false; } $avatar =get_url( $user_data [ 'avatar' ]); // 获取key和secret $key_secret =get_rong_key_secret(); // 实例化融云 $rong_cloud = new \Org\Xb\RongCloud( $key_secret [ 'key' ], $key_secret [ 'secret' ]); // 更新融云用户头像 $result_json = $rong_cloud ->userRefresh( $uid , $user_data [ 'username' ], $avatar ); $result_array =json_decode( $result_json ,true); if ( $result_array [ 'code' ]==200) { return true; } else { return false; } } |
写一个控制器用来获取token、好友列表的头像和用户名:/Application/Api/Controller/RongController.class.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
/** * 获取token */ public function get_token(){ // 获取用户id $uid =get_uid(); // 获取token $token =get_rongcloud_token( $uid ); $data = array ( 'token' => $token ); ajax_return( $data , '获取成功' ,0); } /** * 传递一个、或者多个用户id * 获取用户头像用户名;用来组合成好友列表 */ public function get_user_info(){ $uids =I( 'post.uids' ); // 组合where数组条件 $map = array ( 'id' => array ( 'in' , $uids ) ); $data =M( 'Users' ) ->field( 'id,username,avatar' ) ->where( $map ) ->select(); ajax_return( $data , '获取用户数据成功' ,0); } |
四:集成前端部分
html要引入融云js的sdk;
1
2
|
< script src = "http://cdn.ronghub.com/RongIMLib-2.0.6.beta.min.js" ></ script > < script src = "http://cdn.ronghub.com/RongEmoji-2.0.2.beta.min.js" ></ script > |
然后下面是我痛苦的研究了融云的sdk后简化了的使用方法;
/Public/statics/rongcloud/js/main.js
然后配置html即可;
/tpl/Home/Index/user1.html
/tpl/Home/Index/user2.html
最终的效果是这样的:
当然;样式可以自己改;
测试项目示例的时候;切记使用两个不同的浏览器分别打开代表两个用户的链接;
用来模拟是两个用户在聊天;
出处:http://baijunyao.com/article/72