Go Back   vb.org Archive > vBulletin 3 Discussion > vB3 Programming Discussions
Register FAQ Community Calendar Today's Posts Search

Reply
 
Thread Tools Search this Thread Display Modes
  #1  
Old 11-11-2004, 01:24 PM
Fargo's Avatar
Fargo Fargo is offline
 
Join Date: Jan 2004
Location: North Dakota
Posts: 62
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default Multiple $_REQUEST vars=SQL Error?

Why does the followin code produce a SQL error if there is more than one request variable defined in the url?

PHP Code:
if (empty($_REQUEST['siteid']))
{
$getgames $DB_site->query("SELECT * FROM site_game_info");
}
else
{
$tempval $_REQUEST['siteid'];
$getgames $DB_site->query("SELECT * FROM site_game_info WHERE siteid=$tempval");
}
while(
$game $DB_site->fetch_array($getgames))
{
//call bbcodeparse.php to parse bbcode within overview and requirements fields
require_once('./includes/functions_bbcodeparse.php');
$game['overview'] = parse_bbcode2($game['overview'], 1111);
$game['rec_sys_req'] = parse_bbcode2($game['rec_sys_req'], 1111);
$game['min_sys_req'] = parse_bbcode2($game['min_sys_req'], 1111);
eval(
'$games .= "' fetch_template('gamedetail') . '";');

as you can see, one of the request variables is siteid, however, most of the time there will be more than one variable defined. For example, a link to some specific content may look like this:

index.php?siteid=3?do=overview

The code above functions properly when ONLY siteid is being sent, but once do=overview has been added, I get a SQL error because $tempval is being filled not only with the value of siteid, but "?do=overview" as well.

What im trying to do is have the page first look at the siteid so it knows which set of records to pull from the table (currently, I have it coded where an empty $_REQUEST['siteid'] returns all records), then finally look at DO so it knows what action to perform/template to eval.

Can someone please point me in the right direction?
Reply With Quote
  #2  
Old 11-11-2004, 02:00 PM
Colin F's Avatar
Colin F Colin F is offline
 
Join Date: Jul 2004
Location: Switzerland
Posts: 1,551
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

if you have more than one var in the URL, it has to be formatted like this:

index.php?var1=foo&var2=somethingelse&var3=what

that would result in

$_REQUEST['var1'] == 'foo';
$_REQUEST['var2'] == 'somethingelse';
$_REQUEST['var3'] == 'what';

Also, for security reasons, make sure to either use the vBulletin function globalise() or to addslashes() anything that gets used in a query. If the value is a number, you can also do intval().
Reply With Quote
  #3  
Old 11-11-2004, 02:19 PM
Fargo's Avatar
Fargo Fargo is offline
 
Join Date: Jan 2004
Location: North Dakota
Posts: 62
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Thank you VERY much Colin! I see exactly where I've been screwing up now

Could you please elaborate how/where I would include the globalise(), addslashes() or inval() functions?

If im thinking correctly, since my siteid will always be an int, I change my code from
$tempval = $_REQUEST['siteid'];

to

$tempval = intval($_REQUEST['siteid']);

Correct?

I would like to ask one more thing since im thinking about it...
How can I stop the results from being sent to the template if the requested siteid is either non-numeric, or an unknown value?

For example, if the user decided to try and send

index.php?siteid=1000000000000 or
index.php?siteid=thisisnotnumeric

since the database dont (and never will) have a site id of 1000000000000 and thisisnotnumeric is a text value, currently, both follow through correctly, but no data is sent to the template because the siteid dont exist.

I would prefer that the user is sent an error message instead of a blank template.

Thanks again for your time on the initial question at hand!
Reply With Quote
  #4  
Old 11-11-2004, 02:39 PM
Revan's Avatar
Revan Revan is offline
 
Join Date: Jan 2004
Location: Norway
Posts: 1,671
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I am writing this off the top of my head, so dont expect it to work. But it should give you a starting point:
PHP Code:
// usage of globalize():
if ($_REQUEST['siteid'])
{
    
globalize($_REQUEST, array(
        
'siteid' => INT // if you want site id to be integer only, else remove the "=> INT"
    
));
    
$getgames $DB_site->query("SELECT * FROM site_game_info WHERE siteid='$siteid'");
    
// we can use "$siteid" here because globalize makes it a global variable.
    
    
if(!$getgames// it is false (i.e SQL returns no rows)
    
{
        
standard_error('There are no sites with the ID you have entered, pelase try another ID.');
        die; 
//to avoid having it execute the rest of the script
    
}
    else
    {
        while(
$game $DB_site->fetch_array($getgames))
        {
            
//call bbcodeparse.php to parse bbcode within overview and requirements fields
            
require_once('./includes/functions_bbcodeparse.php');
            
$game['overview'] = parse_bbcode2($game['overview'], 1111);
            
$game['rec_sys_req'] = parse_bbcode2($game['rec_sys_req'], 1111);
            
$game['min_sys_req'] = parse_bbcode2($game['min_sys_req'], 1111);
            eval(
'$games .= "' fetch_template('gamedetail') . '";');
        }
    }

Hope this helps


//peace
Reply With Quote
  #5  
Old 11-11-2004, 02:48 PM
Fargo's Avatar
Fargo Fargo is offline
 
Join Date: Jan 2004
Location: North Dakota
Posts: 62
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Greatly appreciated, Revan! Will let ya know the results...as soon as I get caught up here at work..sigh.
Reply With Quote
  #6  
Old 11-11-2004, 05:52 PM
Fargo's Avatar
Fargo Fargo is offline
 
Join Date: Jan 2004
Location: North Dakota
Posts: 62
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

ok, finally got around to testing your code Revan.

The results: If I enter a numeric siteid that exists, everything still works as expected. If I enter a numeric siteid that dont exist, it still spits out an empty template. If I enter a textual siteid, it still returns a SQL error:

Database error in vBulletin 3.0.3:

Invalid SQL: SELECT * FROM site_game_info WHERE siteid=ghj
mysql error: Unknown column 'ghj' in 'where clause'

mysql error number: 1054

Date: Thursday 11th of November 2004 01:41:39 PM
Script: xxxxxx.com/forums/gameinfo.php?siteid=ghj
Referer:
Username: Fargo
IP Address: 192.168.1.1

If you or anyone else has any suggestions, feel free to offer them. In the meantime, Ill keep attempting to figure it out as well. Theres gotta be an existing vbulletin page that does relatively the same thing......

[edit]ok, forumdisplay.php does about the same thing - returns an error if the forum id dont exist...time to do some research on that file...[/edit]
Reply With Quote
  #7  
Old 11-11-2004, 07:04 PM
Fargo's Avatar
Fargo Fargo is offline
 
Join Date: Jan 2004
Location: North Dakota
Posts: 62
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

well, looks like vb uses verify_id() to check thread/forum id's and the sort. Having a look at functions.php, im finding that ive already gotten way over my head in something I know very little about...but I think I can figure it out - eventually :ermm:
Reply With Quote
  #8  
Old 11-11-2004, 08:54 PM
Natch's Avatar
Natch Natch is offline
 
Join Date: Nov 2002
Location: Australia
Posts: 851
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Once the siteid has been globailzed, you should then test it prior to running the SQL query...

eg:
PHP Code:
... globalize statement ...
if(!
is_int($siteid))
{
... 
trip your error checking facility ...
}
else
{
... 
the rest of your statement ...

Reply With Quote
  #9  
Old 11-13-2004, 12:54 AM
Fargo's Avatar
Fargo Fargo is offline
 
Join Date: Jan 2004
Location: North Dakota
Posts: 62
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Thanks for the input, Natch. While I fully understand what your suggesting I do, could you fill in the blanks and let me know how I would verify that error checking works? Im pretty new at all this stuff, so im a bit ignorant yet
Reply With Quote
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 10:56 AM.


Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.05612 seconds
  • Memory Usage 4,739KB
  • Queries Executed 11 (?)
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
  • (3)bbcode_php
  • (1)footer
  • (1)forumjump
  • (1)forumrules
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (1)navbar
  • (3)navbar_link
  • (120)option
  • (9)post_thanks_box
  • (9)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (9)post_thanks_postbit_info
  • (9)postbit
  • (9)postbit_onlinestatus
  • (9)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_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
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • tag_fetchbit_complete
  • forumrules
  • navbits
  • navbits_complete
  • showthread_complete