即使我的网站是在 SSL 下提供服务,我是否可以强制我的 Web 套接字不使用 SSL?

我有一个 JavaScript 客户端。


我有一个网络套接字,它正在尝试与我的服务器通信。


我的网络应用程序在 https 下运行,我使用 Open SSL 来获取我的证书。


在我的 C# 中,我使用 Socket 对象来接收客户端请求。


我的客户端可以连接,但当我尝试读取/解析标头时,它已加密。(我不知道如何解密)。


如果我的网络套接字不使用 SSL,问题就会消失。但是,即使我将客户端中的 uri 设置为:


var url = "ws://192.168.0.9:8090/Relayer";

改为:


var url = "wss://192.168.0.9:8090/Relayer";

这是我的服务器代码:


//server starting to listen


serverSocket = new Socket( AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.IP );

serverSocket.Bind( new IPEndPoint( IPAddress.Any, 8090 ) );

serverSocket.Listen( 128 );

serverSocket.BeginAccept( null, 0, OnAccept, null );



//server responding to Client Request:


private static Socket serverSocket;


private static void OnAccept(IAsyncResult result)

{

    byte[] buffer = new byte[1024];


    try

    {

        Socket client = null;

        string headerResponse = "";

        if (serverSocket != null && serverSocket.IsBound)

        {

            client = serverSocket.EndAccept(result);

            var i = client.Receive(buffer);




            //my many attempts to read the data....       


            string unicode = (Encoding.UTF8.GetString(buffer)).Substring(0, i);

            string str = Uri.UnescapeDataString(unicode);

            var outputs = System.Net.WebUtility.HtmlDecode(unicode);

        }

        if (client != null)

        {

            /* Handshaking and managing ClientSocket */

        }

    }

    catch (SocketException ex)

    {

        Logger.LogVerbose(LoggerNames.Error, ex.ToString());

    }

    finally

    {

        if (serverSocket != null && serverSocket.IsBound)

        {

            serverSocket.BeginAccept(null, 0, OnAccept, null);

        }

    }

}

那么,我可以强制我的 Web 套接字不使用 SSL 吗?


谢谢


好吧,阅读完内容后,我明白混合 http 和 https、ws 和 wss 不是一个好主意。


任何使用 SSL/wss 使其工作的想法都会很好:)


幕布斯6054654
浏览 79回答 1
1回答

烙印99

即使我的网站是在 SSL 下提供服务,我是否可以强制我的 Web 套接字不使用 SSL?如果您的 JavaScrip 客户端遵循安全约定,那么答案是否定的。答案也是“不应该”。造成这种情况的原因有很多,但以下原因就足够了:当用户观察到该网站已加密时,他们会认为他们共享的任何私人信息都不会被第三方看到。这是加密所做出的承诺的一部分。然而,如果在声明站点已加密后允许明文(未加密)通信,则可能会打破这一承诺。这就是为什么安全客户端不允许在安全网站内进行非加密通信(即 WebSockets、XHR 等)。我的客户端可以连接,但当我尝试读取/解析标头时,它已加密。(我不知道如何解密)。加密的数据应通过 SSL 层才能解密。通常,许多语言都会提供“SSL 套接字”抽象,其行为类似于套接字,但会自动加密/解密数据。
打开App,查看更多内容
随时随地看视频慕课网APP