centos下php socket连接
最近要做一个基于tcp/ip下的短连接
我们自己的代码使用的是php的socket连接,对方服务器,已经测试能够连接,并接收到对方传回来的数据;
现在要求我们自己也需要搭建一个socket服务器,要求对方也可以连接我们服务器,获取相关数据。
以前没有做个socket连接,刚刚接触
服务器也已经设置了一个端口好,可以telnet访问
看网络很多关于socket的php介绍,一些例子也使用了,服务器端的文件,总是不能被访问返回数据
有朋友做个这方面的吗?
帮忙一下
怎么写服务器端文件,怎么实时监听到该socket端口有socket请求,并返回数据个对方
谢谢了
------解决方案--------------------
是的,端口被打开了就不能复用
所以通讯时需要先打开一个周知的端口,一旦监听到该端口有信息时
就需要打开一个空闲端口,并将该端口通知对方,用于后续的通讯
服务方的主监听程序需要常驻内存,只能启动一次
通讯是通过子进程进行的
需要注意的是:php 适合做客户端,而不适合做服务端
可能以后更高的版本会有所改变,至少在php5.5也还是没有改变(虽然已经列入开发计划)
------解决方案--------------------
如果你需要xml进行通信的话,webservice就是最好的选择。你可以了解一下webservice,比如soap。你只要开放webservice对方调用就可以,而且对方可以是任何语言或程序。
------解决方案--------------------
楼主要的东西其实就是RPC,我有一个,你可以直接拿去用,
https://github.com/walkor/workerman
开发文档在:http://www.workerman.net/documentation
安装部署开发都非常方便。
如果有啥不明白,可以随时联系我
------解决方案--------------------
<br />//server.php<br />set_time_limit(0);<br />// Set up our socket<br />$commonProtocol = getprotobyname("tcp");<br />$socket = socket_create(AF_INET, SOCK_STREAM, $commonProtocol);<br />socket_bind($socket, '192.168.10.224', 50004);<br />socket_listen($socket,5);<br />// Initialize the buffer<br />$buffer = "";<br />while(true)<br />{<br /> $run=file_get_contents("./run.txt");<br /> if($run==0)break;<br /> // Accept any connections coming in on this socket<br /> <br /> $connection = socket_accept($socket);<br /> printf("Socket 链接中\r\n");<br /> // Check to see if there is anything in the buffer<br /> if($buffer != "")<br /> {<br /> printf("写入开始 缓冲区内容发送..\r\n");<br /> socket_write($connection, $buffer . "\r\n");<br /> printf("写入结束 \r\n");<br /> }<br /> else<br /> {<br /> printf("缓冲区无数据\r\n");<br /> }<br /> // Get the input socket_read($connection, 1024)<br /> while($data = socket_read($connection, 4096))<br /> {<br /> if($run==0)break;<br /> $buffer = $data;<br /> //写入客户端数据<br /> file_put_contents("./txt.txt", json_encode($data)."\n",FILE_APPEND);<br /> socket_write($connection, "Information Received\r\n");<br /> printf("读结束 缓冲区内容: " . $buffer . "\r\n");<br /> }<br /> socket_close($connection);<br /> printf("关闭 socket\r\n\r\n");<br />}<br /><br />//命令行里 输入: php server.php<br /><br />//client.php 直接浏览器访问<br />$stime = microtime(true);<br />$fp = stream_socket_client("tcp://192.168.10.224:50004", $errno, $errstr, 30,STREAM_CLIENT_CONNECT <br><font color='#FF8000'>------解决方案--------------------</font><br> STREAM_CLIENT_PERSISTENT);<br />if (!$fp) {<br /> echo "$errstr ($errno)<br />\n";<br />} else {<br /> <br /> fwrite($fp,$msg,mb_strlen($msg));<br /> <br /> echo fread($fp, 4096)."\n";<br /> fclose($fp);<br />}<br /><br />$etime = microtime(true);<br /><br />echo "Time: " . ($etime - $stime) . "n";<br /><br /><br />//我目前杀掉占用端口太麻烦,直接用文件控制退出 。run.txt 文件存 0或1 <br />

