Okay, I’ve been digging through hundreds of articles trying to find an answer. I have been able to find answers somewhat close to what I am looking for, but nothing that is exactly what I am looking for.
What I am trying to do is this;
I want to set up a website (Site A) that has a Username and Password field, which the potential user will enter the Username and Password to another site (Site B) and it will take the data entered into the Username and Password Fields on Site A and enter those values into the Username and Password boxes on site B. Once this is accomplished Site A will remain ‘logged in’ to Site B, and log out when the session is terminated.
Originally I thought PERL would be the best way to go about doing this, then I discovered cURL with PHP. If possible, I would like to use cURL since both sites are almost entirely PHP as is.
I am not entirely sure how I would go about this, and any help would be greatly appreciated!
You can make it by php with form GET or POST
example:
your site a is: sitea.com, site b is: siteb.com.
login php at siteb is siteb.com/login.php
code at site A
Okay, I tried that, and all it did was take me to siteb.com and log me in there.
I want to log into siteb.com through sitea.com, and then go to my own custom page on sitea.com, while still being able to control siteb.com in the background.
Well thankfully I have a good reputation with siteb.com, so I don’t believe it will be an issue, and there are already a few 3rd party applications that log into the site outside of it, but I will, thank you
Yeah, if you look at my original post, I figured it would have to be cURL.
Is the cURL library already pre-installed with current distributions, or is it something I am going to have to download and install seperately?
With cURL, I don’t think it is possible. I think I can safely say that the majority of sites use PHP Sessions for logging in, etc. These sessions involve storing a cookie on the clients computer. I do believe that it would be possible to get and set the cookie via cURL, but there is no way to make it accessible to siteb, and it would therefore be useless.
What I would do is use some Javascript, as mentioned above, and when the use clicks the link “log me in” have it act as a form submission. This is very easy to do with jQuery, and not much more difficult with vanilla Js either.
One more note: when storing your user’s passwords in the database, you must encrypt them! Unfortunately, you couldn’t use a one-way salted hash because you need to be able to take the passwords back out. I would essentially use the same concepts as the uniquely salted password method, but use the two way AES-256 encryption rather than Blowfish or SHA.
Of course you can set a maintain a user session with cURL - on your own site though. You can’t make that session available to other domains without creating a fully proxy, which is both inefficient and against the terms of most web hosting places.