在ASP.NET Core 2.0中使用Facebook进行身份验证

Posted fanqisoft

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在ASP.NET Core 2.0中使用Facebook进行身份验证相关的知识,希望对你有一定的参考价值。

  已经很久没有更新自己的技术博客了,自从上个月末来到天津之后把家安顿好,这个月月初开始找工作,由于以前是做.NET开发的,所以找的还是.NET工作,但是天津这边大多还是针对to B(企业)进行定制开发的,一是技术框架已经成型了,招收几个会CRUD的就好,二是小企业众多,给不了太多的钱,老板们大多比较关心这个程序员的工作年限,什么技术的不怎么关心。所以找工作一直碰壁,有看中的直接说我们给不了这么多,你如果要这个数可以考虑什么的。so,我就直接没考虑。一是钱少,二是技术垃圾,学不到什么东西。

  所以前几天开始直接转行了,找java工作,java工作由于自己没有工作经验,二是java技术经理有一种天生的优越感,说实话,很难受。好不容易找到一个有两个部门的公司,现在是负责对这个公司的.NET Core进行技术指导和Java部门进行CRUD。还行吧,先干着再说。

  我还是想说,我是一名.Net程序员吧,不论现在做那个方面吧,从我大学开始学.Net开始我是对.Net有感情的。我自身也一直看好.Net Core,也一直拥抱.Net Core的开源。将来也会一直支持.Net Core的发展。

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

很多时候我们的系统框架需要集成单点登录来让用户使用第三方应用程序(如Facebook,Twitter,Google、QQ、微信等等)的账户登录我们的系统。在本文中,我将使用Facebook帐户来进行ASP.NET Core应用程序的身份验证。【如果Facebook访问404,请关闭此页面】

  1.安装.Net Core SDK(本文基于.Net Core 2.2)

  2.安装相关IDE(例如,VS、VS Code、JetBrains Rider)

⒉创建一个.Net Core MVC应用程序

技术图片

创建完成后目录如下

技术图片

⒊使用数据库迁移更新数据库

  工具>> NuGet包管理器>>程序包管理器控制台。

Update-Database

  迁移完成后可以通过SQL Server对象资源管理器查看自动为什么生成的数据库及表结构

技术图片

⒋运行项目查看效果并记住URL

 技术图片

创建一个Facebook应用程序

  1.访问facebook开发者网站并登录

  2.注册为开发者并新建一个应用

  技术图片

  3.选择应用场景

  技术图片

  4.点击左侧导航菜单中的Facebook登录>设置,在OAuth客户端授权设置页面的“ 有效OAuth跳转URI”字段中输入附加了/signin-facebook的应用程序的基本URL 。

技术图片

  5.单击导航菜单上的设置>基本将看到我们刚刚创建的Facebook应用程序的应用编号(App ID)和应用密钥(App Secret)值。单击应用密钥字段内的显示按钮以查看密码。记住这两个值,我们将利用这两个值在我们的Web应用程序中配置Facebook身份验证。

技术图片

 

⒍配置我们的应用程序以使用Facebook进行身份验证

  1.我们需要在应用程序中存储应用编号(App ID)和应用密钥(App Secret)字段值。我们将使用Secret Manager工具来实现此目的。Secret Manager工具是一个项目工具,可用于在开发过程中为.NET Core项目存储密码,API密钥等秘密。使用Secret Manager工具,我们可以将应用程序机密与特定项目相关联,并可以跨多个项目共享它们。

  在解决方案资源管理器中项目右键然后从上下文菜单中选择“管理用户机密”。

技术图片

将打开secrets.json文件,编写以下配置代码。

1 
2   "Authentication:Facebook:AppId": "465373197596195",
3   "Authentication:Facebook:AppSecret": "421e387a75dd8a3d96ab2ba5c8fb5329"
4 

  2.打开Startup.cs文件编写ConfigureServices 方法。

 1         public void ConfigureServices(IServiceCollection services)
 2         
 3             services.Configure<CookiePolicyOptions>(options =>
 4             
 5                 // This lambda determines whether user consent for non-essential cookies is needed for a given request.
 6                 options.CheckConsentNeeded = context => true;
 7                 options.MinimumSameSitePolicy = SameSiteMode.None;
 8             );
 9 
