Custom HTTPS Dev Environment using .NET Core, Kestrel & certificates

  Рет қаралды 48,992

Les Jackson

Les Jackson

Күн бұрын

Пікірлер: 97
@binarythistle
@binarythistle 4 жыл бұрын
⏲️ *Jump-to Time Codes!* ⏲️ ---------------------------------------------- *INTRODUCTION* - 2:21 Course Overview - 5:46 Demo - 6:27 Tooling *HTTPS OVERVIEW * - 6:49 What is HTTPS, SSL & TLS? - 7:46 Certificate & Authorities Overview - 9:44 What does a certificate contain? - 10:30 Public & Private Key Overview - 11:48 HTTPS How it Works (Interaction Diagram) *LOCALHOST SET UP * - 14:37 Scaffold Up our API - 19:25 Generating a Local Dev Certificate - 22:37 The need for a custom domain *CUSTOM DOMAIN PART 1 * - 23:56 Update HOSTS File - 27:02 Host name resolution order - 28:15 Create our Self-Signed Certificate - 35:00 Import Certificate into Trusted Root *CUSTOM DOMAIN PART 2 * - 36:58 - User Secrets Overview - 38:30 - Configure User Secrets - 42:14 - Update appsettings.Development.json - 44:07 - Create HostConfig static Class - 46:00 - Update Program Class - Read in Config - 49:55 - Load Certificate into Kestrel - 55:13 - Listen on Specific IP Address *FINAL THOUGHTS & ACKNOWLEDGEMENTS * - 57:57 - Wrap Up - 58:39 - Credits
@adamq272
@adamq272 2 жыл бұрын
You are the only one who explain all the details clearly, I appreciate that. Thanks a lot.
@antonyrichard369
@antonyrichard369 3 жыл бұрын
Amazing video. Unbelievable such a kind effort to help others also to learn what you learned. Your sequence of teaching is so good. Thank you very much for this video
@insanekelso
@insanekelso 4 жыл бұрын
Greetings from the Scottish Borders. Why has it taken so long for KZbin algo to suggest your videos to my feed?? These are without doubt the best tutorials on KZbin and I watched loads. Love the way you don’t copy/paste code or waffle while typing. Keep them coming
@binarythistle
@binarythistle 4 жыл бұрын
Hi Ian, thanks mate - I wish I had more control over the KZbin algorithm! Glad you've found the channel though and are enjoying the content. Cheers, Les
@janivimal
@janivimal 11 ай бұрын
Fantastic session with lots of learning , at the same time very interesting to watch. Thank you for putting so much effort in creating and sharing this with developer community. I would love to see more videos taking step further to see how can we deploy this into cloud , ex running as a container. Thanks again !!
@christopherdunderdale7238
@christopherdunderdale7238 2 жыл бұрын
Suddenly getting the urge for a dram while listening to you Les 😅 Great content thank you!
@RobertCoulston_au
@RobertCoulston_au 4 жыл бұрын
Brilliant - now I understand certificates with some degree of confidence
@msharief6273
@msharief6273 3 жыл бұрын
Thank you! It was treat to watch this video! Loved it ! Enjoyed it !
@jakubmichalenko7990
@jakubmichalenko7990 3 жыл бұрын
Thank you very much, I am just finishing my first production Api and I have been stuck on this for past 2 days :DD
@frankoppermann1877
@frankoppermann1877 5 ай бұрын
Very nice explained. Great job.
@TheDemoded
@TheDemoded 4 жыл бұрын
There is a Auto completion in Powershell. If you start typing "convertto-s" and press TAB you'll get "ConvertTo-SecureString". It works with parameters and directories\files as well.
@binarythistle
@binarythistle 4 жыл бұрын
Hi Andy - where were you a few days ago! You'd have saved me a bit of typing! Great tip & thanks! Les
@ardonbailey2654
@ardonbailey2654 4 жыл бұрын
Thank you for making this. Super helpful. I always appreciate all your videos.
@ricardopfeuti9831
@ricardopfeuti9831 4 жыл бұрын
Hi Les. I would like to thank you so much for providing this tutorial. It helped me a lot.
@motomiprysork4923
@motomiprysork4923 4 жыл бұрын
Thank you for another great video! I followed along with my API and works great within my dev machine. One question though in my dev environment, I need to call this API from another dev machine (2nd machine) in the same network. I'm trying to reach the API using IP address since I don't have the host file set up on the 2nd machine. I'm getting certificate issue. These 2 machines can ping each other.
@luizacacio2012
@luizacacio2012 2 жыл бұрын
Jackson, do you have any videos showing api with digital authentication? I need to prepare my api to receive notification from a webhook, which uses mtls for communication.
@marlonchosky
@marlonchosky Жыл бұрын
Thanks so much dude! You're video is helping me a lot. Question, if I don't want to create a domain name but only use the ip address of my machine, will I only need to generate the certificate but using the ip address instead of the domain name?
@carlitobrigante293
@carlitobrigante293 4 жыл бұрын
8:36... "hopefully" we trust ourselves. very deep..
@buddyrowe7460
@buddyrowe7460 4 жыл бұрын
Hey Les, very well done! Thank you. I've been scouring the Internet trying to find how to use my TLS cert in Kestrel.
@parsalotfy
@parsalotfy 4 жыл бұрын
your tutorials are great man , great, thank you a million
@YenHoMinh-m7u
@YenHoMinh-m7u Жыл бұрын
Amazing video. I hope u make another tutorial video for docker
@anasameen6391
@anasameen6391 4 жыл бұрын
finally it's nice to see you again 🎉🎉
@binarythistle
@binarythistle 4 жыл бұрын
Nice to be back Anas!
@rsodeyi
@rsodeyi 4 жыл бұрын
Thank you so much for this. Even the parts you said you wouldn't go deep into were plenty. I was able to secure my local dns and understand better how the whole thing hangs together. My issue is that I am working with Nativescript and just for added measure, SignalR as well. I've been struggling with trying to get an Android Emulator to communicate with my server while it ignores my hosts file and has it's own version of all my DNSs ...good times. I don't see it on your channels as yet but I'm really really hoping it's an area you are planning to explore. However, getting this ssl part has really helped to get to the next step of Jumanji Infinity
@jasonbartlett1357
@jasonbartlett1357 2 жыл бұрын
Great tutorial. I'm doing this in .NET 6 and using minimal api approach. I have a question about using options.ListenAnyIP vs. the Dns host approach: If use ListenAnyIP, when I run the app, it opens to the url I have in the config, (and the url matches the cert url), But, if I use the resolved DNS ip, when I run the app, it doesn't open the url, and if I go to the url, it can't validate the certificates. So what options can I use to have it go to the url, rather than try to use the ip address?
@2005bgva
@2005bgva 4 жыл бұрын
Fantastic video, thanks a lot. One question, are you going to do a video for a production enviroment?
@ankushmadankar1756
@ankushmadankar1756 Жыл бұрын
Very nice video! Saved my day.. Just a question will this work with CA signed certificate on production?
@arun3836
@arun3836 4 жыл бұрын
Hi Les , Great video . I really enjoyed it.
@binarythistle
@binarythistle 4 жыл бұрын
Glad you enjoyed it Arun, Cheers, Les
@everyonesview
@everyonesview 4 жыл бұрын
I have enjoyed this one than any other, Les! Many thanks ❤
@binarythistle
@binarythistle 4 жыл бұрын
Awesome! Wasn't sure about this topic to be honest, it's a little outside of what I usually do, but thought people might find it useful! Glad you enjoyed it!
@rogerfernandes7269
@rogerfernandes7269 3 жыл бұрын
You're amazing sir, getting to learn loads of useful stuff from you. Thank you. Keep up the good work.
@vladeb1104
@vladeb1104 3 жыл бұрын
Best wishes from Scotland (Balloch).
@Adronius
@Adronius 2 жыл бұрын
Would be great to see that updated for .NET 6
@nathanwaterman4380
@nathanwaterman4380 3 жыл бұрын
`dotnet dev-certs https --trust` doesn't work for me. It creates the certificate but doesn't Trust it. It only appears under Personal Certificates :/
@nathanwaterman4380
@nathanwaterman4380 3 жыл бұрын
Brilliant! As part of following this tutorial I discovered that my anti-virus, WebRoot, was blocking the creation of trusted certificates. It was also stopping me from the updating the host file.
@mister_stadler
@mister_stadler Жыл бұрын
Fantastic! Thanks a lot!
@petrkassadinovich2705
@petrkassadinovich2705 4 жыл бұрын
Thanks for tutorial! Btw, you can read configuration file just from .ConfigureKestrel( ), so you don't need to use custom class HostConfig for passing values. .ConfigureWebHostDefaults(webBuilder => { webBuilder.ConfigureKestrel((context, kestrel) => { var file = context.Configuration["CertificateFileLocation"]; var password = context.Configuration["CertPassword"]; }); })
@shaktisingh-lu3dm
@shaktisingh-lu3dm Жыл бұрын
Thanks a lot for such great help :)
@stampgermany
@stampgermany 3 жыл бұрын
You've helped a lot! Thanks!
@KritX01
@KritX01 4 жыл бұрын
Hey Les, thanks for the amazing content that you put out! It really helps us! I would like to ask you if you could do a video on microservices and microservices internal communication. How would one do it and if can we use kubernetes to scale the microservices. Thanks!
@binarythistle
@binarythistle 4 жыл бұрын
HI there, next videos I'm doing will beL API Gateway, Service Mesh and Asynchronous messaging, all of which really talk about Microservices!
@KritX01
@KritX01 4 жыл бұрын
@@binarythistle oh yes please thank you! :D
@sky78710
@sky78710 Ай бұрын
How can use docker for custom https like you do in this video? Please help
@ayxanalifov2791
@ayxanalifov2791 4 жыл бұрын
Thanks so much... Very high quality content !!!
@MarcioAntonioSlivak
@MarcioAntonioSlivak 4 жыл бұрын
Thank you very much, you saved my weekend.
@darshanyadav4784
@darshanyadav4784 2 жыл бұрын
Hello, I've a doubt. How do change the url length in kestrel so that I can pass strings of larger length?
@mateuszkaleta1495
@mateuszkaleta1495 2 жыл бұрын
is this a big difference when we configure our SSL only in application code / or only in server configuration?
@maxbitran
@maxbitran 4 жыл бұрын
Thanks man! Really helpful.
@glennsingh354
@glennsingh354 3 жыл бұрын
Thanks a lot for this wonderful content.
@aikidoshi007
@aikidoshi007 4 жыл бұрын
Hi Les, nice video, this has always been a mystery to me. One issue I have noticed is that although Edge works as shown, Chrome still says the certificate is Invalid. Not sure why, any ideas? It does come good after setting up the certificate etc. Bad luck about Melbourne being back in lockdown, I'm in Forest Hill and was excited about starting to get out again :-(
@binarythistle
@binarythistle 4 жыл бұрын
Hi Steve. This drove me crazy for a bit until I restarted the browser! I should have mentioned that in the video. Drop us a line if that doesn't resolve it - seems to be working in Chrome for me, (after the restart). Another thing I should have mentioned is that Firefox uses its own cert store so uses will need to import the cert following these instructions: knowledge.digicert.com/solution/SO5437 Yeah lock-down again is a pain, but I guess it's for the greater good! Hopefully the numbers start to drop. Thanks for feeding back, and stay safe, Les
@radeksendecki9922
@radeksendecki9922 4 жыл бұрын
I had the same issue. Thanks for Your question and aswer :)
@petargavrilov976
@petargavrilov976 2 жыл бұрын
Hi Les. I wonder why don't we remove the http entry from application url and just use https only ?
@aliascross
@aliascross 4 жыл бұрын
Thanks, It's works well with Edge browser, but in my case, it does not work with Firefox or Safari (which ask to add an exception). Custom Certificate is it the good way to use API https connection a LAN Production project ?
@alxizr
@alxizr 4 жыл бұрын
@Les Jackson #Les Jackson Hi, I was wondering if there is a way to utilize Typescript with dotnet core 3.1 and web api? I would really love to see the use of Typescript in the backend on dotnet core.
@diegobaroffio4462
@diegobaroffio4462 4 жыл бұрын
Hi Les, Thank you for your very well structured video, it's great. One question: Any reason why not reading the certificate from the Certificate Store instead of reading from file? This way you don't have even to worry with passwords. Regards.
@anbupa
@anbupa Жыл бұрын
Hola desde chile.. Si no quisiera levantarlo con Kestrel sino por iis express como sería?
@lifeisgameplayit
@lifeisgameplayit 2 жыл бұрын
I like your content , thanks m8 !
@shahid13384
@shahid13384 4 жыл бұрын
Thank you for great explanation
@saurabhchauhan232
@saurabhchauhan232 4 жыл бұрын
Thank you very much for this video sir,I really enjoy watching video on this channel.God bless you.
@saurabhchauhan232
@saurabhchauhan232 4 жыл бұрын
can you make video on real world problem and solution with design patterns
@binarythistle
@binarythistle 4 жыл бұрын
You are most welcome Saurabh!
@bblair2010
@bblair2010 3 жыл бұрын
Hey Les, I would I get this to work when deployed in Azure?
@LakhanSINGH-rk9et
@LakhanSINGH-rk9et 4 жыл бұрын
Hi Les , This was a great video . Totally loved it Would you be making video on EshopOnContainers microservices ?
@binarythistle
@binarythistle 4 жыл бұрын
Hi Lakhan, yes I'm working on something at the moment, I've taken EshopOnContiners and am re-working it slightly to make it easier to teach with. Hopefully not too long before I complete it.
@LakhanSINGH-rk9et
@LakhanSINGH-rk9et 4 жыл бұрын
@@binarythistle Thanks Les , Waiting for that video to come out. Would be supporting that video on patreon
@manishrao18
@manishrao18 3 жыл бұрын
Just in case, for intellisense use Windows Powershell ISE and use TAB key for auto-complete
@paulsanchez5030
@paulsanchez5030 Жыл бұрын
Did you find a good Open SSL article?
@AGMXZ1
@AGMXZ1 4 жыл бұрын
Thanks Les. I'm struggling with getting my react app and jquery to talk to my local webapi so I'm hoping this does the trick.
@AGMXZ1
@AGMXZ1 4 жыл бұрын
Still failing for me. I'm trying this on my corporate desktop computer. When I run the GET against the weatherforecast from Postman with HTTPS verification enabled it also fails. When I disable verification I get data back, even using the DNS name which is cool, but the SSL verification fails. When I look at the warning in the Postman console I get: Warning: Unable to verify the first certificate When I look further down in the warning in the TLS section I see something perhaps more specific. authorizationError: "UNABLE_TO_VERIFY_LEAF_SIGNATURE"
@EminoMeneko
@EminoMeneko Жыл бұрын
On my work machine it... works. On Linux too. On my personal machine it... gets personal and throws 'System.Security.Cryptography.CryptographicException' occurred in System.Security.Cryptography.dll: 'Access denied.' Any idea what makes it break ?
@gajarubanjeyakumar7226
@gajarubanjeyakumar7226 3 жыл бұрын
Thankyou!
@crazyhiker379
@crazyhiker379 4 жыл бұрын
Thanks boss for your contents.
@binarythistle
@binarythistle 4 жыл бұрын
My pleasure Prasanth!
@vpep5439
@vpep5439 4 жыл бұрын
Thank you very much for sharing videos
@binarythistle
@binarythistle 4 жыл бұрын
No worries Pei!
@joseperezbalan7788
@joseperezbalan7788 Жыл бұрын
could you make a video for certs in ubuntu or linux base os ?, i have spend three days and still have not got it to work.. dev certs for linux is a pain in the ass .
@CarlosAndres-lv1zq
@CarlosAndres-lv1zq 4 жыл бұрын
Thank you so much
@patrickcandlin7420
@patrickcandlin7420 8 ай бұрын
❤ PowerShell here
@nick11927
@nick11927 4 жыл бұрын
Thank you!
@binarythistle
@binarythistle 4 жыл бұрын
You're welcome!
@Teutathis
@Teutathis 4 жыл бұрын
DHCP is Dynamic Host _Configuration_ Protocol. Great video though
@3AgL3DeeJay
@3AgL3DeeJay 4 жыл бұрын
PLEASE HELP MEE!!! Amazing video but if I add that "var host = Dns.GetHostEntry("");" line in program.cs my code jumps to that line instead of entering into ".ConfigureServices((context, services) =>"... any idea why??? I'm trying to get the string with the domain from config so I'm using it like this: prnt.sc/vwnlaq thanks!
@3AgL3DeeJay
@3AgL3DeeJay 4 жыл бұрын
Solved it! Now I get a "The requested address is not valid in its context" error....
@3AgL3DeeJay
@3AgL3DeeJay 4 жыл бұрын
Nevermind, I solved it! :D I was using the domain IP in the localhost. Thanks for the video man!
@kalpeshblue2
@kalpeshblue2 4 жыл бұрын
Super Like
@binarythistle
@binarythistle 4 жыл бұрын
Thanks!
@geojaya
@geojaya 4 жыл бұрын
Any one knows how to CA Signed Certificate to a custom domain using Kestrel
@DanielFantaneanu
@DanielFantaneanu 3 жыл бұрын
nice
@khaledslaimia3135
@khaledslaimia3135 4 жыл бұрын
what i fin dissapointing is a channel like that where we find a real treasure have little subscribers meanwhile gaming channels have millions.
@zenobiusztasak8604
@zenobiusztasak8604 3 жыл бұрын
Does it work on .net 5 ? I get an error NET::ERR_CERT_COMMON_NAME_INVALID
Run ASP.NET Core 3.1 Apps in Docker with HTTPS.
1:01:33
Les Jackson
Рет қаралды 88 М.
Secure a .NET Core API with Bearer Authentication
1:06:56
Les Jackson
Рет қаралды 192 М.
How Strong Is Tape?
00:24
Stokes Twins
Рет қаралды 96 МЛН
Мясо вегана? 🧐 @Whatthefshow
01:01
История одного вокалиста
Рет қаралды 7 МЛН
HTTP 1 Vs HTTP 2 Vs HTTP 3!
7:37
ByteByteGo
Рет қаралды 364 М.
Certificates from Scratch - X.509 Certificates explained
21:50
OneMarcFifty
Рет қаралды 137 М.
Coding Shorts: ASP.NET Core Middleware Explained
17:36
Shawn Wildermuth
Рет қаралды 32 М.
Quick and Easy Local SSL Certificates for Your Homelab!
12:08
Wolfgang's Channel
Рет қаралды 915 М.
Build an API Gateway with Envoy and use with .NET Core APIs
1:51:27
ASP.NET Core Kestrel Explained
15:58
Raw Coding
Рет қаралды 13 М.
Coding a Web Server in 25 Lines - Computerphile
17:49
Computerphile
Рет қаралды 360 М.
Making Minimalist Web Server in C on Linux
10:23
Nir Lichtman
Рет қаралды 260 М.