NET Core 1.0-學習筆記(一)
下面是本篇將要分享的學習步奏,對於剛學或者即將要學習的朋友做個相互交流:
1.window7系統搭建開發環境
2.快速建立個net core Web Application專案,簡單認識core專案自動生成的mvc檔案
3.使用命令dontnet run讓瀏覽器可以訪問專案
4.連線本地資料庫操作
5.分析Startup.cs檔案的程式碼
6.使用Program.cs檔案開放多個埠使站點執行起來
1.window7系統搭建開發環境
首先,去https://www.microsoft.com/net/download地址下載幾個安裝檔案,根據自己的系統下載不同的版本吧,這裡截圖說明下當前我安裝的包,如下:
這要要說的是最後一個包的功能,主要讓程式執行起來,監聽埠,近似於iis釋出站點功能(有更多希望大家補充或糾正);
都安裝完後會重啟一次,那下面開啟您的vs2015 visual C#->.Net Core:如果可以大家看到的應該是3個可選項:類庫,控制檯程式,net core web application;
記得當時第一想的怎麼沒有winform的呢,後來覺得winform裡面需要一些資源皮膚等現有資源這些在其他系統沒有,估計也是這裡看不到的原因吧,這裡只是猜測系統某個後來者能證實下,謝謝。
2.快速建立個net core Web Application
專案,簡單認識core
專案自動生成的mvc檔案
選擇net core Web Application
點選”確定”按鈕,看到如下圖:
這裡感覺很以前建立mvc
的介面都差不多,沒什麼具體說明的,這裡有一個在雲中託管,操作步驟具體請看官網地址:https://docs.asp.net/en/latest/tutorials/publish-to-azure-webapp-using-vs.html;輸入專案的名稱,即可得到如下目錄:
注:
1.appsettings.json檔案初始化的資訊是本地資料庫連結和日誌logging配置資訊
2.gulpfile.js載入一些js檔案,css等
3.project.json專案工程包
4.web.config裡面內嵌了一個aspNetCore節點
5.Program.cs檔案裡面有個main函式,這裡是專案開啟入口
6.Startup.cs檔案主要是初始化設定的地方
7.program和startup關聯的,首先程式進入program裡面的main函式,在WebHostBuilder執行run之前會通過UseStartup進入到startup檔案的各個方法中,順序是:Startup(構造器初始化載入一些配置檔案)-》ConfigureServices(新增各個服務的依賴關係)-》Configure
3.使用命令dontnet run
讓瀏覽器可以訪問專案
首先,在vs中右鍵專案-》在資源管理器中開啟檔案-》點選src路徑資料夾-》找到對應的專案資料夾-》按住鍵盤Shift+滑鼠右鍵專案資料夾-》選擇在此處開啟命令視窗,這樣就進入了cmd介面路徑是專案資料夾路徑(其實也可以直接cmd-》碟符:-》cd 專案資料夾路徑和剛才說的效果一樣);
然後,在cmd
中錄入:dotnet run
,這裡cmd窗體會顯示一些資訊如圖:
截圖上面顯示了一個5000
埠,沒錯您即可在瀏覽器中輸入localhost:5000
訪問您的專案,先來看下我們執行起來的截圖:
這5000
是預設的開啟監聽埠,下面會在第6步奏講到怎麼監聽其他埠
4.連線本地資料庫操作
首先,在Models
資料夾中建立一個子資料夾AiticleModels
,其中再增加一個類檔案Article
類;
然後,在Controllers
資料夾中建立一個ArticleController
,建立Controller
時選擇MVC Controller with views, using Entity Framework
,並且在下一步的時候選擇之前建立的Article類作為模型類,資料庫上下文選擇自動下拉的ApplicationDbContext
,如圖:
點選“確定”按鈕後,會在試圖View
資料夾和Controller
資料夾中分別生成一些檔案,這裡有點問題的地方是滑鼠在Controller
中Action
方法上右鍵不會出現跳轉至試圖的選項了,不知道是本來就沒有還是那個沒找到,知道的朋友請分享告知下;
上面除了會在Views
,Controllers
資料夾中增加一些檔案外,會自動再Data
資料夾下面的ApplicationDbContext.cs
檔案中新增如下程式碼:
public DbSet<Article> Article { get; set; }
好了咋們生成下專案看編譯是否通過,應該是沒問題的生成成功;進行到下一步,和上面第3點將的差不多,在vs中右鍵專案-》在資源管理器中開啟檔案-》點選src路徑資料夾-》找到對應的專案資料夾-》按住鍵盤Shift+滑鼠右鍵專案資料夾-》選擇在此處開啟命令視窗,然後分別輸入如下命令:
dotnet ef migrations add Initial dotnet ef database update
當執行第一條命令時候,Data
資料夾下面Migrations
資料夾中會自動增加一個.cs檔案,名稱格式如:時間+_Initial.cs,開啟看一下吧,感覺有點複雜的樣子哈哈,但是從中可以瞭解到是建立表結構,和刪除表的方法;好了在執行第二條命令;命令截圖如下:
效果是除了Migrations
資料夾中增加了cs檔案,還有咋們可以在vs中點選 試圖-》Sql Server物件管理器-》點選LocalDB
-》資料庫-》aspnet-Text.Core-2c3af9e6-9257-4859-9cea-dcc21968bf8b 能看到增加了個本地資料庫,再開啟表Article,能看到欄位是咋們剛才在Article類中對應的屬性,值得注意的時候這裡直接預設了ID為咋們的主鍵,這裡應該是預設第一個屬性欄位為主鍵
再來,生成下確定沒問題,我們們執行下dotnet run
命令開啟監聽,在瀏覽器中輸入http://localhost:5000/Articles,看到的結果是table框裡面空白的頁面,想一想資料庫沒有資料啊,那麼新增幾條吧,點選頁面上的“Create New”,隨便輸入個時間和標題,儲存後返回到列表頁面,能看到此時已經增加了一條資料,好了看下資料庫也有資料了;截圖如下:
5.分析Startup.cs
檔案的程式碼
上面說了那麼多,終於來到了第5節點了;程式碼簡單分析還是通過程式碼中寫備註的方式來說明吧,截圖不怎麼友好,希望各位朋友看下程式碼:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Text.Core.Data;
using Text.Core.Models;
using Text.Core.Services;
namespace Text.Core
{
public class Startup
{
/// <summary>
/// Startup檔案中執行方法的步驟使用A,B,C,D表示
/// </summary>
/// <param name="env"></param>
/// 步驟A IHostingEnvironment獲取環境變數資訊,沒錯就是獲取環境變數
public Startup(IHostingEnvironment env)
{
//這裡建立ConfigurationBuilder,其作用就是載入Congfig等配置檔案
var builder = new ConfigurationBuilder()
//env.ContentRootPath:獲取當前專案的跟路徑
.SetBasePath(env.ContentRootPath)
//使用AddJsonFile方法把專案中的appsettings.json配置檔案載入進來,後面的reloadOnChange顧名思義就是檔案如果改動就重新載入
.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
//這裡關注的是$"{param}"的這種寫法,有點類似於string.Format()
.AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true);
if (env.IsDevelopment())
{
//待研究
builder.AddUserSecrets();
//待研究
builder.AddApplicationInsightsSettings(developerMode: true);
}
builder.AddEnvironmentVariables();
//這返回一個配置檔案跟節點:IConfigurationRoot
Configuration = builder.Build();
}
/// <summary>
/// 通過構造器獲取配置檔案等資訊(個人眉腳:這裡是不是可以把這個節點開放到整個專案都是用,因為有些配置資訊需要在實際的程式碼類中使用到,這樣就不用再單獨再獲取一次了吧)
/// </summary>
public IConfigurationRoot Configuration { get; }
/// <summary>
/// 步驟B 各種服務依賴註冊的地方,netcore還是配置依賴注入方式為主
/// </summary>
/// <param name="services"></param>
public void ConfigureServices(IServiceCollection services)
{
//待驗證功能
services.AddApplicationInsightsTelemetry(Configuration);
//這裡是注入了資料庫上下文,如果沒有這裡,剛才的Controller獲取出來根本就獲取不到資料資訊
//Configuration.GetConnectionString("DefaultConnection")獲取了配置檔案appsettings.json中的DefaultConnection節點資料
//注:因為ConfigurationBuilder的作用,咋們以後獲取json配置檔案時候可以使用如appsettings.json檔案中的:Configuration.GetSection("Logging:LogLevel:Microsoft"); 方法,獲取json層級關係的屬性值
services.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
//注入Indentity,目前這個IdentityRole在這裡暫時沒用到
services.AddIdentity<ApplicationUser, IdentityRole>()
.AddEntityFrameworkStores<ApplicationDbContext>()
.AddDefaultTokenProviders();
//新增mvc服務,沒有這個mvc執行不起
services.AddMvc();
//注入netcore自帶的兩個服務
services.AddTransient<IEmailSender, AuthMessageSender>();
services.AddTransient<ISmsSender, AuthMessageSender>();
//這裡還有其他注入方式
//services.AddSingleton<>();//單例注入
//services.AddScoped<>();//作用域注入
//services.AddMemoryCache(); //MemoryCache快取注入
}
/// <summary>
/// 步驟C
/// </summary>
/// <param name="app"></param>
/// <param name="env"></param>
/// <param name="loggerFactory"></param>
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
{
//新增Console輸出
loggerFactory.AddConsole(Configuration.GetSection("Logging"));
loggerFactory.AddDebug();
//待研究
app.UseApplicationInsightsRequestTelemetry();
if (env.IsDevelopment())
{
//跳轉到異常頁面,異常錯誤展示
app.UseDeveloperExceptionPage();
app.UseDatabaseErrorPage();
app.UseBrowserLink();
}
else
{
//如果錯誤,從定向到錯誤改路由
app.UseExceptionHandler("/Home/Error");
}
//待研究
app.UseApplicationInsightsExceptionTelemetry();
//啟動靜態檔案
app.UseStaticFiles();
//啟動靜態檔案
app.UseIdentity();
//設定mvc路由
app.UseMvc(routes =>
{
//這裡的{id?} ?號表示可以有可無
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
}
}
}
6.使用Program.cs
檔案開放多個埠使站點執行起來
首先在,Program.cs
檔案Main
方法中增加如下程式碼部分
public static void Main(string[] args)
{
var host = new WebHostBuilder()
.UseKestrel()
//增加處,*號表示ip
.UseUrls("http://*:5001,http://*:5002")
.UseContentRoot(Directory.GetCurrentDirectory())
.UseIISIntegration()
.UseStartup<Startup>()
.Build();
host.Run();
}
然後,重新執行dotnet run
,能看到如下情況:
開啟了兩個埠的監聽,那麼在瀏覽器上分別訪問下:
相關文章
- NET Core-學習筆記(一)筆記
- 《學習筆記》.NET Core API搭建筆記API
- NET Core-學習筆記(二)筆記
- NET Core-學習筆記(三)筆記
- NET Core-學習筆記(四)筆記
- .NET Core學習筆記(8)——Entity Framework Core之Database First筆記FrameworkDatabase
- .NET Core學習筆記(9)——Entity Framework Core之Code First筆記Framework
- .NET Core學習筆記(7)——Exception最佳實踐筆記Exception
- Asp.Net Core學習筆記:入門篇ASP.NET筆記
- .Net Core 學習筆記1——包、元包、框架筆記框架
- ASP.NET Core 學習筆記 第四篇 ASP.NET Core 中的配置ASP.NET筆記
- .Net-Avalonia學習筆記(一)-HelloWorld筆記
- ASP.NET Core 學習筆記 第五篇 ASP.NET Core 中的選項ASP.NET筆記
- (一)學習瞭解OrchardCore筆記——開篇:基於asp.net core的OrchardCore筆記ASP.NET
- Networking && Internet 計網學習筆記一筆記
- 【一】kubernetes學習筆記-Pod概念筆記
- ASP.NET Core 學習筆記 第二篇 依賴注入ASP.NET筆記依賴注入
- oracle 學習筆記 (ORACLE NET )Oracle筆記
- ASP.NET MVC學習筆記:(一)路由匹配ASP.NETMVC筆記路由
- .NET 5學習筆記(10)——Entity Framework Core之切換SQLServer和SQLite筆記FrameworkServerSQLite
- 學習筆記(一)筆記
- ASP.NET學習筆記2ASP.NET筆記
- Kubernetes scheduler學習筆記筆記
- tensorflow學習筆記——DenseNet筆記SENet
- Netty學習筆記之ChannelHandlerNetty筆記
- [.net core學習] .net core中的Rijndael取代方法
- dotnet學習筆記一 - 裝箱拆箱 (轉)筆記
- .NET 雲原生架構師訓練營(ASP .NET Core 整體概念推演)--學習筆記架構筆記
- .NET 6學習筆記(3)——在Windows Service中託管ASP.NET Core並指定埠筆記WindowsASP.NET
- .NET 6學習筆記(7)——ASP.NET Core透過配置檔案啟用HTTPS筆記ASP.NETHTTP
- kitten 學習教程(一) 學習筆記筆記
- LaTeX學習筆記:一筆記
- ANFIS學習筆記(一)筆記
- Angular 學習筆記(一)Angular筆記
- GOLang 學習筆記(一)Golang筆記
- oracle學習筆記《一》Oracle筆記
- React 學習筆記【一】React筆記
- Jquery學習筆記(一)jQuery筆記