In this video I will demonstrate how you can make a Simple HTTPS Web Server using the C Programming Language and OpenSSL library on Linux. You can view the code I wrote in the video over here: github.com/nir9/welcome/tree/...
Пікірлер: 60
@nirlichtman6 ай бұрын
- Notice that if you run the server quickly after running it before, bind might fail since the port may not be cleaned up yet, so I recommend running the server with ltrace/strace so you can actually see what is going on under the hood, my new video about the importance of error handling in c also talks about this specifically
@enesalbay970715 күн бұрын
Add setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &(int){1}, sizeof(int)) before bind to overcome this problem.
@space98246 ай бұрын
These videos are so insightful, especially the way you show the man pages where you can find all this information. I literally didn't even know C library functions had man pages until I starting watching your content.
@Dysl3xicDog5 ай бұрын
The way you put the documentation digging into the videos is super helpful. The thing that's lost on me at this point is how you discover the functions you need to use before you hit the docs for each item.
@nirlichtman5 ай бұрын
Thanks for the feedback I will try talking more about the discovery as well on future videos, check out my man pages tips video for general tips about finding man pages.
@iamspeed14056 ай бұрын
Geez I opened the video and BOOM! it was straight into the action no silly 1 minute long intro. Love it ❤!
@bromophenol24696 ай бұрын
Nir, your distinct no nonsense style is very refreshing
@KimTiger7776 ай бұрын
Wow I guess Christmas came early this year. This opens up many possibilities with all kinds of web services. Only imagination is the limit! Thank you soo much!
@Maagiicc6 ай бұрын
Thanks for the longer video and more complicated program. Do you have any plans on doing anything non-minimalist?
@nirlichtman6 ай бұрын
Yes, I am planning on perhaps fully implementing one of the unix commands :)
@StefanWelebny6 ай бұрын
Could you show how to handle concurrent requests and concurrent listeners?
@AlTiri-rd7ly6 ай бұрын
@reapiu8316yeah I would love to see that, although I really loke these semi short videos.
@hermessantos1816 ай бұрын
awesome!@reapiu8316
@spacewad87456 ай бұрын
Ah you've read my mind! I just started messing around with sockets and was about to try my hand at developing a simple http server.
@sashakuznechkin6 ай бұрын
Thanks for video! Happy new year!
@Temon09426 ай бұрын
Hey bro your videos are amazing keep making them
@justcurious19408 күн бұрын
Great videos bro, Thanks.
@Humble_Electronic_Musician6 ай бұрын
This is good stuff! Awesome!
@davidgillies6206 ай бұрын
If you need to implement a production-grade HTTPS server in C++, Vinnie Falco's Beast library is the way to go.
@quezinmark82256 ай бұрын
Making short videos are good but giving overview about what you're going to do would make it better I mean explaining flow!
@pavfrang6 ай бұрын
WOW - that is original hack stuff. Love it. Carry on!
@ItsCOMMANDer_6 ай бұрын
My wish has been heared, thx
@tan42966 ай бұрын
I really like your thumbnails
@DrDulos4 ай бұрын
Thanks, good work
@rogo73306 ай бұрын
I believe it's better to use separate TLS reverse proxies that will do TLS stuff and then pass the connection to next program by just connecting to localhost port or unix socket. It makes programs much simplier and can become a problem only on high load servers, where you don't want too many calls to write and read from programs because it's more user-kernel context switching.
@nirlichtman6 ай бұрын
I agree about this point, for actual production it would be better to separate the HTTP server and the SSL server, or to just use nginx :)
@luadicrous5 ай бұрын
I found out that if you hold F5 in the browser for a while it can make it 'crash'. It's not a real crash however, it's the SIGPIPE signal that is being fired and it happens when a pipe gets broken. You can capture this event with the 'signal' function if you are on Unix based systems, but no idea what the equivalent on Windows is. Once you've captured this signal, you can just ignore it and the server keeps running.
@ttrss6 ай бұрын
aw your not writing a c implement of tls in 15 minutes
@samjiman6 ай бұрын
Nice videos. What is the window manager you are using on Windows?
@nirlichtman6 ай бұрын
I am using dwm-win32, more info about the setup in the welcome link in the channel description
@samjiman6 ай бұрын
@@nirlichtman Thanks, Nir.
@bob-0076 ай бұрын
great stuff thanks, any chance of something similar but in Python?
@nirlichtman6 ай бұрын
Good idea, noted :)
@erbenton075 ай бұрын
Hi, what editor are you using? I'd like to try it out.
@nirlichtman5 ай бұрын
I am using Vim, many of my older videos are about it if you want more info
@kimlehtinen6 ай бұрын
Interesting! Is this what NGINX does under the hood when configured as reverse proxy with SSL?
@nirlichtman6 ай бұрын
I haven't explored the NGINX source code yet, but I assume it works pretty similar, I am pretty sure it also uses OpenSSL :)
@soniablanche56725 ай бұрын
I don't think it's as simple as that. NGINX could be running TLS with http version 2 and it is redirecting the http request to a local web server that is not using TLS and is using http version 1.
@aralozkayaАй бұрын
Well, wouldn't it be better to send a corresponding HTTP error code (instead of 200 OK each time) when you return a "not found" error?
@ItsCOMMANDer_6 ай бұрын
Hey Nir, i used openssl commandline utility to generate key and cert. i changed "SSL_use_certificate_chain_file(ssl, "fullChain");" to "SSL_use_certificate_file(ssl, "key.pem", SSL_FILETYPE_PEM);" and ajusted file name.I compiled and ran it gave me an "The connection was reset The connection to the server was reset while the page was loading." error. can you help?
@nirlichtman6 ай бұрын
Is that the error you got from the web browser? Reason is probably because the certificate is self-signed, and the browser is rejecting the connection, if you want to try out the server you can use wget with the ignore cert option or try configurating the browser to accept the self-signed cert. If you want it to work out of the box you need to get a certificate signed by a certificate authority, on my setup in the video for example I used my certificate and private generated by let's encrypt which is a service that lets you easily get a certificate for your server
@ItsCOMMANDer_6 ай бұрын
@@nirlichtman, update, i added an printf debug statement to nearly every function call wich prints its return value, and i found out that `bind()` returns an error (-1) when it doesnt work and success if it works (to download) could the reason be that in the code (because its not "production ready") an "un-bind" is missing?
@Acorn_Anomaly6 ай бұрын
@@ItsCOMMANDer_ There's no need to "unbind". The binding of the socket is released when the server socket is closed. If bind() is returning -1, then as you said, something is going wrong. When you get a failure, you should add code to print out the value of the errno special variable, to see what the error is. (See the bind(2) man page for more info.)
@honeymak3 ай бұрын
i just wonder how you know the sequence of function calls beforehand
@nirlichtman3 ай бұрын
On most cases the man pages/docs are sufficient to help me do the preliminary research, but specifically in the case of OpenSSL, which has quite poor docs in my opinion, I had to also do online research
@dkkogmaw1311Ай бұрын
How can you link it static … im stuck at this point
@leonss23566 ай бұрын
noice
@MarcoLeong6 ай бұрын
What is that {0} terminator for?
@nirlichtman6 ай бұрын
That is standard C syntax to initialize all array members with 0, as long as you are not using an old/weird C compiler, it works nicely :) devdocs.io/c/language/array_initialization
@rian0xFFF6 ай бұрын
Do some basic OpenGL stuff or some UI
@nirlichtman6 ай бұрын
I am planning a future UI video about making a minimalist paint app for Windows. OpenGL is a good idea, noted :)
@rian0xFFF6 ай бұрын
@@nirlichtman 😊
@yargonslavter6 ай бұрын
Narration: Great Content: Great Code Editor: C'mon man, use Visual Code
@nirlichtman6 ай бұрын
My favorite editor is Vim, in some of my older videos I explain why :)
@rajveer_20092 ай бұрын
upgrade your vim
@rickdearman99926 ай бұрын
It annoys me you use void for main. That is very C++ not C. 😂