寫 SideProejct 剛好有資料庫的需求,Heroku 有提供免費的 PostgreSQL 方案可以使用.
環境
- ASP.NET 5(Blazor App)
- Heroku PostgreSQL
Heroku
必須先有一個Heroku的帳號,接著建立一個 App
data:image/s3,"s3://crabby-images/23c0b/23c0bccc5aee0d5c11df58e30aae625e40e422f1" alt=""
在 App 內的 Resource 的 Add-ons 找到 Heroku PostgreSQL
data:image/s3,"s3://crabby-images/2af69/2af692543a2b6f70afc5e35cdbe1d4c26341b066" alt=""
將 Heroku PostgreSQL
加入 App,這邊可以選擇方案(價錢),正好就有 Free 的方案可以使用(詳細的規格內容可以從這邊查看)
data:image/s3,"s3://crabby-images/83c34/83c348253a19e8c7d30df0bc80f8b4bf88929c0b" alt=""
新增後在 Resource 裡面就有 PostgreSQL 可以使用
data:image/s3,"s3://crabby-images/b15c3/b15c3dd542337c6c128b3b3bbfd618055746157b" alt=""
點進去後,在 Settings
的 Database Credentials
裡面就是我們需要的連線內容
data:image/s3,"s3://crabby-images/2869c/2869c1d5b744ece1bc81601f819bad9102175064" alt=""
ASP.NET
建立專案,並加入 nuget package
- Microsoft.EntityFrameworkCore
- Npgsql.EntityFrameworkCore.PostgreSQL
準備好一個 DbContext
public class MyDbContext : DbContext
{
public MyDbContext(DbContextOptions options)
: base(options)
{
}
public DbSet<Product> Products { get; set; }
protected override void OnModelCreating(ModelBuilder builder)
{
builder.HasDefaultSchema("MySchema");
builder.ApplyConfiguration(new ProductConfig());
base.OnModelCreating(builder);
}
}
在 Startup 加入 DbContext
public void ConfigureServices(IServiceCollection services)
{
services.AddRazorPages();
services.AddServerSideBlazor();
services.AddSingleton<WeatherForecastService>();
services.AddDbContext<MyDbContext>(builder =>
{
builder.UseNpgsql(Configuration.GetConnectionString("MyDb"),
optionsBuilder =>
{
// Heroku PostgreSQL 必須使用 SSL
// 如果沒設定這行,會在連線時拿到 SSL off 的錯誤
optionsBuilder.RemoteCertificateValidationCallback(
(_, _, _, _) => true);
});
});
}
}
在 AppSetting 加上連線字串,這邊必須加上 SslMode=Require
{
"ConnectionStrings": {
"MyDb": "Server=<host>;Database=<database>;User Id=<user>;Password=<password>;SslMode=Require;"
}
}
接著試著連線並取得資料
data:image/s3,"s3://crabby-images/f2f59/f2f59de6dcd7518f6c8a919519fd92c43e66c923" alt=""
data:image/s3,"s3://crabby-images/299fd/299fd242a2efe3563e93e6e15f6f1859c312ef37" alt=""
成功
data:image/s3,"s3://crabby-images/9c3ef/9c3ef7a4be26df297545f475c754e540f8573e0f" alt=""