Problemas no IE com alteração do componente de login
Enviado: 30 Jul 2010, 08:44
Gente.. preciso de ajudaAAAA...
fiz algumas alterações no componete de login nativo do joomla, e também no modulo do login deste componente.
As alterações são para que o usuário não precise digitar o login e a senha, elas são passadas no código do controller.php.
Minhas modificações funcionam no Mozilla e no Chrome, mas não funionam no IE!!!! Alguém tem ideia do pq está acontecendo isso???
Segue a alteração que fiz no meu componente de login!
No arquivo controller.php do com_user, na função de login fiz isso...
function login()
{
// Check for request forgeries
JRequest::checkToken('request') or jexit( 'Invalid Token' );
//______________Inicio da modificação_____________________
$headers = apache_request_headers();
if (!isset($headers['Authorization'])){
header('HTTP/1.1 401 Unauthorized');
header('WWW-Authenticate: NTLM');
echo " 1";
exit;
}
$auth = $headers['Authorization'];
echo " 2";
if (substr($auth,0,5) == 'NTLM ') {
$msg = base64_decode(substr($auth, 5));
echo " 3";
if (substr($msg, 0, 8) != "NTLMSSP\x00"){
LogError('Header not recognised');
echo " 4";
die;
}
if ($msg[8] == "\x01") {
$msg2 = "NTLMSSP\x00\x02"."\x00\x00\x00\x00".
"\x00\x00\x00\x00".
"\x01\x02\x81\x01".
"\x00\x00\x00\x00\x00\x00\x00\x00".
"\x00\x00\x00\x00\x00\x00\x00\x00".
"\x00\x00\x00\x00\x30\x00\x00\x00";
echo " 5";
header('HTTP/1.1 401 Unauthorized');
header('WWW-Authenticate: NTLM '.trim(base64_encode($msg2)));
echo " 6";
exit;
}
else if ($msg[8] == "\x03") {
echo " 7";
function get_msg_str($msg, $start, $unicode = true) {
$len = (ord($msg[$start+1]) * 256) + ord($msg[$start]);
$off = (ord($msg[$start+5]) * 256) + ord($msg[$start+4]);
echo " 8";
if ($unicode)
return str_replace("\0", '', substr($msg, $off, $len));
else
return substr($msg, $off, $len);
}
echo " 9";
$user = get_msg_str($msg, 36);//retorna o login do usuário no computador
//$domain = get_msg_str($msg, 28);
//$workstation = get_msg_str($msg, 44);
}
}
//_______________Fim da parte modificada_____________________
global $mainframe;
if ($return = JRequest::getVar('return', '', 'method', 'base64')) {
$return = base64_decode($return);
if (!JURI::isInternal($return)) {
$return = '';
}
}
$options = array();
$options['remember'] = JRequest::getBool('remember', false);
$options['return'] = $return;
$credentials = array();
//AQUI TBM DEVE SER MODIFICADO DESTA FORMA
$credentials['username'] = $user;
$credentials['password'] = "123456";
//preform the login action
$error = $mainframe->login($credentials, $options);
if(!JError::isError($error))
{
// Redirect if the return url is not registration or login
if ( ! $return ) {
$return = 'index.php?option=com_user';
}
$mainframe->redirect( $return );
}
else
{
// Facilitate third party login forms
if ( ! $return ) {
$return = 'index.php?option=com_user&view=login';
}
// Redirect to a login form
$mainframe->redirect( $return );
}
}
Se alguém puder testar esse código e vê se vai funcionar no IE, fico grata!!!
P.S.: Para testar, deve existir um usuário cadastrado no joomla com um nome de usuário igual ao nome de usuário no computador e senha 123456.
O código aqui funciona no Chrome e no Mozilla, menos no IE!!! =/
Alguém me ajuda??? Alguém sabe se tem alguma coisa no código que é incompatível com o IE8???
fiz algumas alterações no componete de login nativo do joomla, e também no modulo do login deste componente.
As alterações são para que o usuário não precise digitar o login e a senha, elas são passadas no código do controller.php.
Minhas modificações funcionam no Mozilla e no Chrome, mas não funionam no IE!!!! Alguém tem ideia do pq está acontecendo isso???
Segue a alteração que fiz no meu componente de login!
No arquivo controller.php do com_user, na função de login fiz isso...
function login()
{
// Check for request forgeries
JRequest::checkToken('request') or jexit( 'Invalid Token' );
//______________Inicio da modificação_____________________
$headers = apache_request_headers();
if (!isset($headers['Authorization'])){
header('HTTP/1.1 401 Unauthorized');
header('WWW-Authenticate: NTLM');
echo " 1";
exit;
}
$auth = $headers['Authorization'];
echo " 2";
if (substr($auth,0,5) == 'NTLM ') {
$msg = base64_decode(substr($auth, 5));
echo " 3";
if (substr($msg, 0, 8) != "NTLMSSP\x00"){
LogError('Header not recognised');
echo " 4";
die;
}
if ($msg[8] == "\x01") {
$msg2 = "NTLMSSP\x00\x02"."\x00\x00\x00\x00".
"\x00\x00\x00\x00".
"\x01\x02\x81\x01".
"\x00\x00\x00\x00\x00\x00\x00\x00".
"\x00\x00\x00\x00\x00\x00\x00\x00".
"\x00\x00\x00\x00\x30\x00\x00\x00";
echo " 5";
header('HTTP/1.1 401 Unauthorized');
header('WWW-Authenticate: NTLM '.trim(base64_encode($msg2)));
echo " 6";
exit;
}
else if ($msg[8] == "\x03") {
echo " 7";
function get_msg_str($msg, $start, $unicode = true) {
$len = (ord($msg[$start+1]) * 256) + ord($msg[$start]);
$off = (ord($msg[$start+5]) * 256) + ord($msg[$start+4]);
echo " 8";
if ($unicode)
return str_replace("\0", '', substr($msg, $off, $len));
else
return substr($msg, $off, $len);
}
echo " 9";
$user = get_msg_str($msg, 36);//retorna o login do usuário no computador
//$domain = get_msg_str($msg, 28);
//$workstation = get_msg_str($msg, 44);
}
}
//_______________Fim da parte modificada_____________________
global $mainframe;
if ($return = JRequest::getVar('return', '', 'method', 'base64')) {
$return = base64_decode($return);
if (!JURI::isInternal($return)) {
$return = '';
}
}
$options = array();
$options['remember'] = JRequest::getBool('remember', false);
$options['return'] = $return;
$credentials = array();
//AQUI TBM DEVE SER MODIFICADO DESTA FORMA
$credentials['username'] = $user;
$credentials['password'] = "123456";
//preform the login action
$error = $mainframe->login($credentials, $options);
if(!JError::isError($error))
{
// Redirect if the return url is not registration or login
if ( ! $return ) {
$return = 'index.php?option=com_user';
}
$mainframe->redirect( $return );
}
else
{
// Facilitate third party login forms
if ( ! $return ) {
$return = 'index.php?option=com_user&view=login';
}
// Redirect to a login form
$mainframe->redirect( $return );
}
}
Se alguém puder testar esse código e vê se vai funcionar no IE, fico grata!!!
P.S.: Para testar, deve existir um usuário cadastrado no joomla com um nome de usuário igual ao nome de usuário no computador e senha 123456.
O código aqui funciona no Chrome e no Mozilla, menos no IE!!! =/
Alguém me ajuda??? Alguém sabe se tem alguma coisa no código que é incompatível com o IE8???