Go Back   vb.org Archive > vBulletin 4 Discussion > vB4 General Discussions
FAQ Community Calendar Today's Posts Search

Reply
 
Thread Tools Display Modes
  #1  
Old 09-16-2014, 12:13 PM
Disco_Dave's Avatar
Disco_Dave Disco_Dave is offline
 
Join Date: May 2011
Location: Belfast
Posts: 586
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default Anyone help with this '

Hi Guys

Receiving database errors, when some registers with ' in the email address. Would anyone know how to fix this?

PHP Code:
Database error in vBulletin 4.2.2:

Invalid SQL:
SELECT FROM vbuserregcode WHERE userregemail 'wendy_o'reilly@inwebmail.com';

MySQL Error   : You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '
reilly@inwebmail.com'' at line 1
Error Number  
1064
Request Date  
MondaySeptember 15th 2014 04:56:37 PM
Error Date    
MondaySeptember 15th 2014 04:56:38 PM
Script        
http://nirc.co.uk/joiningthenirc.php
Referrer      http://nirc.co.uk/joiningthenirc.php
IP Address    69.12.84.199
Username      
Unregistered
Classname     
vB_Database_MySQLi
MySQL Version 

Dave
Reply With Quote
  #2  
Old 09-16-2014, 12:19 PM
Dave Dave is offline
 
Join Date: May 2010
Posts: 2,583
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Which plugin are you using which alters the registration process? I think we have a SQL injection vulnerability here.
Reply With Quote
  #3  
Old 09-16-2014, 12:22 PM
Disco_Dave's Avatar
Disco_Dave Disco_Dave is offline
 
Join Date: May 2011
Location: Belfast
Posts: 586
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

It's that one, that makes you register your email before you can sign up. Give me a sec and I'll find it.



this one? https://vborg.vbsupport.ru/showthread.php?t=294164
Reply With Quote
  #4  
Old 09-16-2014, 12:41 PM
Dave Dave is offline
 
Join Date: May 2010
Posts: 2,583
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Go to your plugins in the admincp and look for the register_start hook of that plugin.

Find:
Code:
$emailalreadyused = $db->query_read("SELECT * FROM " . TABLE_PREFIX . "userregcode WHERE userregemail = '$email'");
Replace with:
Code:
$emailalreadyused = $db->query_read("SELECT * FROM " . TABLE_PREFIX . "userregcode WHERE userregemail = '" . $db->escape_string($email) . "'");
Reply With Quote
Благодарность от:
Disco_Dave
  #5  
Old 09-16-2014, 12:43 PM
Disco_Dave's Avatar
Disco_Dave Disco_Dave is offline
 
Join Date: May 2011
Location: Belfast
Posts: 586
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I'll give that a go now mate cheers
Reply With Quote
  #6  
Old 09-16-2014, 12:52 PM
fxdigi-cash fxdigi-cash is offline
 
Join Date: Jul 2012
Posts: 674
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

possibly you have an old version of this mod!! because I can't find the table vbuserregcode

I think you need to uninstall the mod and install the latest version of it.

I found similar issue someone else had here:

http://www.vbulletin.com/forum/forum...database-error
Reply With Quote
  #7  
Old 09-16-2014, 12:58 PM
Dave Dave is offline
 
Join Date: May 2010
Posts: 2,583
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by fxdigi-cash View Post
possibly you have an old version of this mod!! because I can't find the table vbuserregcode

I think you need to uninstall the mod and install the latest version of it.

I found similar issue someone else had here:

http://www.vbulletin.com/forum/forum...database-error
I'm pretty sure vb is his table_prefix.
Reply With Quote
  #8  
Old 09-16-2014, 12:58 PM
Disco_Dave's Avatar
Disco_Dave Disco_Dave is offline
 
Join Date: May 2011
Location: Belfast
Posts: 586
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

May be I'm reading it wrong....But is that line not already the same as you provided?

PHP Code:
$navbits construct_navbits(array('' => 'Verify Email')); 
$navbar render_navbar_template($navbits); 
            
