Notitie
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen u aan te melden of de directory te wijzigen.
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen de mappen te wijzigen.
Van toepassing op:Azure SQL Database
In deze quickstart wordt beschreven hoe u een toepassing verbindt met een database in Azure SQL Database en query's uitvoert met behulp van .NET en Entity Framework Core. Deze quickstart volgt de aanbevolen benadering zonder wachtwoord om verbinding te maken met de database. Meer informatie over verbindingen zonder wachtwoord vindt u op de hub zonder wachtwoord.
Vereiste voorwaarden
- Een Azure-abonnement.
- Een SQL-database die is geconfigureerd voor verificatie met Microsoft Entra ID (voorheen Azure Active Directory). U kunt er een maken met behulp van de quickstart: Een individuele database maken - Azure SQL Database.
- .NET 9.0 of hoger.
- Visual Studio of hoger met de workload ASP.NET en webontwikkeling .
- De nieuwste versie van de Azure CLI.
- De nieuwste versie van de Entity Framework Core-hulpprogramma's:
- Visual Studio-gebruikers moeten de Package Manager Console-hulpprogramma's voor Entity Framework Core installeren.
- .NET CLI-gebruikers moeten de .NET CLI-hulpprogramma's voor Entity Framework Core installeren.
De databaseserver configureren
Voor beveiligde, wachtwoordloze verbindingen met Azure SQL Database zijn bepaalde databaseconfiguraties vereist. Controleer de volgende instellingen op uw logische server in Azure om verbinding te maken met Azure SQL Database in zowel lokale als gehoste omgevingen:
Voor lokale ontwikkelingsverbindingen moet u ervoor zorgen dat uw logische server zo is geconfigureerd dat het IP-adres van uw lokale computer en andere Azure-services verbinding kunnen maken:
Navigeer naar de pagina Netwerken van uw server.
Schakel het keuzerondje Geselecteerde netwerken in om extra configuratieopties weer te geven.
Selecteer Voeg uw IPv4-clientadres (xx.xx.xx.xx) toe om een firewallregel toe te voegen waarmee verbindingen vanaf het IPv4-adres van uw lokale computer worden ingeschakeld. U kunt ook + Een firewallregel toevoegen selecteren om een specifiek IP-adres van uw keuze in te voeren.
Zorg ervoor dat het selectievakje Azure-services en -resources toegang geven tot deze server is ingeschakeld.
Waarschuwing
Het inschakelen van de Toestaan dat Azure-services en -resources toegang krijgen tot deze server instelling is geen aanbevolen beveiligingspraktijk voor productiescenario's. Echte toepassingen moeten veiligere benaderingen implementeren, zoals sterkere firewallbeperkingen of configuraties van virtuele netwerken.
Meer informatie over databasebeveiligingsconfiguraties vindt u in de volgende bronnen:
Op de server moet ook Microsoft Entra-verificatie zijn ingeschakeld en moet een Microsoft Entra-beheerdersaccount zijn toegewezen. Voor lokale ontwikkelingsverbindingen moet het Microsoft Entra-beheerdersaccount een account zijn waarmee u zich ook lokaal kunt aanmelden bij Visual Studio of de Azure CLI. U kunt controleren of Microsoft Entra-verificatie is ingeschakeld op de Microsoft Entra ID pagina van uw logische server.
Als u een persoonlijk Azure-account gebruikt, moet u ervoor zorgen dat u Microsoft Entra hebt ingesteld en geconfigureerd voor Azure SQL Database om uw account toe te wijzen als serverbeheerder. Als u een bedrijfsaccount gebruikt, wordt de Microsoft Entra-id waarschijnlijk al voor u geconfigureerd.
Het project maken
Met de stappen in deze sectie maakt u een .NET Minimal Web API met behulp van de .NET CLI of Visual Studio 2022.
Navigeer in de menubalk van Visual Studio naar Bestand>nieuw>project...
Voer in het dialoogvenster ASP.NET in het zoekvak van de projectsjabloon in en selecteer het ASP.NET Core Web API-resultaat. Kies Volgende onder aan het dialoogvenster.
Voer DotNetSQL in voor de projectnaam. Laat de standaardwaarden voor de rest van de velden staan en selecteer Volgende.
Voor framework selecteert u .NET 9.0 en schakelt u Controllers gebruiken uit. In deze quickstart wordt een minimale API-sjabloon gebruikt om het maken en configureren van eindpunten te stroomlijnen.
Kies Maken. Het nieuwe project wordt geopend in de Visual Studio-omgeving.
Entity Framework Core toevoegen aan het project
Als u verbinding wilt maken met Azure SQL Database met behulp van .NET en Entity Framework Core, moet u drie NuGet-pakketten toevoegen aan uw project met behulp van een van de volgende methoden:
Klik in het venster Solution Explorer met de rechtermuisknop op het knooppunt Afhankelijkheden van het project en selecteer NuGet-pakketten beheren.
Zoek in het resulterende venster naar EntityFrameworkCore. Zoek en installeer de volgende pakketten:
-
Microsoft.EntityFrameworkCore: Biedt essentiële Entity Framework Core-functionaliteit -
Microsoft.EntityFrameworkCore.SqlServer: Biedt extra onderdelen om verbinding te maken met de logische server -
Microsoft.EntityFrameworkCore.Design: biedt ondersteuning voor het uitvoeren van Entity Framework-migraties -
Microsoft.EntityFrameworkCore.Tools: biedt ondersteuning voor Visual Studio Package Manager Console-hulpprogramma's (alleen PowerShell) -
Swashbuckle.AspNetCore: Optioneel - biedt ondersteuning voor SwaggerUI-interactie met de app-eindpunten
De code toevoegen om verbinding te maken met Azure SQL Database
De Entity Framework Core-bibliotheken zijn afhankelijk van de en Azure.Identity bibliotheken voor het Microsoft.Data.SqlClient implementeren van verbindingen zonder wachtwoord met Azure SQL Database. De Azure.Identity bibliotheek biedt een klasse met de naam DefaultAzureCredential die verificatie zonder wachtwoord naar Azure afhandelt.
DefaultAzureCredential ondersteunt meerdere verificatiemethoden en bepaalt welke u tijdens runtime moet gebruiken. Met deze aanpak kan uw app verschillende verificatiemethoden gebruiken in verschillende omgevingen (lokaal versus productie) zonder omgevingsspecifieke code te implementeren. In het overzicht van de Azure Identity-bibliotheek worden de volgorde en locaties uitgelegd waarin DefaultAzureCredential wordt gezocht naar referenties.
Voer de volgende stappen uit om verbinding te maken met Azure SQL Database met behulp van Entity Framework Core en de onderliggende DefaultAzureCredential klasse:
Voeg een
ConnectionStringssectie toe aan hetappsettings.Development.jsonbestand, zodat deze overeenkomt met de volgende code. Vervang<server>.database.windows.netdoor de naam van de databaseserver zonder wachtwoord waarmee u verbinding wilt maken en<database>door de naam van de database.{ "Logging": { "LogLevel": { "Default": "Information", "Microsoft.AspNetCore": "Warning" } }, "ConnectionStrings": { "AZURE_SQL_CONNECTIONSTRING": "Data Source=<server>.database.windows.net;Initial Catalog=<database>;Authentication=Active Directory Default;Encrypt=True;" } }Opmerking
Vergeet niet om de
<your database-server-name>tijdelijke<your-database-name>aanduidingen in de databaseverbindingsreeks bij te werken. Verbindingsreeksen zonder wachtwoord kunnen veilig worden doorgevoerd in broncodebeheer, omdat ze geen geheimen bevatten, zoals gebruikersnamen, wachtwoorden of toegangssleutels.De verbindingsreeks zonder wachtwoord bevat een configuratiewaarde van
Authentication=Active Directory Default, waarmee Entity Framework Core verbinding kan makenDefaultAzureCredentialmet Azure-services. Wanneer de app lokaal wordt uitgevoerd, wordt deze geverifieerd met de gebruiker waarmee u bent aangemeld bij Visual Studio. Zodra de app in Azure wordt geïmplementeerd, detecteert en past dezelfde code de beheerde identiteit toe die is gekoppeld aan de gehoste app, die u later configureert.Vervang de inhoud van het bestand
Program.csdoor de volgende code:using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; var builder = WebApplication.CreateBuilder(); builder.Services.AddOpenApi(); var connection = String.Empty; if (builder.Environment.IsDevelopment()) { builder.Configuration.AddEnvironmentVariables().AddJsonFile("appsettings.Development.json"); connection = builder.Configuration.GetConnectionString("AZURE_SQL_CONNECTIONSTRING"); } else { connection = Environment.GetEnvironmentVariable("AZURE_SQL_CONNECTIONSTRING"); } builder.Services.AddDbContext<PersonDbContext>(options => options.UseSqlServer(connection)); var app = builder.Build(); if (app.Environment.IsDevelopment()) { app.MapOpenApi(); app.UseSwaggerUI(options => { options.SwaggerEndpoint("/openapi/v1.json", "v1"); }); } app.MapGet("/", () => "Hello world!"); app.MapGet("/Person", (PersonDbContext context) => { return context.Person.ToList(); }); app.MapPost("/Person", (Person person, PersonDbContext context) => { context.Add(person); context.SaveChanges(); }); app.Run(); public class Person { public int Id { get; set; } public string FirstName { get; set; } public string LastName { get; set; } } public class PersonDbContext : DbContext { public PersonDbContext(DbContextOptions<PersonDbContext> options) : base(options) { } public DbSet<Person> Person { get; set; } }De voorgaande code verwerkt de volgende stappen:
- Haalt de verbindingsreeks voor de database zonder wachtwoord op uit het
appsettings.Development.jsonbestand voor lokale ontwikkeling of uit de omgevingsvariabelen voor gehoste productiescenario's. - Registreert de Entity Framework Core-klasse
DbContextmet de .NET-afhankelijkheidsinjectiecontainer. Meer informatie vindtDbContextu in de aan de slag-documentatie voor Entity Framework Core. - Configureert .NET 9.0 OpenAPI-ondersteuning met SwaggerUI om een gebruikersinterface te bieden die u kunt gebruiken om te communiceren met de app-eindpunten en -database.
- Voegt eindpunten toe om entiteiten in de database op te halen en toe te voegen.
- Definieert een
Personklasse die één record in dePersonsdatabasetabel vertegenwoordigt en dePersonDbContextklasse die is geregistreerd bij de .NET-afhankelijkheidsinjectiecontainer.
- Haalt de verbindingsreeks voor de database zonder wachtwoord op uit het
De migraties uitvoeren om de database te maken
Als u het databaseschema wilt bijwerken zodat het overeenkomt met uw gegevensmodel met behulp van Entity Framework Core, moet u een migratie gebruiken. Migraties kunnen een databaseschema maken en incrementeel bijwerken om dit gesynchroniseerd te houden met het gegevensmodel van uw toepassing. Meer informatie over dit patroon vindt u in het overzicht van migraties.
Open een terminalvenster naar de hoofdmap van uw project.
Voer de volgende opdracht uit om een initiële migratie te genereren waarmee de database kan worden gemaakt:
Add-Migration InitialCreate
Er moet een
Migrationsmap worden weergegeven in de projectmap, samen met een bestandInitialCreatemet unieke nummers dat vooraf is gegaan. Voer de migratie uit om de database te maken met behulp van de volgende opdracht en de Entity Framework Core-hulpprogramma's maken het databaseschema in Azure dat is gedefinieerd door dePersonDbContextklasse.Update-Database
De app lokaal testen
De app is gereed om lokaal te worden getest. Zorg ervoor dat u bent aangemeld bij Visual Studio of de Azure CLI met hetzelfde account dat u hebt ingesteld als de beheerder voor uw database.
Druk boven aan Visual Studio op de knop Uitvoeren om het API-project te starten.
Vouw op de pagina Swagger UI de POST-methode uit en selecteer Probeer het.
Wijzig de voorbeeld-JSON om waarden op te nemen voor de voornaam en familienaam. Selecteer uitvoeren om een nieuwe record toe te voegen aan de database. De API retourneert een geslaagd antwoord.
Vouw de
GETmethode uit op de pagina Swagger UI en selecteer Uitproberen. Selecteer uitvoeren en de persoon die u zojuist hebt gemaakt, wordt geretourneerd.
Implementeren in Azure App Service
De app is klaar om te worden geïmplementeerd in Azure. Visual Studio kan een Azure App Service maken en uw toepassing in één werkstroom implementeren.
Zorg ervoor dat de app is gestopt en bouwt.
Klik in het Venster Solution Explorer van Visual Studio met de rechtermuisknop op het projectknooppunt op het hoogste niveau en selecteer Publiceren.
Selecteer In het publicatiedialoogvenster Azure als het implementatiedoel en selecteer vervolgens Volgende.
Voor het specifieke doel selecteert u Azure App Service (Windows) en selecteert u vervolgens Volgende.
Selecteer het groene + pictogram om een nieuwe App Service te maken waarop u wilt implementeren en voer de volgende waarden in:
- naam: laat de standaardwaarde staan.
- abonnementsnaam: selecteer het abonnement waarnaar u wilt implementeren.
- Resourcegroep: Selecteer Nieuw en maak een nieuwe resourcegroep met de naam msdocs-dotnet-sql.
- Hostingabonnement: Selecteer Nieuw om het dialoogvenster hostingabonnement te openen. Laat de standaardwaarden staan en selecteer OK.
- Selecteer Maken om het oorspronkelijke dialoogvenster te sluiten. Visual Studio maakt de App Service-resource in Azure.
Zodra de resource is gemaakt, moet u in de lijst met app-services selecteren en vervolgens Volgende selecteren.
Schakel in de STAP API Management het selectievakje Deze stap overslaan onderaan in en selecteer Voltooien.
Selecteer Publiceren in de rechterbovenhoek van het overzicht van het publicatieprofiel om de app in Azure te implementeren.
Wanneer de implementatie is voltooid, start Visual Studio de browser om de gehoste app weer te geven. U ziet het Hello world bericht van het standaardeindpunt. Op dit moment werken de database-eindpunten echter niet correct in Azure. U moet nog steeds de beveiligde verbinding tussen de App Service en de SQL-database configureren om uw gegevens op te halen.
De App Service verbinden met Azure SQL Database
De volgende stappen zijn vereist om het App Service-exemplaar te verbinden met Azure SQL Database:
- Maak een beheerde identiteit voor de App Service. De
Microsoft.Data.SqlClientbibliotheek die in uw app is opgenomen, detecteert automatisch de beheerde identiteit, net zoals uw lokale Visual Studio-gebruiker. - Maak een SQL-databasegebruiker en koppel deze aan de door App Service beheerde identiteit.
- Wijs SQL-rollen toe aan de databasegebruiker die lees-, schrijf- en mogelijk andere machtigingen toestaat.
Er zijn meerdere hulpprogramma's beschikbaar om deze stappen te implementeren:
ServiceConnector is een hulpprogramma waarmee geverifieerde verbindingen tussen verschillende services in Azure worden gestroomlijnd. Service Connector ondersteunt momenteel het verbinden van een App Service met een SQL-database met behulp van de azure CLI-extensie zonder wachtwoord.
Installeer of upgrade de serviceconnector-extensie zonder wachtwoord:
az extension add --name serviceconnector-passwordless --upgradeVoer de
az webapp connection create sqlopdracht uit om uw web-app te verbinden met de database met behulp van een door het systeem toegewezen beheerde identiteit. Vervang de tijdelijke aanduidingen door de juiste waarden:az webapp connection create sql -g <your-resource-group> -n <your-app-service-name> --tg <your-database-server-resource-group> --server <your-database-server-name> --database <your-database-name> --system-identity
U kunt de wijzigingen controleren die door Service Connector zijn aangebracht in de App Service-instellingen.
Ga naar de pagina Identity voor uw App Service. Op het tabblad Systeem dat is toegewezen, moet de status zijn ingesteld op Op. Deze waarde betekent dat een door het systeem toegewezen beheerde identiteit is ingeschakeld voor uw app.
Ga naar de pagina Configuration voor uw App Service. Op het tabblad Verbindingsreeksen ziet u een verbindingsreeks met de naam
AZURE_SQL_CONNECTIONSTRING. Selecteer de klikknop om waardetekst weer te geven om de gegenereerde verbindingsreeks zonder wachtwoord weer te geven. De naam van deze verbindingsreeks komt overeen met de naam die u in uw app hebt geconfigureerd, zodat deze automatisch wordt gedetecteerd wanneer deze wordt uitgevoerd in Azure.
Belangrijk
Hoewel deze oplossing een eenvoudige aanpak biedt om aan de slag te gaan, is het geen best practice voor bedrijfsproductieomgevingen. In deze scenario's moet de app niet alle bewerkingen uitvoeren met één, verhoogde identiteit. U moet proberen het principe van minimale bevoegdheden te implementeren door meerdere identiteiten met specifieke machtigingen voor specifieke taken te configureren. Zie voor meer informatie over het configureren van databaserollen en -beveiliging:
De geïmplementeerde toepassing testen
Blader naar de URL van de app om te testen of de verbinding met Azure SQL Database werkt. U kunt de URL van uw app vinden op de overzichtspagina van App Service. Voeg het /person pad toe aan het einde van de URL om naar hetzelfde eindpunt te bladeren dat u lokaal hebt getest.
De persoon die u lokaal hebt gemaakt, moet worden weergegeven in de browser. Gefeliciteerd, uw toepassing is nu verbonden met Azure SQL Database in zowel lokale als gehoste omgevingen.
De middelen opschonen
Wanneer u klaar bent met het werken met de Azure SQL Database, verwijdert u de resource om onbedoelde kosten te voorkomen.
Zoek in de zoekbalk van Azure Portal naar Azure SQL- en selecteer het overeenkomende resultaat.
Zoek en selecteer uw database in de lijst met databases.
Selecteer op de pagina Overzicht van uw Azure SQL Database Verwijderen.
Op de Azure-pagina die wordt geopend, waar u zeker weet dat u wilt verwijderen..., voert u de naam van uw database in om te bevestigen en selecteer vervolgens Verwijderen.
Opmerking
Als u de voorbeeld-app in Azure hebt geïmplementeerd, moet u ook de App Service-resource zoeken en verwijderen om onbedoelde kosten te voorkomen.
Verwante inhoud
- Zelfstudie: Een database beveiligen in Azure SQL Database
- databasetoegang tot SQL Database, SQL Managed Instance en Azure Synapse Analytics autoriseren
- Een overzicht van de beveiligingsmogelijkheden van Azure SQL Database en SQL Managed Instance
- Playbook voor het aanpakken van algemene beveiligingsvereisten met Azure SQL Database en Azure SQL Managed Instance