Using SSL with Webmin Fix SSL error

SSL Error On First Access of Webmin on New Install - (Error code: ssl_error_rx_record_too_long)

If you try to log into a new install and you receive this error:
An error occurred during a connection to xxx.xxx.xxx.xxx:10000.
SSL received a record that exceeded the maximum permissible length.
(Error code: ssl_error_rx_record_too_long)
It is because SSL is not configured for Webmin and it must be enabled.
Solution:

Because your Webmin login and password are normally passed between your browser and the server in unencrypted form, an attacker with access to any of the networks between the browser and server can easily capture your Webmin login. To prevent this, Webmin can be configured to use SSL to encrypt all of its network traffic.

If you have yum support on your linux distribution following will resolve SSL issue.
yum install openssl openssl-devel perl perl-Net-SSLeay perl-Crypt-SSLeay

Else follow below method.

Running Webmin in SSL mode

To install SSL, follow these steps :
Download the OpenSSL library
OpenSSL is a C library that provides the underlying SSL functions used by Webmin and many other programs. It is available in RPM format and as a .tar.gz file. When installing from the RPM, you may also need the development RPM in order to compile Net::SSLeay. 
Most Linux and BSD distributions now come with OpenSSL RPMs that are installed as standard or available on the CD. If your distribution has openssl and possibily openssl-devel packages, use them instead.
Install the OpenSSL library
If you are installing from the RPM, run the commands :
  rpm -i openssl-0.x.y.rpm
  rpm -i openssl-devel-0.x.y.rpm
If installing from the source, you will need to compile and install it with the commands :
  tar xvzf openssl-0.x.y.tar.gz
  cd openssl-0.x.y
  ./Configure     (or ./config in new OpenSSL versions)
  make
  make install
Download the Net::SSLeay Perl module
Net::SSLeay is a module that allows Perl scripts to call the functions in the OpenSSL library. It is available in .tar.gz format from the Webmin site or from the CPAN Perl module archive
Alternately, you can use the Perl Modules module in Webmin to download an install Net::SSLeay from CPAN. If this works OK, the next step can be skipped. 
Some Linux distributions come with an RPM package containing this Perl module, often named perl-Net-SSLeay. If one is available, install it instead of compiling the module manually. You may also be able to find a suitable package at rpmfind.net if your distribution doesn't include one. However, be aware that any Perl module in RPM format must have been built for the same version of Perl that you are running, or it won't work.
Install the Net::SSLeay module
To install the module, use the commands :
  tar xvzf Net_SSLeay.pm-x.yy.tar.gz
  cd Net_SSLeay.pm-x.yy
  perl Makefile.PL
  make install
If you have installed OpenSSL from the RPM, you may need to run perl Makefile.PL /usr in order to find the OpenSSL library properly.
Test the SSL install
If the command perl -e 'use Net::SSLeay' doesn't output any error message, then the SSL support that Webmin needs is properly installed.
If Webmin is not installed yet, install it
If you install SSL support first, when Webmin's setup.sh script is run it will ask you if you want to enable SSL. Just enter y. The RPM version of Webmin will always automaticlly use SSL mode if possible.
If Webmin is already installed, turn on SSL
In the Webmin Configuration module (under the Webmin category) an icon for SSL Encryption should appear. Click on it, and change the SSL option from Disabled to Enabled.
Warning - if you enable SSL support in Webmin, your browser must also support SSL (such as Netscape and IE). If not, you will not be able to access the Webmin server. If there is a firewall or proxy between the machine you are running your browser on and the Webmin server, check that it allows SSL requests to pass through as well.

Using STunnel to protect Webmin

Because many people have trouble installing OpenSSL and the Net::SSLeay module needed to run Webmin in SSL mode natively, I have created documentation explaining an alterative method. The STunnel program can convert SSL-encrypt any network services, such as POP3 or IMAP - or even Webmin. However, only Webmin versions 1.090 and above will work fully. To set it up, follow these steps :
Install STunnel
The program is installed as standard with many Linux distributions, or can be downloaded from www.stunnel.org and compiled for your system.
Create a new tunnel
Use Webmin's SSL Tunnels module to create a new tunnel on port 10001 called ssl-webmin that uses the Connect to remote host mode to connects to localhost port 10000 (assuming you are running Webmin on port 10000).
The SSL certificate and key file option should be set to Use Webmin's cert, and all of the other options left as their defaults.
Activate the tunnel
Hit the Apply Changes button in the SSL Tunnels module to activate your new tunnel.
Configure Webmin so that it knows about the SSL tunnel
Added the line inetd_ssl=1 to /etc/webmin/miniserv.conf and run /etc/webmin/stop ; /etc/webmin/start.
Login to Webmin in SSL mode
You should now be able to connect to https://yourhostname:10001/ and login as normal. The old URL on port 10000 will no longer work properly.


Related Reading: How to Disable SSL for Webmin

Comments

Mac pro said…
Nice article admin thanks for share your atricle keep share your knowledge i am waiting for your new post check long sleeve shirts girls polo shirts kindly review and reply me

Popular posts from this blog

Linux File and Directory Permissions

How to Disable SSL for Webmin

INSTALL CISCO VPN CLIENT ON WINDOWS 10 (32 & 64 BIT). FIX REASON 442