Um die Anwendung vor Sitzungsangriffen im Zusammenhang mit den Sitzungen zu schützen, sind folgende Maßnahmen erforderlich: 1. Stellen Sie die HTTPonly- und sicheren Flags ein, um die Sitzungs Cookies zu schützen. 2. Exportcodes für alle Benutzereingaben. 3. Implementieren Sie die Inhaltssicherheitsrichtlinie (CSP), um die Skriptquellen einzuschränken. Durch diese Richtlinien können Sitzungsangriffe im Zusammenhang mit Sitzungen effektiv geschützt und Benutzerdaten sichergestellt werden.

Methoden zur Optimierung der PHP -Sitzungsleistung gehören: 1. Start der Verzögerung der Sitzung, 2. Verwenden Sie Datenbank zum Speichern von Sitzungen, 3. Kompress -Sitzungsdaten, 14. Sitzungslebenszyklus verwalten und 5. Sitzungsfreigabe implementieren. Diese Strategien können die Effizienz von Anwendungen in hohen Parallelitätsumgebungen erheblich verbessern.

Thesession.gc_maxlifetimesettingInphpdeterminesthelifspanofSessionData, setInseconds.1) ItsconfiguredInphp.iniorviaini_Set (). 2) AbalanceIsneedToAvoidPerformanceSandunexexwortedyg -Probablogouts

In PHP können Sie die Funktion Session_name () verwenden, um den Sitzungsnamen zu konfigurieren. Die spezifischen Schritte sind wie folgt: 1. Verwenden Sie die Funktion Session_name (), um den Sitzungsnamen wie Session_name ("my_Session") festzulegen. 2. Nachdem Sie den Sitzungsnamen festgelegt haben, call Session_start (), um die Sitzung zu starten. Das Konfigurieren von Sitzungsnamen kann Sitzungsdatenkonflikte zwischen mehreren Anwendungen vermeiden und die Sicherheit verbessern, aber auf die Einzigartigkeit, Sicherheit, Länge und Festlegen des Zeitpunkts der Sitzungsnamen achten.

Die Sitzungs -ID sollte regelmäßig bei Anmeldung, vor sensiblen Operationen und alle 30 Minuten regeneriert werden. 1. Regenerieren Sie die Sitzungs -ID, wenn Sie sich anmelden, um festgelegte Angriffe zu verhindern. 2.. Genieren Sie vor sensiblen Operationen, um die Sicherheit zu verbessern. 3. Die regelmäßige Regeneration reduziert das langfristige Nutzungsrisiko, aber die Benutzererfahrung muss abgewogen werden.

Das Einstellen von Sitzungs -Cookie -Parametern in PHP kann über die Funktion Session_set_cookie_params () erreicht werden. 1) Verwenden Sie diese Funktion, um Parameter wie Ablaufzeit, Pfad, Domänenname, Sicherheitsflag usw. Zu setzen; 2) Call Session_start (), um die Parameter wirksam zu machen; 3) Parameter dynamisch entsprechend den Anforderungen wie dem Benutzeranmeldestatus des Benutzers einstellen. 4) Achten Sie darauf, sichere und httponly -Flags festzulegen, um die Sicherheit zu verbessern.

Der Hauptzweck bei der Verwendung von Sitzungen in PHP besteht darin, den Status des Benutzers zwischen verschiedenen Seiten aufrechtzuerhalten. 1) Die Sitzung wird über die Funktion Session_start () gestartet, wodurch eine eindeutige Sitzungs -ID erstellt und im Benutzer Cookie gespeichert wird. 2) Sitzungsdaten werden auf dem Server gespeichert, sodass Daten zwischen verschiedenen Anforderungen wie Anmeldestatus und Einkaufswagen -Inhalten übergeben werden können.

Wie teile ich eine Sitzung zwischen Subdomains? Implementiert durch Einstellen von Sitzungs Cookies für gemeinsame Domainnamen. 1. Setzen Sie die Domäne des Sitzungs -Cookie auf .example.com auf der Serverseite. 2. Wählen Sie die entsprechende Sitzungsspeichermethode wie Speicher, Datenbank oder verteiltes Cache. 3. Übergeben Sie die Sitzungs -ID über Cookies, und der Server ruft und aktualisiert die Sitzungsdaten basierend auf der ID.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools