更新
要求:
- 首先运行 redis。
- 接下来启动 socket.io。
- 终于上传/托管 PHP(存档中有依赖项)。
Socket.io
var express = require('express'),
app = express.createServer(),
sio = require('socket.io'),
redis = require("redis"),
client = redis.createClient(),
io = null;
/**
* Used to parse cookie
*/
function parse_cookies(_cookies) {
var cookies = {};
_cookies && _cookies.split(';').forEach(function( cookie ) {
var parts = cookie.split('=');
cookies[ parts[ 0 ].trim() ] = ( parts[ 1 ] || '' ).trim();
});
return cookies;
}
app.listen(3000, "localhost");
io = sio.listen(app);
io.of('/private').authorization(function (handshakeData, callback) {
var cookies = parse_cookies(handshakeData.headers.cookie);
client.get(cookies.PHPSESSID, function (err, reply) {
handshakeData.identity = reply;
callback(false, reply !== null);
});
}).on('connection' , function (socket) {
socket.emit('identity', socket.handshake.identity);
});
PHP
带有openid认证的php => http://dl.dropbox.com/u/314941/6503745/php.tar.gz
登录后您必须重新加载client.php 进行身份验证
p.s:我真的不喜欢创建另一个可能不安全的密码的概念。我建议你看看openID(例如通过Google),Facebook Connect(仅举几个选项)。
我的问题是一旦他们认证
通过 php/session 会是什么
对用户进行身份验证的过程
看看他们是否有正确的登录名
访问 nodejs 服务器的权限
与socket.io?我不想要那个人
可以访问 nodejs/socket.io
功能/服务器,除非他们有
通过php登录进行身份验证。
将唯一的session_id 添加到允许的 id 列表/集,以便 socket.io 可以authorize(搜索授权功能)该连接。我会让 PHP 使用 redis 与 node.js 通信,因为这将是闪电般的快速/真棒:)。现在我正在伪造来自redis-cli的PHP通信
安装 Redis
Download redis => 现在可以从http://redis.googlecode.com/files/redis-2.2.11.tar.gz下载稳定版
alfred@alfred-laptop:~$ mkdir ~/6502031
alfred@alfred-laptop:~/6502031$ cd ~/6502031/
alfred@alfred-laptop:~/6502031$ tar xfz redis-2.2.11.tar.gz
alfred@alfred-laptop:~/6502031$ cd redis-2.2.11/src
alfred@alfred-laptop:~/6502031/redis-2.2.11/src$ make # wait couple of seconds
启动 Redis-server
alfred@alfred-laptop:~/6502031/redis-2.2.11/src$ ./redis-server
Socket.io
npm 依赖项
如果npm尚未安装,请先访问http://npmjs.org
npm install express
npm install socket.io
npm install redis
根据npm ls列出我已经安装的依赖项,你也应该安装它们以防不兼容
alfred@alfred-laptop:~/node/socketio-demo$ npm ls
/home/alfred/node/socketio-demo
├─┬ express@2.3.12
│ ├── connect@1.5.1
│ ├── mime@1.2.2
│ └── qs@0.1.0
├── hiredis@0.1.12
├── redis@0.6.0
└─┬ socket.io@0.7.2
├── policyfile@0.0.3
└── socket.io-client@0.7.2
var express = require('express'),
app = express.createServer(),
sio = require('socket.io'),
redis = require("redis"),
client = redis.createClient(),
io = null;
/**
* Used to parse cookie
*/
function parse_cookies(_cookies) {
var cookies = {};
_cookies && _cookies.split(';').forEach(function( cookie ) {
var parts = cookie.split('=');
cookies[ parts[ 0 ].trim() ] = ( parts[ 1 ] || '' ).trim();
});
return cookies;
}
app.listen(3000, "localhost");
io = sio.listen(app);
io.configure(function () {
function auth (data, fn) {
var cookies = parse_cookies(data.headers.cookie);
console.log('PHPSESSID: ' + cookies.PHPSESSID);
client.sismember('sid', cookies.PHPSESSID, function (err , reply) {
fn(null, reply);
});
};
io.set('authorization', auth);
});
io.sockets.on('connection', function (socket) {
socket.emit('access', 'granted');
});
要运行服务器,只需运行node server.js
<?php
session_start();
echo "<h1>SID: " . session_id() . "</h1>";
?>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script>
<script src="http://localhost:3000/socket.io/socket.io.js"></script>
</head>
<body>
<p id="text">access denied</p>
<script>
var socket = io.connect('http://localhost:3000/');
socket.on('access', function (data) {
$("#text").html(data);
});
</script>
</body>
测试认证
当您从 Web 浏览器加载网页(PHP 文件)时,会显示消息 access denied,但是当您将浏览器中也显示的 session_id 添加到 redis 服务器时,将显示消息 access granted。当然通常你不会做任何复制粘贴,而是让 PHP 直接与 Redis 通信。。但是对于这个演示,您将 SID ramom807vt1io3sqvmc8m4via1 放入 redis 中,然后授予访问权限。
alfred@alfred-laptop:~/database/redis-2.2.0-rc4/src$ ./redis-cli
redis> sadd sid ramom807vt1io3sqvmc8m4via1
(integer) 1
redis>