$vbulletin->input->clean_array_gpc('r', array( 
        
'email' => TYPE_STR
        
'emailconfirm' => TYPE_STR
        
'emailconfirmationcode' => TYPE_STR
        
'codehasbeenset' => TYPE_BOOL
        
'so' => TYPE_BOOL
        
'emailcode' => TYPE_STR
        
'ihaveit' => TYPE_BOOL
        
'reorder' => TYPE_BOOL
    
'month' => TYPE_UINT
    
'year'  => TYPE_UINT
    
'day'   => TYPE_UINT
        
COOKIE_PREFIX 'notcoppa' =>  TYPE_STR 

    
)); 

if(
$vbulletin->options['usecoppa']) 

$current['year'] = date('Y'); 
$current['month'] = date('m'); 
$current['day'] = date('d'); 



if(!isset(
$_COOKIE[COOKIE_PREFIX 'notcoppa']) AND $vbulletin->GPC['month'] != AND $vbulletin->GPC['day'] != AND $vbulletin->GPC['year'] != AND (mktime(000$vbulletin->GPC['month'], $vbulletin->GPC['day'], $vbulletin->GPC['year']) <= mktime(000$current['month'], $current['day'], $current['year'] - 13))) 

vbsetcookie('notcoppa'$vbulletin->GPC['month'] . '-' $vbulletin->GPC['day'] . '-' $vbulletin->GPC['year'], 1); 


$coppaage = ($_COOKIE[COOKIE_PREFIX 'coppaage']) ? $_COOKIE[COOKIE_PREFIX 'coppaage'] : $_COOKIE[COOKIE_PREFIX 'notcoppa'] ; 

