SignalR - 仅适用于localhost

时间:2014-09-04 19:49:56

标签: c# javascript signalr

所以,我有一个SignalR自托管控制台应用程序和一个在WAMP上运行的网站。当我使用localhost作为域名时,一切正常。显然这只适用于本地。

我希望它也适用于其他计算机。所以我试图将localhost更改为我的本地IP,无论是在c#console应用程序中,还是在网站上。当我有本地IP时,控制台应用程序崩溃,错误:

  

未处理的类型异常   mscorlib.dll中发生'System.Reflection.TargetInvocationException'

我还尝试在控制台应用程序中使用*而不是localhost。像这样:

string url = "http://*:8080/servers/2/";

同样如此,它崩溃了。我做错了什么?

控制台应用程序代码:

namespace SignalRSelfHost
{        
    class Program
    {    
        public static IPAddress ipAd { get; set; }
        public static TcpListener myList { get; set; }
        static void Main(string[] args)
        {    
            // This will *ONLY* bind to localhost, if you want to bind to all addresses
            // use http://*:8080 to bind to all addresses. 
            // See http://msdn.microsoft.com/en-us/library/system.net.httplistener.aspx 
            // for more information.

            string url = "http://localhost:8080/servers/2/";
            using (WebApp.Start(url))
            {
                Console.WriteLine("Server running on {0}", url);
                Console.ReadLine();
            }                
        }            
    }
    class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            app.Map("/signalr", map =>
            {
                // Setup the CORS middleware to run before SignalR.
                // By default this will allow all origins. You can 
                // configure the set of origins and/or http verbs by
                // providing a cors options with a different policy.
                map.UseCors(CorsOptions.AllowAll);
                var hubConfiguration = new HubConfiguration
                {
                    // You can enable JSONP by uncommenting line below.
                    // JSONP requests are insecure but some older browsers (and some
                    // versions of IE) require JSONP to work cross domain
                    // EnableJSONP = true

                };
                // Run the SignalR pipeline. We're not using MapSignalR
                // since this branch already runs under the "/signalr"
                // path.
                map.RunSignalR(hubConfiguration);
            });
        }
    }
    public class MyHub : Hub
    {
        public void Send(string message)
        {
            Clients.All.addMessage(message);

        }
    }
}

我的网站代码:

<input type="text" id="message" />
        <input type="button" id="sendmessage" value="Send" />
        <input type="hidden" id="displayname" />
    <ul id="discussion"></ul>

<!--Script references. -->
    <!--Reference the jQuery library. -->
    <script src="/assets/js/jquery-1.6.4.min.js"></script>
    <!--Reference the SignalR library. -->
    <script src="/assets/js/jquery.signalR-2.0.3.min.js"></script>
    <!--Reference the autogenerated SignalR hub script. -->
    <script src="http://localhost:8080/servers/<?php echo $server->row()->id; ?>/signalr/hubs"></script>
    <!--Add script to update the page and send messages.-->
    <script type="text/javascript">
        $(function () {
            var url = "http://localhost:8080/servers/<?php echo $server->row()->id; ?>/signalr";
            //Set the hubs URL for the connection
            $.connection.hub.url = url;

            // Declare a proxy to reference the hub.
            var chat = $.connection.myHub;

            // Create a function that the hub can call to broadcast messages.
            chat.client.addMessage = function (message) {
                // Html encode display name and message.
                var encodedMsg = $('<div />').text(message).html();
                // Add the message to the page.
                $('#discussion').append('<li>' + encodedMsg + '</li>');
            };
            // Get the user name and store it to prepend to messages.
            //$('#displayname').val(prompt('Enter your name:', ''));
            // Set initial focus to message input box.
            //$('#message').focus();
            // Start the connection.
            $.connection.hub.start().done(function () {
                $('#sendmessage').click(function () {
                    // Call the Send method on the hub.
                    chat.server.send($('#message').val());
                    // Clear text box and reset focus for next comment.
                    $('#message').val('').focus();
                });
            });
        });
    </script>

1 个答案:

答案 0 :(得分:10)

以管理员身份运行程序解决了这个问题。