我在javascript中运行一个普通的TCP套接字并使用node来执行。在我将响应发送回客户端之前,我想用一些php(mysql)代码验证数据。 如何在这个javascript文件中执行此代码? STACKOVERFLOW中的所有类似问题都在HTML中询问此代码。 (这是好的,我理解那部分),但这是一个普通的javascript文件(在节点中执行)。 javascript代码如下,我已经标记了验证函数调用。
var net = require('net');
var HOST = '192.168.0.6';
var PORT = 8765;
net.createServer(function(sock) {
console.log('CONNECTED: ' + sock.remoteAddress +':'+ sock.remotePort);
sock.on('data', function(data) {
var output;
var validScan;
//This is the function call to a php file
**validScan = validateScanTag(data);**
console.log('DATA ' + sock.remoteAddress + ': ' + data);
sock.write(validScan);
});
// Closing this instance of socket
sock.on('close', function(data) {
console.log('CLOSED: ' + sock.remoteAddress +' '+ sock.remotePort);
});
}).listen(PORT, HOST);
console.log('Server listening on ' + HOST +':'+ PORT);
validateScanTag执行一行lke:
$.post('getperiod.php', {hours:hrs, minutes:mins, seconds:secs, ddd:day},
但这不起作用。如何从javascript文件中调用此“geteriod.php”文件?
答案 0 :(得分:1)
我很确定问题本身值得重新思考(例如,将你的mysql代码从php移植到节点)但这是我的解决方案:
var net = require('net');
var PORT = 8765;
var Lazy=require('lazy');
var spawn = require('child_process').spawn;
// php code runs as a server in external process
var validator = spawn('php', ['validator.php']);
net.createServer(function(sock) {
console.log('CONNECTED: ' + sock.remoteAddress +':'+ sock.remotePort);
// on 'data' handler is not enough to read input line by line
// you need to buffer data, use some kind of state machine or one of available stream parsers. I use lazy here: npm install lazy
// write each line to php validation code
new Lazy(sock).lines.forEach(function(line) {
console.log('DATA ' + sock.remoteAddress + ': ' + line.toString());
validator.stdin.write(line);
validator.stdin.write('\n');
});
// read validation result line by line from validator process
new Lazy(validator.stdout).lines.forEach(function(line) {
console.log('Validation result:' + line.toString()) // line is Buffer object here, hence toString
});
validator.stdout.pipe(process.stdout);
// Closing this instance of socket
sock.on('close', function() {
console.log('CLOSED');
});
}).listen(PORT);
validator.php应该从stdin读取并写入stdout
<?
function validatescanTag($l) {
// put your validation code here
return $l . '!!!!';
}
$stdin = fopen('php://stdin', 'r');
do {
$line = fgets($stdin);
print validateScanTag($line);
} while(1);
?>
另一种选择是使用fastcgi protocol来传达节点&lt; - &gt; php或dnode rpc。或者只使用http并从nginx / apache运行php(甚至是node-php)
答案 1 :(得分:0)
提供更通用的答案以澄清和“让你了解”的方法:
据我所知,你试图使用node.js服务器调用的http post请求来运行你的php脚本。
您可能首先必须意识到运行服务器端JavaScript通常具有不同的动机和可能性以及对您的体系结构的影响,而不是在浏览器中运行JS - 至少在经典的“jQuery意义”中。
正如您的评论中所述,您希望jQuery在服务器端node.js中无缝工作。这不适用于评论发布的ReferenceError: $ is not defined
向您展示。你的node.js堆栈中没有可用的服务器端jQuery开箱即用(使用jQuery服务器端的可能性应该单独讨论,是另一个主题)。
然而,您显然正在寻找一种方法来重用PHP脚本,该脚本已经处理了您的mysql数据连接并通过利用服务器端进行处理。使用http 执行此操作可能会显示in this stackoverflow post或in the http.request section of the node.js documentation。如果您的php脚本与node.js运行在同一服务器(或更好的运行时环境)上,您也可以通过使用php standalone将其作为子进程生成,直接执行php脚本(命令行)实用程序。
最后但并非最不重要:是的,有一些方法(npm模块,ORM层)可以直接用你的node.js应用程序连接mysql。但这是另一个复杂的主题,并在其他地方进行了讨论。
我希望这有助于避免混淆那些不应混淆的事情。
答案 2 :(得分:0)
PHP中有一个PHP扩展embedding Chrome's V8 engine。