Skip to main content

How to access remote server using PHP SSH?

To remotely access a server in PHP provides a full library of functions called SSH2 functions. You can get the manual from the link. You'll get most of the information from the manual itself but it also leaves the user with some questions which are unanswered. Here i am just trying to explain the same in some better way..

Simple Example : 

<?php
    if (!function_exists("ssh2_connect"))
        die("function ssh2_connect doesn't exist");
    if(!($con = ssh2_connect("www.example.com", 22(port number)))){
        echo "fail: unable to establish connection\n";
    } else {
        if(!ssh2_auth_password($con, "username", "password")) {
            echo "fail: unable to authenticate\n";
        } else {
            echo "okay: root logged in...\n";
            $stream = shell_exec("mkdir /var/www/shiv");
        }
    }

?>

Important Notes :

1) If you are logged in as a normal user(not root user) then you can't change user and login to the root or super user using these function. You can use su as a command but can't enter password as a command because server only allow the user to enter password through standard input device. For example if you are trying like this:

$stream = shell_exec("su; superuser password");

then it won't work.

2) If you want to run multiple commands then you have to use single shell_exec() function for that. For example :

$stream = shell_exec("mkdir /var/www/shiv; mkdir /var/www/modi");

It would create two sub-directories named 'shiv' and 'modi' in /var/www/ directory.


while


$stream = shell_exec("mkdir /var/www/shiv");
$stream = shell_exec("mkdir /var/www/modi");

commands won't work, because command n shell environment will not be remembered during the execution of command n+1.If you want the shell commands to be working while depending on each other in terms of environment, you should put several commands in a unique ssh2_exec().


Now you can run any number of commands on remote server. You can also use ssh php function to download, upload files etc....

Comments

Popular posts from this blog

Odoo/OpenERP: one2one relational field example

one2one relational field is deprecated in OpenERP version>5 but you can achieve the same using many2one relational field. You can achieve it in following two ways : 1) using many2one field in both the objects ( http://tutorialopenerp.wordpress.com/2014/04/23/one2one/ ) 2)  using inheritance by deligation You can easily find the first solution with little search over internet so let's start with 2nd solution. Scenario :  I want to create a one2one relation between two objects of openerp hr.employee and hr.employee.medical.details What I should do  i. Add _inherits section in hr_employee class ii. Add field medical_detail_id in hr_employee class class hr_employee(osv.osv):     _name = 'hr.employee'     _inherits = {' hr.employee.medical.details ': "medical_detail_id"}     _inherit = 'hr.employee'         _columns = {              'emp_code':fields.char('Employee Code', si

How to draw Dynamic Line or Timeseries Chart in Java using jfreechart library?

Today we are going to write a code to draw a dynamic timeseries-cum-line chart in java.   The only difference between simple and dynamic chart is that a dynamic event is used to create a new series and update the graph. In out example we are using timer which automatically calls a funtion after every 1/4 th second and graph is updated with random data. Let's try with the code : Note : I had tried my best to provide complete documentation along with code. If at any time anyone have any doubt or question please post in comments section. DynamicLineAndTimeSeriesChart.java import java.awt.BorderLayout; import java.awt.Color; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.Timer; import javax.swing.JPanel; import org.jfree.chart.ChartFactory; import org.jfree.chart.ChartPanel; import org.jfree.chart.JFreeChart; import org.jfree.chart.axis.ValueAxis; import org.jfree.chart.plot.XYPlot; import

pyodbc.OperationalError: ('08001', '[08001] [Microsoft][ODBC Driver 17 for SQL Server]

Recently, I faced this error in our Docker-Container environment. All the necessary packages were already installed but still, I was facing this clueless error. I search a bit and after an hour and so I found the exact reason and solution for this error. To know more about this error in detail. Please follow this Github thread. https://github.com/mkleehammer/pyodbc/issues/610 https://github.com/mkleehammer/pyodbc/issues/610#issuecomment-587523802 Solution: It's because the   server's certificate has too weak a key. In case you are using Linux env directly/not the Docker one.  Just edited /etc/ssl/openssl.cnf and change these 2 lines. MinProtocol = TLSv1.0 CipherString = DEFAULT@SECLEVEL=1 In case you are also using a container, please add these three lines to your Docker file. RUN chmod +rwx /etc/ssl/openssl.cnf RUN sed -i ' s/TLSv1.2/TLSv1/g ' /etc/ssl/openssl.cnf RUN sed -i ' s/SECLEVEL=2/SECLEVEL=1/g ' /etc/ssl/openssl.cnf Thanks!! Enjoy Programming! Refer