Solved

convert php encryption into java code

Posted on 2010-08-19
3
684 Views
Last Modified: 2016-03-18
A bit of background.

I have SugarCRM. My data for sugarcrm is in a progress database. Apatar can move the data. One problem though. sugarcrm requires a key. I've posted the code below. Apatar is open source, so I grabbed the regular sugarcrm template and created a sugarcrmldap template.

The encryption is where I run into a problem.  I've been trying to convert it into java. I know what encryption does, but the coding specifics between ASE/DSE/3DES, i need some help with. Basically, I'm trying to convert the $ldap_hash line into the the same equivalent java code. I can see it's using 3DES, but I've seen some very very different ways of implementing this. I has something going but I was running into an illegal key size. Couldn't figure that out so I'm retreating a bit and looking for help.
require_once('./path/to/nusoap.php');
 
 $soap_client = new soapclient('http://someurl.com/sugar/soap.php?wsdl');
 
 $user_name = 'matt';
 $user_password = 'mygoodsecret123';
 $app_name = 'myniceprogram';
 
 $key = 'abc123';  // LDAP Key as entered in Sugar
 $key = substr(md5($key),0,24);
 $iv = 'password';  // note that this is the word password, not the user's password or hash...
 $ldap_hash = bin2hex(mcrypt_cbc(MCRYPT_3DES, $key, $user_password, MCRYPT_ENCRYPT, $iv));
 $soap_client->call('login',array('user_auth'=>array('user_name'=>$user_name, 'password'=>$ldap_hash,'version'=>'.1'), 'application_name'=>$app_name));

Open in new window

0
Comment
Question by:kblackwel
3 Comments
 
LVL 19

Expert Comment

by:Michael701
ID: 33482336
I might be totally wrong on this, but I seem to recall that the md5 function is specific to php and as I learned different in mysql. So, I'm thinking it might also be different in java. try echoing the key after the md5 in both java and php and see if they're the same

 $key = substr(md5($key),0,24);
echo $key;
0
 
LVL 92

Accepted Solution

by:
objects earned 500 total points
ID: 33482353
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 33482843
>>I has something going but I was running into an illegal key size. Couldn't figure that out so I'm retreating a bit and looking for help.

Yes, afaicr 3DES uses a 128-bit key, so it'll need to be padded
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
Introduction This article is the last of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article covers our test design approach and then goes through a simple test case example, how …
Viewers will learn one way to get user input in Java. Introduce the Scanner object: Declare the variable that stores the user input: An example prompting the user for input: Methods you need to invoke in order to properly get  user input:
This tutorial will introduce the viewer to VisualVM for the Java platform application. This video explains an example program and covers the Overview, Monitor, and Heap Dump tabs.

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question