ядро 2.1, реагирует, ошибка соединения signalR - PullRequest
0 голосов
/ 01 ноября 2019

ChatScreen.js

import React, { Component } from 'react';
import { StyleSheet, View, Text, AsyncStorage, Platform, KeyboardAvoidingView, SafeAreaView } from 'react-native';
import { Header } from 'react-navigation-stack';
import { GiftedChat } from 'react-native-gifted-chat';
import Constants from 'expo-constants';
import moment from 'moment';
import * as signalR from '@aspnet/signalr';

export default class ChatScreen extends Component {

    constructor(props) {
        super(props);
        }

    state = {
        username: '',
        seq: '',
        messages: [{
            _id: 1,
            text: 'Hello developer',
            createdAt: moment.utc().format("YYYY/MM/DD HH:mm:ss").toString(),//new Date(),
            user: {
                _id: 2,
                name: 'React',
                avatar: '',
            },
        }],
        signalRConnection: null
    };


    static navigationOptions = ({ navigation }) => ({
        title: (navigation.state.params || {}).key || 'NULL!',
        headerForceInset: { vertical: 'never' }
    });


    _bootstrap = async () => {
        const username = await AsyncStorage.getItem('username');
        this.setState({ name: username });
    }

    componentDidMount = () => {
        console.log("componentDidMount");
        let connection = new signalR.HubConnectionBuilder()
            .withUrl("http://192.168.111.14:5000/api/chat", {
                skipNegotiation: true,
                transport: signalR.HttpTransportType.WebSockets
            })
            .configureLogging(signalR.LogLevel.Debug)
            .build();

        console.log('what is connection?')

        console.log(connection)


        connection
            .start()
            .then(() => console.log('Connection started'))
            .catch(err => console.log('Error while starting connection: ' + err));
    }

    onSend(message = []) {
        sendMessage = () => {
            this.state.hubConnection
                .invoke('sendToAll', this.state.nick, this.state.message)
                .catch(err => console.error(err));
        }
    }
    render() 
        const mainContent = (
            <GiftedChat
                messages={this.state.messages}
                onSend={(messages) => this.onSend(messages)}
                user={{ _id: 1 }}
            />
        );
        if (Platform.OS === 'android') {
            return (
                <KeyboardAvoidingView style={{ flex: 1 }} keyboardVerticalOffset={100} behavior="padding" enabled>
                    {mainContent}
                </KeyboardAvoidingView>
            );
        } else {
            return (<SafeAreaView style={{ flex: 1 }}>
                {mainContent}
            </SafeAreaView>)
        }
    }
}

const styles = StyleSheet.create({
    container: {
        flex: 1,
        justifyContent: 'center',
        alignItems: 'center'
    }
});

Startup.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using CoreServer.Repositories;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.IdentityModel.Tokens;
using Newtonsoft.Json.Serialization;

namespace CoreServer {
    public class Startup {
        public IConfiguration Configuration { get; }

        public Startup (IConfiguration configuration) {
            Configuration = configuration;
        }
        // This method gets called by the runtime. Use this method to add services to the container.
        // For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
        public void ConfigureServices (IServiceCollection services) {
            services.AddMvc ().SetCompatibilityVersion (CompatibilityVersion.Version_2_1);

            var key = Configuration.GetSection ("AppSettings").GetSection ("SecretKey").Value;
            var secretKey = new SymmetricSecurityKey (Encoding.UTF8.GetBytes (key));
            services.AddTransient<AuthRepo> ();
            services.AddTransient<TalkRepo> ();

            services.AddSingleton(Configuration);

            services.AddSignalR();
            services.AddCors (options => {
                options.AddPolicy ("EnableCORS", builder => {
                    builder.AllowAnyOrigin ()
                        .AllowAnyHeader ()
                        .AllowAnyMethod ()
                        .AllowCredentials ()
                        .Build ();
                });
            });

        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure (IApplicationBuilder app, IHostingEnvironment env) {
            if (env.IsDevelopment ()) {
                app.UseDeveloperExceptionPage ();
            } else {
                app.UseHsts ();
            }

            app.UseCors ("EnableCORS");

            // app.UseHttpsRedirection();
            //app.UseAuthentication ();
            app.UseMvc ();
            app.UseSignalR (builder => { builder.MapHub<ChartHub> ("/chat"); });

        }
    }
}

ChatController.cs

using System;
using System.Collections.Generic;
using System.IdentityModel.Tokens.Jwt;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using CoreServer.Repositories;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.SignalR;
using Microsoft.Extensions.Configuration;
using Microsoft.IdentityModel.Tokens;

namespace CoreServer.Controllers {
    [Route ("api/[controller]")]
    [ApiController]
    public class ChatController : ControllerBase {
        private IHubContext<ChartHub> _hub;