if(
$coppaage

$dob explode('-'$coppaage); 
$month = ( $dob[0] != 0) ? $dob[0] : -1
$day = ( $dob[1] != ) ? $dob[1] : -1
$year = ( $dob[2] != ) ? $dob[2] : -1


$so = (isset($vbulletin->GPC['so'])) ? $vbulletin->GPC['so'] : 
$email strtolower($vbulletin->GPC['email']); 
$emailcode$vbulletin->GPC['emailcode'] ; 
$emailconfirm$vbulletin->GPC['emailconfirm'] ; 
$emailconfirmationcode $vbulletin->GPC['emailconfirmationcode']; 
$codehasbeenset $vbulletin->GPC['codehasbeenset']; 
$reorder $vbulletin->GPC['reorder']; 
$ihaveit $vbulletin->GPC['ihaveit']; 

$show['reorder'] = false
$show['emailerrors'] = false

if(isset(
$email) AND $email != "" AND !empty($email)) 


    if(!
simpleping($email)) 
    { 
        
$show['emailerrors'] = true
        
$errorlist .= "<li>".$vbphrase['pingerror']."</li>"
    } 

    
$emailalreadyused $db->query_read("SELECT * FROM " TABLE_PREFIX "userregcode WHERE userregemail = '$email'"); 

    if (
$db->num_rows($emailalreadyused) ) 
    { 
        
$show['emailerrors'] = true
        
$show['reorder'] = true
        
$errorlist .= "<li>".$vbphrase['emailalreadyusednotconfirmed']."</li>"
        
$userfetched $db->fetch_row($emailalreadyused); 
        if(
$userfetched[3] >= $vbulletin->options['email_verfication']) 
        { 
             eval(
standard_error(fetch_error('thiswasusedmorethanenough'))); 
        } 
    } 

    
$emailalreadyregisterd $db->query_read("SELECT * FROM " TABLE_PREFIX "user WHERE email = '$email'"); 

    if (
$db->num_rows($emailalreadyregisterd)) 
    { 
        
$show['emailerrors'] = true
        
$errorlist .= "<li>".$vbphrase['emailalreadyregisterd']."</li>"
    } 


if( 
$so != AND ( ($show['emailerrors'] AND $codehasbeenset != 0) OR ( !isset($email) OR $email == "" OR empty($email) ) ) AND !$reorder AND !$ihaveit )

    
$codehasbeenset 0;  
    
$templater vB_Template::create('reg_ver_start'); 
    
$templater->register('header'$header); 
    
$templater->register('navbar'$navbar);  
    
$templater->register('email'$email);  
    
$templater->register('emailconfirm'$emailconfirm);  
    
$templater->register('headinclude'$headinclude);  
    
$templater->register('footer'$footer);  
    
$templater->register('errorlist'$errorlist); 
    
$templater->register('reorder'$reorder); 
    
$templater->register('ihaveit'$ihaveit); 
    
$templater->register('codehasbeenset '$codehasbeenset ); 
    
$templater->register('jqueryurl'$jqueryurl); 
    
$reg_ver_start $templater->render();   
    
vB_Template::preRegister('register', array('reg_ver_start' => $reg_ver_start)); 
    
$vbulletin->templatecache['register'] = '$reg_ver_start'
Reply With Quote
  #9  
Old 09-16-2014, 01:00 PM
Disco_Dave's Avatar
Disco_Dave Disco_Dave is offline
 
Join Date: May 2011
Location: Belfast
Posts: 586
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by fxdigi-cash View Post
possibly you have an old version of this mod!! because I can't find the table vbuserregcode

I think you need to uninstall the mod and install the latest version of it.

I found similar issue someone else had here:

http://www.vbulletin.com/forum/forum...database-error

Yes I posted this on here some time ago also, I did remove the mod when vb.org pulled it because of my thread. I will try what you have suggested..
Reply With Quote
  #10  
Old 09-16-2014, 01:01 PM
Dave Dave is offline
 
Join Date: May 2010
Posts: 2,583
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I downloaded the latest version, but it's not safe:
It has a check to see if it's a string, then there's a strtolower function around it. Then the variable is being used in the query without being sanitized.

You should change the following:

HTML Code:
$email = strtolower($vbulletin->GPC['email']);
to

HTML Code:
$email = $db->escape_string(strtolower($vbulletin->GPC['email']));
Reply With Quote
Благодарность от:
tbworld
Reply


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT. The time now is 02:02 AM.


Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2024, vBulletin Solutions Inc.
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.04967 seconds
  • Memory Usage 2,336KB
  • Queries Executed 13 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)ad_showthread_beforeqr
  • (1)ad_showthread_firstpost
  • (1)ad_showthread_firstpost_sig
  • (1)ad_showthread_firstpost_start
  • (2)bbcode_code
  • (2)bbcode_html
  • (2)bbcode_php
  • (2)bbcode_quote
  • (1)footer
  • (1)forumjump
  • (1)forumrules
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (1)navbar
  • (3)navbar_link
  • (120)option
  • (1)pagenav
  • (1)pagenav_curpage
  • (1)pagenav_pagelink
  • (10)post_thanks_box
  • (2)post_thanks_box_bit
  • (10)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (2)post_thanks_postbit
  • (10)post_thanks_postbit_info
  • (10)postbit
  • (10)postbit_onlinestatus
  • (10)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open
  • (1)tagbit_wrapper 

Phrase Groups Available:
  • global
  • inlinemod
  • postbit
  • posting
  • reputationlevel
  • showthread
Included Files:
  • ./showthread.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showthread_start
  • showthread_getinfo
  • forumjump
  • showthread_post_start
  • showthread_query_postids
  • showthread_query
  • bbcode_fetch_tags
  • bbcode_create
  • showthread_postbit_create
  • postbit_factory
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • fetch_musername
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • post_thanks_function_fetch_thanks_bit_start
  • post_thanks_function_show_thanks_date_start
  • post_thanks_function_show_thanks_date_end
  • post_thanks_function_fetch_thanks_bit_end
  • post_thanks_function_fetch_post_thanks_template_start
  • post_thanks_function_fetch_post_thanks_template_end
  • pagenav_page
  • pagenav_complete
  • tag_fetchbit_complete
  • forumrules
  • navbits
  • navbits_complete
  • showthread_complete