10             services.AddDbContext<ApplicationDbContext>(options =>
11                 options.UseSqlServer(
12                     Configuration.GetConnectionString("DefaultConnection")));
13             services.AddDefaultIdentity<IdentityUser>()
14                 .AddDefaultUI(UIFramework.Bootstrap4)
15                 .AddEntityFrameworkStores<ApplicationDbContext>();
16 
17             services.AddAuthentication().AddFacebook(facebookOptions =>
18             
19                 facebookOptions.AppId = Configuration["Authentication:Facebook:AppId"];
20                 facebookOptions.AppSecret = Configuration["Authentication:Facebook:AppSecret"];
21             );
22 
23             services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
24         

  完整的Startup.cs文件

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Threading.Tasks;
 5 using Microsoft.AspNetCore.Builder;
 6 using Microsoft.AspNetCore.Identity;
 7 using Microsoft.AspNetCore.Identity.UI;
 8 using Microsoft.AspNetCore.Hosting;
 9 using Microsoft.AspNetCore.Http;
10 using Microsoft.AspNetCore.HttpsPolicy;
11 using Microsoft.AspNetCore.Mvc;
12 using Microsoft.EntityFrameworkCore;
13 using FbAuth.Data;
14 using Microsoft.Extensions.Configuration;
15 using Microsoft.Extensions.DependencyInjection;
16 
17 namespace FbAuth
18 
19     public class Startup
20     
21         public Startup(IConfiguration configuration)
22         
23             Configuration = configuration;
24         
25 
26         public IConfiguration Configuration  get; 
27 
28         // This method gets called by the runtime. Use this method to add services to the container.
29         public void ConfigureServices(IServiceCollection services)
30         
31             services.Configure<CookiePolicyOptions>(options =>
32             
33                 // This lambda determines whether user consent for non-essential cookies is needed for a given request.
34                 options.CheckConsentNeeded = context => true;
35                 options.MinimumSameSitePolicy = SameSiteMode.None;
36             );
37 
38             services.AddDbContext<ApplicationDbContext>(options =>
39                 options.UseSqlServer(
40                     Configuration.GetConnectionString("DefaultConnection")));
41             services.AddDefaultIdentity<IdentityUser>()
42                 .AddDefaultUI(UIFramework.Bootstrap4)
43                 .AddEntityFrameworkStores<ApplicationDbContext>();
44 
45             services.AddAuthentication().AddFacebook(facebookOptions =>
46             
47                 facebookOptions.AppId = Configuration["Authentication:Facebook:AppId"];
48                 facebookOptions.AppSecret = Configuration["Authentication:Facebook:AppSecret"];
49             );
50 
51             services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
52         
53 
54         // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
55         public void Configure(IApplicationBuilder app, IHostingEnvironment env)
56         
57             if (env.IsDevelopment())
58             
59                 app.UseDeveloperExceptionPage();
60                 app.UseDatabaseErrorPage();
61             
62             else
63             
64                 app.UseExceptionHandler("/Home/Error");
65                 // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
66                 app.UseHsts();
67             
68 
69             app.UseHttpsRedirection();
70             app.UseStaticFiles();
71             app.UseCookiePolicy();
72 
73             app.UseAuthentication();
74 
75             app.UseMvc(routes =>
76             
77                 routes.MapRoute(
78                     name: "default",
79                     template: "controller=Home/action=Index/id?");
80             );
81         
82     
83 

⒎运行我们的应用程序进行测试

技术图片

技术图片

技术图片

 

 

以上是关于在ASP.NET Core 2.0中使用Facebook进行身份验证的主要内容,如果未能解决你的问题,请参考以下文章

ASP.NET Core 2.0中的HttpContext

如何在 ASP.NET Core 2.0 中根据路由配置服务身份验证

如何使用 Url.Action 在 asp.net core 2.0 razor 页面中传递多个操作

在ASP.NET Core 2.0中使用Facebook进行身份验证

ASP.Net Core 2.0 FileTable 使用

调试 ASP.NET Core 2.0 源代码