Making Minimalist HTTPS Server in C on Linux

แชร์
ฝัง
  • เผยแพร่เมื่อ 5 ก.ย. 2024
  • 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/nir...

ความคิดเห็น • 62

  • @nirlichtman
    @nirlichtman  8 หลายเดือนก่อน +9

    - 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

    • @enesalbay9707
      @enesalbay9707 3 หลายเดือนก่อน

      Add setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &(int){1}, sizeof(int)) before bind to overcome this problem.

  • @space9824
    @space9824 8 หลายเดือนก่อน +28

    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.

  • @Dysl3xicDog
    @Dysl3xicDog 8 หลายเดือนก่อน +9

    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.

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน +2

      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.

  • @iamspeed1405
    @iamspeed1405 8 หลายเดือนก่อน +12

    Geez I opened the video and BOOM! it was straight into the action no silly 1 minute long intro. Love it ❤!

  • @bromophenol2469
    @bromophenol2469 8 หลายเดือนก่อน +5

    Nir, your distinct no nonsense style is very refreshing

  • @Maagiicc
    @Maagiicc 8 หลายเดือนก่อน +18

    Thanks for the longer video and more complicated program. Do you have any plans on doing anything non-minimalist?

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน +11

      Yes, I am planning on perhaps fully implementing one of the unix commands :)

    • @StefanWelebny
      @StefanWelebny 8 หลายเดือนก่อน +2

      Could you show how to handle concurrent requests and concurrent listeners?

    • @AlTiri-rd7ly
      @AlTiri-rd7ly 8 หลายเดือนก่อน

      ​​@reapiu8316yeah I would love to see that, although I really loke these semi short videos.

    • @hermessantos181
      @hermessantos181 8 หลายเดือนก่อน

      awesome!@reapiu8316

  • @spacewad8745
    @spacewad8745 8 หลายเดือนก่อน +1

    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.

  • @ItsCOMMANDer_
    @ItsCOMMANDer_ 8 หลายเดือนก่อน +2

    My wish has been heared, thx

  • @KimTiger777
    @KimTiger777 8 หลายเดือนก่อน

    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!

  • @davidgillies620
    @davidgillies620 8 หลายเดือนก่อน +1

    If you need to implement a production-grade HTTPS server in C++, Vinnie Falco's Beast library is the way to go.

  • @justcurious1940
    @justcurious1940 2 หลายเดือนก่อน

    Great videos bro, Thanks.

  • @quezinmark8225
    @quezinmark8225 8 หลายเดือนก่อน

    Making short videos are good but giving overview about what you're going to do would make it better I mean explaining flow!

  • @rogo7330
    @rogo7330 8 หลายเดือนก่อน +1

    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.

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน +2

      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 :)

  • @hulio3994
    @hulio3994 2 หลายเดือนก่อน

    I love your workflow, I'd really love to program using man pages and simple text editors but I always feel stuck when programming without a proper IDE. How did you practice C programming when you started?

    • @nirlichtman
      @nirlichtman  2 หลายเดือนก่อน +1

      Thanks! I started with IDEs (mostly Visual Studio) and then gradually moved over to Vim, first by using a Vim plugin on the IDE and then after feeling comfortable enough, I moved to Vim vanilla.

  • @luadicrous
    @luadicrous 8 หลายเดือนก่อน

    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.

  • @Temon0942
    @Temon0942 8 หลายเดือนก่อน

    Hey bro your videos are amazing keep making them

  • @Humble_Electronic_Musician
    @Humble_Electronic_Musician 8 หลายเดือนก่อน +1

    This is good stuff!
    Awesome!

  • @sashakuznechkin
    @sashakuznechkin 8 หลายเดือนก่อน

    Thanks for video! Happy new year!

  • @tan4296
    @tan4296 8 หลายเดือนก่อน

    I really like your thumbnails

  • @pavfrang
    @pavfrang 8 หลายเดือนก่อน

    WOW - that is original hack stuff. Love it. Carry on!

  • @mrlistenerr
    @mrlistenerr 4 หลายเดือนก่อน

    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?

  • @ttrss
    @ttrss 8 หลายเดือนก่อน +8

    aw your not writing a c implement of tls in 15 minutes

  • @DrDulos
    @DrDulos 6 หลายเดือนก่อน

    Thanks, good work

  • @samjiman
    @samjiman 8 หลายเดือนก่อน +1

    Nice videos. What is the window manager you are using on Windows?

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน +1

      I am using dwm-win32, more info about the setup in the welcome link in the channel description

    • @samjiman
      @samjiman 8 หลายเดือนก่อน

      @@nirlichtman Thanks, Nir.

  • @honeymak
    @honeymak 5 หลายเดือนก่อน

    i just wonder how you know the sequence of function calls beforehand

    • @nirlichtman
      @nirlichtman  5 หลายเดือนก่อน +1

      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

  • @bob-007
    @bob-007 8 หลายเดือนก่อน +1

    great stuff thanks, any chance of something similar but in Python?

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน

      Good idea, noted :)

  • @kimlehtinen
    @kimlehtinen 8 หลายเดือนก่อน

    Interesting! Is this what NGINX does under the hood when configured as reverse proxy with SSL?

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน

      I haven't explored the NGINX source code yet, but I assume it works pretty similar, I am pretty sure it also uses OpenSSL :)

    • @soniablanche5672
      @soniablanche5672 8 หลายเดือนก่อน

      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.

  • @dkkogmaw1311
    @dkkogmaw1311 3 หลายเดือนก่อน

    How can you link it static … im stuck at this point

  • @erbenton07
    @erbenton07 8 หลายเดือนก่อน

    Hi, what editor are you using? I'd like to try it out.

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน

      I am using Vim, many of my older videos are about it if you want more info

  • @yargonslavter
    @yargonslavter 8 หลายเดือนก่อน +1

    Narration: Great
    Content: Great
    Code Editor: C'mon man, use Visual Code

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน

      My favorite editor is Vim, in some of my older videos I explain why :)

  • @ItsCOMMANDer_
    @ItsCOMMANDer_ 8 หลายเดือนก่อน

    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?

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน

      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_
      @ItsCOMMANDer_ 8 หลายเดือนก่อน

      ​@@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_Anomaly
      @Acorn_Anomaly 8 หลายเดือนก่อน

      @@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.)

  • @MarcoLeong
    @MarcoLeong 8 หลายเดือนก่อน

    What is that {0} terminator for?

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน +1

      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

  • @rian0xFFF
    @rian0xFFF 8 หลายเดือนก่อน

    Do some basic OpenGL stuff or some UI

    • @nirlichtman
      @nirlichtman  8 หลายเดือนก่อน +1

      I am planning a future UI video about making a minimalist paint app for Windows. OpenGL is a good idea, noted :)

    • @rian0xFFF
      @rian0xFFF 8 หลายเดือนก่อน

      @@nirlichtman 😊

  • @leonss2356
    @leonss2356 8 หลายเดือนก่อน

    noice

  • @rajveer_2009
    @rajveer_2009 5 หลายเดือนก่อน

    upgrade your vim

  • @rickdearman9992
    @rickdearman9992 8 หลายเดือนก่อน

    It annoys me you use void for main. That is very C++ not C. 😂

    • @benhetland576
      @benhetland576 8 หลายเดือนก่อน +1

      It is not very C++ either.