        public ChatController (IHubContext<ChartHub> hub) {
            _hub = hub;
        }

        public IActionResult Get () {
            var timerManager = new TimerManager (() => _hub.Clients.All.SendAsync ("transferchartdata", DataManager.GetData ()));

            return Ok (new { Message = "Request Completed" });
        }
    }
}

Когда я использую почтальон для подключения, он не имеетлюбая проблема.

Когда я использую реагирование с использованием signalR для подключения, он выдает нулевую ошибку, это то, что я получил на реагирующей консоли.

[2019-11-01T14:06:13.729Z] Debug: Starting HubConnection.
[2019-11-01T14:06:13.730Z] Debug: Starting connection with transfer format 'Text'.
Error while starting connection: null

[2019-11-01T14:06:15.743Z] Error: Failed to start the connection: null
- node_modules\react-native\Libraries\YellowBox\YellowBox.js:59:8 in error
- node_modules\expo\build\environment\muteWarnings.fx.js:27:24 in error
- ... 14 more stack frames from framework internals

=====================================================================================

вот что у меня на дотнет ядре

info: Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker[2]
      Executed action CoreServer.Controllers.ChatController.Get (CoreServer) in 268.1478ms
Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker:Information: Executed action CoreServer.Controllers.ChatController.Get (CoreServer) in 268.1478ms
info: Microsoft.AspNetCore.Hosting.Internal.WebHost[2]
      Request finished in 598.9061ms 200 application/json; charset=utf-8
Microsoft.AspNetCore.Hosting.Internal.WebHost:Information: Request finished in 598.9061ms 200 application/json; charset=utf-8

Может кто-нибудьпомогите мне в этом?

======================== Обновлено 11.01 2019

Это ошибкажурнал после обновления сервисов. AddSignalR (o => o.EnableDetailedErrors = true);

info: Microsoft.AspNetCore.Hosting.Internal.WebHost[1]
      Request starting HTTP/1.1 GET http://192.168.111.14:5000/api/chat  
Microsoft.AspNetCore.Hosting.Internal.WebHost:Information: Request starting HTTP/1.1 GET http://192.168.111.14:5000/api/chat  
info: Microsoft.AspNetCore.Cors.Infrastructure.CorsService[4]
      Policy execution successful.
Microsoft.AspNetCore.Cors.Infrastructure.CorsService:Information: Policy execution successful.
info: Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker[3]
      Route matched with {action = "Get", controller = "Chat"}. Executing controller action with signature Microsoft.AspNetCore.Mvc.IActionResult Get() on controller CoreServer.Controllers.ChatController (CoreServer).
Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker:Information: Route matched with {action = "Get", controller = "Chat"}. Executing controller action with signature Microsoft.AspNetCore.Mvc.IActionResult Get() on controller CoreServer.Controllers.ChatController (CoreServer).
info: Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker[1]

Это журнал ошибок экспо

06
HubConnection {
  "cachedPingMessage": "{\"type\":6}",
  "callbacks": Object {},
  "closedCallbacks": Array [],
  "connection": HttpConnection {
    "baseUrl": "http://192.168.111.14:5000/api/chat",
    "connectionStarted": false,
    "connectionState": "Disconnected",
    "features": Object {},
    "httpClient": DefaultHttpClient {
      "httpClient": XhrHttpClient {
        "logger": ConsoleLogger {
          "minimumLogLevel": 1,
          "outputConsole": Object {
            "assert": [Function assert],
            "debug": [Function __expoConsoleLog],
            "error": [Function error],
            "group": [Function group],
            "groupCollapsed": [Function groupCollapsed],
            "groupEnd": [Function groupEnd],
            "info": [Function __expoConsoleLog],
            "log": [Function __expoConsoleLog],
            "warn": [Function warn],
          },
        },
      },
    },
    "logger": ConsoleLogger {
      "minimumLogLevel": 1,
      "outputConsole": Object {
        "assert": [Function assert],
        "debug": [Function __expoConsoleLog],
        "error": [Function error],
        "group": [Function group],
        "groupCollapsed": [Function groupCollapsed],
        "groupEnd": [Function groupEnd],
        "info": [Function __expoConsoleLog],
        "log": [Function __expoConsoleLog],
        "warn": [Function warn],
      },
    },
    "onclose": [Function anonymous],
    "onreceive": [Function anonymous],
    "options": Object {
      "WebSocket": [Function WebSocket],
      "logMessageContent": false,
      "logger": ConsoleLogger {
        "minimumLogLevel": 1,
        "outputConsole": Object {
          "assert": [Function assert],
          "debug": [Function __expoConsoleLog],
          "error": [Function error],
          "group": [Function group],
          "groupCollapsed": [Function groupCollapsed],
          "groupEnd": [Function groupEnd],
          "info": [Function __expoConsoleLog],
          "log": [Function __expoConsoleLog],
          "warn": [Function warn],
        },
      },
      "skipNegotiation": true,
      "transport": 1,
    },
  },
  "connectionStarted": false,
  "connectionState": "Disconnected",
  "handshakeProtocol": HandshakeProtocol {},
  "invocationId": 0,
  "keepAliveIntervalInMilliseconds": 15000,
  "logger": ConsoleLogger {
    "minimumLogLevel": 1,
    "outputConsole": Object {
      "assert": [Function assert],
      "debug": [Function __expoConsoleLog],
      "error": [Function error],
      "group": [Function group],
      "groupCollapsed": [Function groupCollapsed],
      "groupEnd": [Function groupEnd],
      "info": [Function __expoConsoleLog],
      "log": [Function __expoConsoleLog],
      "warn": [Function warn],
    },
  },
  "methods": Object {},
  "protocol": JsonHubProtocol {
    "name": "json",
    "transferFormat": 1,
    "version": 1,
  },
  "receivedHandshakeResponse": false,
  "reconnectPolicy": undefined,
  "reconnectedCallbacks": Array [],
  "reconnectingCallbacks": Array [],
  "serverTimeoutInMilliseconds": 30000,
}
INFO
10:06
[2019-11-01T15:06:19.386Z] Debug: Starting HubConnection.
INFO
10:06
[2019-11-01T15:06:19.388Z] Debug: Starting connection with transfer format 'Text'.
INFO
10:06
[2019-11-01T15:06:19.515Z] Debug: HubConnection failed to start successfully because of error 'null'.
INFO
10:06
Error while starting connection: null
ERROR
10:06
[2019-11-01T15:06:19.495Z] Error: Failed to start the connection: null

Stack trace:
  node_modules\react-native\Libraries\YellowBox\YellowBox.js:59:8 in error
  node_modules\expo\build\environment\muteWarnings.fx.js:27:24 in error
  node_modules\@aspnet\signalr\dist\cjs\Utils.js:205:45 in log
  node_modules\@aspnet\signalr\dist\cjs\HttpConnection.js:306:40 in <unknown>
  node_modules\@aspnet\signalr\dist\cjs\HttpConnection.js:34:27 in step
  node_modules\@aspnet\signalr\dist\cjs\HttpConnection.js:7:65 in rejected
  node_modules\promise\setimmediate\core.js:37:14 in tryCallOne
  node_modules\promise\setimmediate\core.js:123:25 in <unknown>
  node_modules\react-native\Libraries\Core\Timers\JSTimers.js:152:14 in _callTimer
  node_modules\react-native\Libraries\Core\Timers\JSTimers.js:200:17 in _callImmediatesPass
  node_modules\react-native\Libraries\Core\Timers\JSTimers.js:473:30 in callImmediates
  node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:337:6 in __callImmediates
  node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:135:6 in <unknown>
  node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:314:10 in __guard
  node_modules\react-native\Libraries\BatchedBridge\MessageQueue.js:134:17 in flushedQueue

...