アーラン接続php-fpm
erlang が php-fpm に接続する例をインターネットで見ましたので、それに従い、デバッグされたコードを以下に投稿しました
元のコードの 2 つのバグを修正しました:
1 パラメーターが 128 文字を超えているエラー
2 php が 1024 バイトを超えるとエラーが発生します
ファイル名 fastcgi.erl
<p class="sycode"> - module(fastcgi). - compile(export_all).do_request(Argv) -> Env = [ { " SCRIPT_FILENAME " , " E:/phpGame/game/gateway.php " }, { " websocket " ,Argv} ], io:format( " Argv msg: ~ts~n " , [Argv]), {ok, Socket} = gen_tcp:connect( " 127.0.0.1 " , 9000 ,[binary, {packet, 0}, {active,true}], 10000 ), fcgi_send_record(Socket, 1 , 1 , << 1 : 16 ,0: 8 ,0: 40 >> ), fcgi_send_record(Socket, 4 , 1 , Env), fcgi_send_record(Socket, 4 , 1 , []), Bin = phpRespone(Socket,[]), gen_tcp:close(Socket), %% 原报文 << Version: 8 , Type: 8 , RequestId: 16 , ContentLength: 16 ,PaddingLength: 8 , Reserved: 8 ,Str / binary >> = Bin, << _: 32 ,ContentLength: 16 ,_: 16 ,Str / binary >> = Bin, %% 计算输出内容长度 Dlen = ContentLength - 52 , %% 获取内容 << _H: 52 / binary,Data:Dlen / binary,_Other / binary >> = Str, io:fwrite( " rs:~p~n " ,[Data]), {ok,Data}.recv_msg(Sock) -> receive {tcp, Sock, Bin} -> io:format( " Bin msg: ~p~n " , [Bin]), %% 原报文 << Version: 8 , Type: 8 , RequestId: 16 , ContentLength: 16 ,PaddingLength: 8 , Reserved: 8 ,Str / binary >> = Bin, << _: 32 ,ContentLength: 16 ,_: 16 ,Str / binary >> = Bin, %% 计算输出内容长度 Dlen = ContentLength - 52 , %% 获取内容 << _H: 52 / binary,Data:Dlen / binary,_Other / binary >> = Str, io:fwrite( " rs:~p~n " ,[Data]), {ok,Data}; {tcp_closed,Sock} -> io:format( " socket close: ~p~n " , [Sock]); _Other -> io:format( " Other msg: ~p~n " , [_Other]), recv_msg(Sock) after 3000 -> io:format( " Time out.~n " ) end. phpRespone(Sock,SoFar) -> receive {tcp, Sock, Bin} -> phpRespone(Sock,[Bin | SoFar]); {tcp_closed,Sock} -> list_to_binary(lists:reverse(SoFar)); _Other -> io:format( " Other msg: ~p~n " , [_Other]), phpRespone(Sock,SoFar) after 3000 -> io:format( " Time out.~n " ) end. %% 发送选项 fcgi_send_record(Socket, Type, RequestId, NameValueList) -> EncodedRecord = fcgi_encode_record(Type, RequestId,NameValueList), gen_tcp:send(Socket, EncodedRecord). %% 组包 fcgi_encode_record(Type, RequestId, NameValueList) when is_list(NameValueList) -> fcgi_encode_record(Type, RequestId,fcgi_encode_name_value_list(NameValueList)); %% 判断ContentData是否满8字节,否则填充 fcgi_encode_record(Type, RequestId, ContentData) when is_binary(ContentData) -> ContentLength = size(ContentData), PaddingLength = if ContentLength rem 8 == 0 -> 0; true -> 8 - (ContentLength rem 8 ) end, %% 填充数据,每8字节组包 不足用0填充 PaddingData = << 0:(PaddingLength * 8 ) >> , Version = 1 , Reserved = 0, << Version: 8 , Type: 8 , RequestId: 16 , ContentLength: 16 , PaddingLength: 8 , Reserved: 8 , ContentData / binary, PaddingData / binary >> . %% 将环境变量组成binary fcgi_encode_name_value_list(_NameValueList = []) -> << >> ; fcgi_encode_name_value_list(_NameValueList = [{Name, Value} | Tail]) -> << (fcgi_encode_name_value(Name,Value)) / binary,(fcgi_encode_name_value_list(Tail)) / binary >> . fcgi_encode_name_value(Name, _Value = undefined) -> fcgi_encode_name_value(Name, "" ); fcgi_encode_name_value(Name, Value) when is_list(Name) and is_list(Value) -> NameSize = length(Name), NameSizeData = << NameSize: 8 >> , ValueSize = length(Value), if ValueSize < 128 -> ValueSizeData = << ValueSize: 8 >> ; ValueSize > 127 -> ValueSizeData = << (ValueSize bor 16 # 80000000):32>> end, << NameSizeData / binary,ValueSizeData / binary,(list_to_binary(Name)) / binary,(list_to_binary(Value)) / binary >> . </p>
Windows で php cgi を起動するには、次のように実行できます
php-cgi.exe -b 127.0.0.1: 9000
erlang シェルで呼び出します:
2> c(fastcgi).
{ok,fastcgi}
3> fastcgi:do_request("{'uid':1}").
文章は良くありません、皆さんお願いしますたくさん

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。
