从PHP Ratchet WebSocket服务器获取客户端Cookie

时间:2017-10-09 10:23:11

标签: php cookies websocket ratchet

我有一个PHP Ratchet WebSocket服务器,在我的网站上运行自定义聊天室。

我想在连接到服务器时获取用户的cookie,以便我可以获取会话数据并在他们登录/具有特定权限等时执行特殊操作。

在其他帖子中(包括StackOverflow和其他帖子),据说要获取会话数据,您必须获取客户端的cookie,这些cookie在其请求中提供给Web服务器。以下代码行是为了这样做:

$conn->WebSocket->request->getCookies()

$connConnectionInterface

我的问题是,在运行时,这只会返回一个空数组,即使DevTools会显示确实存在cookie。

为什么这不会返回值?

1 个答案:

答案 0 :(得分:1)

以防您仍在寻找解决方案:

1.如果您的cookie仅对特定域/子域有效 - 您应该通过同一地址与WebSocket服务器建立连接。 例如,仅对admin.example.com有效的cookie不会发送到根域(example.com)上的WebSocket服务器。

2.如果您的cookie仅对安全连接有效(https://),您的WebSocket服务器也应该通过安全连接(wss://),使用最新的Ratchet版本很容易实现

package com.example.name.app;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

    Button button = (Button) findViewById(R.id.button);
    WebView browser = (WebView) findViewById(R.id.webView);
    String url = "http://www.google.com";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                browser.setWebViewClient(new WebViewClient());
                browser.getSettings().setLoadsImagesAutomatically(true);
                browser.getSettings().setJavaScriptEnabled(true);
                browser.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
                browser.loadUrl(url);
            }
        });
    }
}

3.使用Ratchet 0.4.x,不再有cookie解析器。 您只能将其作为原始字符串获取,然后自行解析。

获取&使用Ratchet 0.4.x解析cookie:

$webSock = new React\Socket\Server('0.0.0.0:8443', $loop);
$webSock = new React\Socket\SecureServer($webSock, $loop, [
    'local_cert'        => 'path_to_server_cert',
    'local_pk'          => 'path_to_private_key',
    //'allow_self_signed' => TRUE,
    'verify_peer' => FALSE
]);