Sdílet prostřednictvím


Kurz: Vytvoření aplikace ASP.NET Core pomocí Reactu v sadě Visual Studio

V tomto článku se dozvíte, jak vytvořit projekt ASP.NET Core tak, aby fungoval jako back-end rozhraní API a projekt React, který bude fungovat jako uživatelské rozhraní.

Visual Studio v současné době obsahuje šablony jednostránkové aplikace (SPA) ASP.NET Core, které podporují Angular a React. Šablony poskytují integrovanou složku klientské aplikace v projektech ASP.NET Core, které obsahují základní soubory a složky každé architektury.

Metodu popsanou v tomto článku můžete použít k vytvoření ASP.NET základních jednostrákových aplikací, které:

  • Umístěte klientskou aplikaci do samostatného projektu mimo projekt ASP.NET Core.
  • Vytvoření klientského projektu na základě rozhraní příkazového řádku nainstalovaného na vašem počítači

Poznámka

Tento článek popisuje proces vytváření projektu pomocí aktualizované šablony v sadě Visual Studio 2022 verze 17.11, která používá rozhraní příkazového řádku Vite. Vite určuje verzi Reactu pomocí závislostí projektu, jako jsou ty nakonfigurované v package.json.

Požadavky

  • Visual Studio 2022 verze 17.11 nebo novější s nainstalovanou úlohou ASP.NET a vývojem webu. Přejděte na stránku ke stažení Visual Studio a nainstalujte si ji zdarma. Pokud potřebujete nainstalovat úlohu a sadu Visual Studio už máte, přejděte na Tools>Získat nástroje a funkce..., čímž se otevře instalační program sady Visual Studio. Zvolte ASP.NET a úlohy vývoje webu a pak zvolte Upravit.
  • npm (https://www.npmjs.com/), který je součástí Node.js

Vytvoření front-endové aplikace

  1. V okně Start vyberte Vytvořit nový projekt.

    Snímek obrazovky zobrazující vytvoření nového projektu

  2. Na panelu hledání v horní části vyhledejte React a pak vyberte React a ASP.NET Core. Tato šablona je javascriptová šablona.

    Snímek obrazovky znázorňující výběr šablony

  3. Pojmenujte projekt ReactWithASP a pak vyberte Další.

    V dialogovém okně Další informace se ujistěte, že je povolena možnost Konfigurovat pro HTTPS. Ve většině scénářů ponechte ostatní nastavení na výchozích hodnotách.

  4. Vyberte Vytvořit.

    Průzkumník řešení zobrazuje následující informace o projektu:

    snímek obrazovky s Průzkumníkem řešení

    V porovnání s samostatnou šablonou Reactse zobrazí některé nové a upravené soubory pro integraci s ASP.NET Core:

    • vite.config.js
    • App.js (změněno)
    • App.test.js (změněno)
  5. Na panelu nástrojů Ladění vyberte nainstalovaný prohlížeč, například Chrome nebo Microsoft Edge.

    Pokud požadovaný prohlížeč ještě není nainstalovaný, nejprve nainstalujte prohlížeč a vyberte ho.

Nastavení vlastností projektu

  1. V Průzkumníku řešení klikněte pravým tlačítkem na projekt ReactWithASP.Server a zvolte Vlastnosti.

    Snímek obrazovky zobrazující otevření vlastností projektu

  2. Na stránce Vlastnosti otevřete kartu Ladění a vyberte možnost Otevřít uživatelské rozhraní pro spuštění ladění. Zrušte zaškrtnutí možnosti Spustit prohlížeč pro profil https nebo profil pojmenovaný po projektu ASP.NET Core( pokud je k dispozici).

    Snímek obrazovky s uživatelským rozhraním spouštěcích profilů ladění

    Tato hodnota brání otevření webové stránky se zdrojovými daty o počasí.

    Poznámka

    V sadě Visual Studio ukládá launch.json nastavení spuštění spojené s tlačítkem Start na panelu nástrojů Ladění. V současné době musí být launch.json umístěna ve složce .vscode.

  3. Pravým tlačítkem myši klikněte na řešení v Průzkumníku řešení a vyberte Vlastnosti. Ověřte, že nastavení spouštěcího projektu je nastaveno na více projektůa že akce pro oba projekty jsou nastaveny na Spustit.

Spuštění projektu

Stisknutím klávesy F5 nebo výběrem tlačítka Start v horní části okna spusťte aplikaci. Zobrazí se dva příkazové řádky:

  • Spuštěný projekt rozhraní API ASP.NET Core

  • Rozhraní příkazového řádku Vite zobrazující zprávu, jako je například VITE v4.4.9 ready in 780 ms

    Poznámka

    Zkontrolujte výstup konzoly pro zprávy. Například se může zobrazit zpráva o tom, že je potřeba aktualizovat Node.js.

Zobrazí se aplikace React a naplní se přes rozhraní API (port localhost se může lišit od snímku obrazovky).

Snímek obrazovky s aplikací pro předpověď počasí

Pokud aplikaci nevidíte, přečtěte si řešení potíží.

Publikování projektu

  1. V Průzkumníku řešení klikněte pravým tlačítkem na projekt ReactWithASP.Server a vyberte Přidat>referenci projektu.

    Ujistěte se, že je vybrán projekt reactwithasp.client.

  2. Zvolte OK.

  3. Znovu klikněte pravým tlačítkem na projekt ASP.NET Core a vyberte Upravit soubor projektu.

    Tím se otevře soubor .csproj projektu.

  4. V souboru .csproj se ujistěte, že odkaz na projekt obsahuje prvek <ReferenceOutputAssembly> s hodnotou nastavenou na false.

    Tento odkaz by měl vypadat takto.

     <ProjectReference Include="..\reactwithasp.client\reactwithasp.client.esproj">
       <ReferenceOutputAssembly>false</ReferenceOutputAssembly>
     </ProjectReference>
    
  5. Klikněte pravým tlačítkem na projekt ASP.NET Core a zvolte Znovu načíst projekt, pokud je tato možnost dostupná.

  6. V Program.csse ujistěte, že je k dispozici následující kód.

    app.UseDefaultFiles();
    app.UseStaticFiles();
    
    // Configure the HTTP request pipeline.
    if (app.Environment.IsDevelopment())
    {
       app.UseSwagger();
       app.UseSwaggerUI();
    }
    
  7. Pokud chcete publikovat, klikněte pravým tlačítkem na projekt ASP.NET Core, zvolte Publikovata vyberte možnosti, které odpovídají požadovanému scénáři publikování, jako je Azure, publikování do složky atd.

    Proces publikování trvá déle, než to dělá jenom u projektu ASP.NET Core, protože při publikování se vyvolá příkaz npm run build. BuildCommand se ve výchozím nastavení spouští npm run build.

    Pokud publikujete do složky, přečtěte si ASP.NET Core adresářová struktura pro více informací o souborech přidaných do složky pro publikování .

Řešení problémů

Chyba proxy serveru

Může se zobrazit následující chyba:

[HPM] Error occurred while trying to proxy request /weatherforecast from localhost:4200 to https://localhost:7183 (ECONNREFUSED) (https://nodejs.org/api/errors.html#errors_common_system_errors)

Pokud se zobrazí tento problém, pravděpodobně front-end začal před back-endem.

  • Jakmile se zobrazí příkazový řádek back-endu spuštěný, stačí aktualizovat aplikaci React v prohlížeči.
  • Ověřte také, že je back-end nakonfigurovaný tak, aby se spustil před front-endem. Chcete-li to ověřit, vyberte řešení v Průzkumníku řešení a zvolte Vlastnosti z nabídky Projekt. Dále vyberte Konfigurovat projekty po spuštění a ujistěte se, že backendový ASP.NET Core projekt je na seznamu jako první. Pokud to není první, vyberte projekt a pomocí tlačítka Šipka nahoru ho nastavte jako první projekt v seznamu spuštění.

Ověření portů

Pokud se data o počasí nenačítají správně, možná budete muset ověřit, jestli jsou porty správné.

  1. Ujistěte se, že se čísla portů shodují. Přejděte do souboru launchSettings.json v projektu ASP.NET Core ReactWithASP.Server (ve složce Vlastnosti). Získejte číslo portu z vlastnosti applicationUrl.

    Pokud existuje více applicationUrl vlastností, vyhledejte jednu z nich pomocí koncového bodu https. Vypadá podobně jako https://localhost:7183.

  2. Otevřete soubor vite.config.js projektu React. Aktualizujte vlastnost target tak, aby odpovídala vlastnosti applicationUrl v launchSettings.json. Aktualizovaná hodnota vypadá nějak takto:

    target: 'https://localhost:7183/',
    

Chyba ochrany osobních údajů

Může se zobrazit následující chyba certifikátu:

Your connection isn't private

Zkuste odstranit certifikáty React z %appdata%\local\asp.net\https nebo %appdata%\roaming\asp.net\httpsa pak to zkuste znovu.

Docker

Pokud vytvoříte projekt s podporou Dockeru povolenou, proveďte následující kroky:

  1. Po načtení aplikace získejte port HTTPS Dockeru pomocí okna Containers ve Visual Studiu. Zkontrolujte kartu prostředí prostředí nebo porty.

    Snímek obrazovky zobrazující porty kontejneru Dockeru

  2. Otevřete soubor vite.config.js projektu React. Aktualizujte proměnnou target tak, aby odpovídala portu HTTPS v okně Kontejnery. Například v následujícím kódu:

    const target = env.ASPNETCORE_HTTPS_PORT ? `https://localhost:${env.ASPNETCORE_HTTPS_PORT}` :
       env.ASPNETCORE_URLS ? env.ASPNETCORE_URLS.split(';')[0] : 'https://localhost:7143';
    

    změňte https://localhost:7143 na odpovídající port HTTPS (v tomto příkladu https://localhost:44307).

  3. Restartujte aplikaci.

Další kroky

Další informace o aplikacích SPA v ASP.NET Core najdete v části React v části Vývoj jednostránkové aplikace. Propojený článek poskytuje další kontext pro soubory projektu, jako je aspnetcore-https.js, i když podrobnosti implementace se liší na základě rozdílů šablony. Například místo složky ClientApp jsou soubory React obsažené v samostatném projektu.

Informace o nástroji MSBuild specifické pro klientský projekt naleznete v části vlastnosti MSBuild pro JSPS.