For Programmers: Free Programming Magazines  


Home > Archive > PHP on Windows > May 2004 > RE: [PHP-WIN] Passing +, =, - at post and get









You are viewing an archived Text-only version of the thread. To view this thread in it's original format and/or if you want to reply to this thread please [click here]

 

Author RE: [PHP-WIN] Passing +, =, - at post and get
Charles P. Killmer

2004-05-20, 10:35 am

I hope you are not allowing the client to send T-SQL through the query
string. Consider them sending something like=20
File.php?Query=3D'; drop table XXX; --

Charles Killmer

-----Original Message-----
From: George Pitcher [mailto:george.pitcher@ingenta.com]=20
Sent: Thursday, May 20, 2004 8:25 AM
To: php-windows@lists.php.net
Subject: [PHP-WIN] Passing +, =3D, - at post and get

Hi,

I want to be able to pass the '=3D', '+' and '-' characters both from a
web form and as part of a url, to enable a better way of searching.
However, these characters are choking my IIS webserver and not getting
through to the script.

Can anyone suggest a better way of achieving this?

Cheers

George

--
PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
http://www.php.net/unsub.php
George Pitcher

2004-05-20, 10:35 am

Charles,

No way! This site will only have about 3-4 users as its an intranet and I'll
be parsing everything at the server end.

George


> -----Original Message-----
> From: Charles P. Killmer [mailto:charlesk@netgaintechnology.com]
> Sent: 20 May 2004 2:31 pm
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =, - at post and get
>
>
> I hope you are not allowing the client to send T-SQL through the query
> string. Consider them sending something like
> File.php?Query='; drop table XXX; --
>
> Charles Killmer
>
> -----Original Message-----
> From: George Pitcher [mailto:george.pitcher@ingenta.com]
> Sent: Thursday, May 20, 2004 8:25 AM
> To: php-windows@lists.php.net
> Subject: [PHP-WIN] Passing +, =, - at post and get
>
> Hi,
>
> I want to be able to pass the '=', '+' and '-' characters both from a
> web form and as part of a url, to enable a better way of searching.
> However, these characters are choking my IIS webserver and not getting
> through to the script.
>
> Can anyone suggest a better way of achieving this?
>
> Cheers
>
> George
>
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
> http://www.php.net/unsub.php
>
> --
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>

George Pitcher

2004-05-20, 10:35 am

And doing a bit more, I find that '=' and '-' are passing through OK so I'll
need to train my users to use an alternative to '+'.

The choking seems to be with my parsing function, which I have pasted in
below:
========================================
=========
function sql_fltr($sql,$field,$input){
if(strlen($input)>0){
if( substr_count($input,"=")>0 | substr_count($input," -")>0 |
substr_count($input," +")>0 ){
$output = "";
$temp = str_replace(" -","|-",(str_replace(" -","|-",($input))));
$temp = explode("|",$temp);
for ($i = 0; $i <= sizeof($temp); $i++){
if (substr($temp[$i],0,1)=="*"){
$temp[$i] = $field." like
'".rtrim(str_replace("*","%",$temp[$i]))."%'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=="-"){
$temp[$i] = " and ".$field." not like
'".rtrim(str_replace("*","%",$temp[$i]))."'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=="="){
$temp[$i] = " and
".$field."='".rtrim(str_replace("=","",$temp[$i]))."'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)!="+" &&
substr($temp[$i],0,1)!="-"&&substr($temp[$i],0,1)!="*" &&
substr($temp[$i],0,1)!="="){
$temp[$i] = "and ".$field." like
'%".rtrim(str_replace("=","",$temp[$i]))."'";
$output.= $temp[$i]."|";
} else {
$temp[$i] = " ".$field."='".rtrim($temp[$i])."'";
$output.= $temp[$i]."|";
}
}
$output = " AND ".substr($output,0,strlen($output)-1);
} else {
$temp = $input;
if (substr($temp,0,1)=="*"){
$temp = $field." like '".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=="-"){
$temp = $field." not like '".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=="="){
$temp = $field."='".rtrim(str_replace("=","",$temp))."'";
} elseif (substr($temp,0,1)!="+" &&
substr($temp,0,1)!="-"&&substr($temp,0,1)!="*" && substr($temp,0,1)!="="){
$temp = $field." like '%".rtrim(str_replace("=","",$temp))."'";
} else {
$temp = $field."='".rtrim($temp)."'";
}
$output = " AND ".$temp;
}
} else {
$output = "";
}
return $output;
}
========================================
=========
This works fine if the user has eneterd either no control or the * wildcared
with the criteria.

Any suggestions?

Cheers

George


> -----Original Message-----
> From: George Pitcher [mailto:george.pitcher@ingenta.com]
> Sent: 20 May 2004 2:33 pm
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =, - at post and get
>
>
> Charles,
>
> No way! This site will only have about 3-4 users as its an
> intranet and I'll
> be parsing everything at the server end.
>
> George
>
>
>
> --
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>

B.A.T. Svensson

2004-05-20, 11:33 am

In such case GRANT is a nice command to prevent
droping tables in the first place.


-----Original Message-----
From: Charles P. Killmer
To: php-windows@lists.php.net
Sent: 20-5-2004 15:31
Subject: RE: [PHP-WIN] Passing +, =, - at post and get

I hope you are not allowing the client to send T-SQL through the query
string. Consider them sending something like
File.php?Query='; drop table XXX; --

Charles Killmer

-----Original Message-----
From: George Pitcher [mailto:george.pitcher@ingenta.com]
Sent: Thursday, May 20, 2004 8:25 AM
To: php-windows@lists.php.net
Subject: [PHP-WIN] Passing +, =, - at post and get

Hi,

I want to be able to pass the '=', '+' and '-' characters both from a
web form and as part of a url, to enable a better way of searching.
However, these characters are choking my IIS webserver and not getting
through to the script.

Can anyone suggest a better way of achieving this?

Cheers

George

--
PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
http://www.php.net/unsub.php

--
PHP Windows Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Trevor Gryffyn

2004-05-20, 11:33 am

Sorry, don't have time to go through your code or to look up the regex
way of doing this, but you can translate then decode the plus sign
fairly easily. One really basic example:

$plussign =3D "+";
echo "Plus: $plussign\n";
$plussign =3D "&#" . ord($plussign) .";";
echo "HTML Entity Plus: $plussign\n";
$plussign =3D chr(substr($plussign,2,strlen($plussign)
-3));
echo "HTML Entity Converted Back: $plussign\n";


The plus sign should pass through a POST ok, but in a GET the plus sign
is used to represent spaces in a URL sometimes. Ampersands, equal
signs, forward (and probably back) slashes, colons and question marks
are also used in URLs (might have forgot some). Since GET puts all the
data through a URL, you need to be aware of the reserved characters used
in URLs. You shouldn't have this problem through a POST transaction
though. I'm not aware of anything that won't pass through POST, but I'm
sure there's something.

There's almost always a way to transfer text into something that'll pass
through POST or GET without screwing things up. Easier to change the
code than change the users.

-TG

> -----Original Message-----
> From: George Pitcher [mailto:george.pitcher@ingenta.com]=20
> Sent: Thursday, May 20, 2004 9:43 AM
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
>=20
> And doing a bit more, I find that '=3D' and '-' are passing=20
> through OK so I'll
> need to train my users to use an alternative to '+'.

B.A.T. Svensson

2004-05-20, 11:33 am

In your second if you do a count on the occurence of a character,
but don't use the result, why not use strpos() directly?

Also if you just want to replace a single char with another
single char, then you might like to do like this:

$String = implode(explode($String, $OldChar), $NewChar);



-----Original Message-----
From: George Pitcher
To: php-windows@lists.php.net
Sent: 20-5-2004 15:43
Subject: RE: [PHP-WIN] Passing +, =, - at post and get

And doing a bit more, I find that '=' and '-' are passing through OK so
I'll
need to train my users to use an alternative to '+'.

The choking seems to be with my parsing function, which I have pasted in
below:
========================================
=========
function sql_fltr($sql,$field,$input){
if(strlen($input)>0){
if( substr_count($input,"=")>0 | substr_count($input,"
-")>0 |
substr_count($input," +")>0 ){
$output = "";
$temp = str_replace(" -","|-",(str_replace("
-","|-",($input))));
$temp = explode("|",$temp);
for ($i = 0; $i <= sizeof($temp); $i++){
if (substr($temp[$i],0,1)=="*"){
$temp[$i] = $field." like
'".rtrim(str_replace("*","%",$temp[$i]))."%'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=="-"){
$temp[$i] = " and ".$field." not
like
'".rtrim(str_replace("*","%",$temp[$i]))."'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=="="){
$temp[$i] = " and
".$field."='".rtrim(str_replace("=","",$temp[$i]))."'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)!="+" &&
substr($temp[$i],0,1)!="-"&&substr($temp[$i],0,1)!="*" &&
substr($temp[$i],0,1)!="="){
$temp[$i] = "and ".$field." like
'%".rtrim(str_replace("=","",$temp[$i]))."'";
$output.= $temp[$i]."|";
} else {
$temp[$i] = "
".$field."='".rtrim($temp[$i])."'";
$output.= $temp[$i]."|";
}
}
$output = " AND
".substr($output,0,strlen($output)-1);
} else {
$temp = $input;
if (substr($temp,0,1)=="*"){
$temp = $field." like
'".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=="-"){
$temp = $field." not like
'".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=="="){
$temp =
$field."='".rtrim(str_replace("=","",$temp))."'";
} elseif (substr($temp,0,1)!="+" &&
substr($temp,0,1)!="-"&&substr($temp,0,1)!="*" &&
substr($temp,0,1)!="="){
$temp = $field." like
'%".rtrim(str_replace("=","",$temp))."'";
} else {
$temp = $field."='".rtrim($temp)."'";
}
$output = " AND ".$temp;
}
} else {
$output = "";
}
return $output;
}
========================================
=========
This works fine if the user has eneterd either no control or the *
wildcared
with the criteria.

Any suggestions?

Cheers

George


> -----Original Message-----
> From: George Pitcher [mailto:george.pitcher@ingenta.com]
> Sent: 20 May 2004 2:33 pm
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =, - at post and get
>
>
> Charles,
>
> No way! This site will only have about 3-4 users as its an
> intranet and I'll
> be parsing everything at the server end.
>
> George
>
>
query[color=darkred]
a[color=darkred]
getting[color=darkred]
visit:[color=darkred]
>
> --
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>


--
PHP Windows Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Trevor Gryffyn

2004-05-20, 11:33 am

That's gotta be one of the more creative ways around using a regular
expression I've ever seen.. Hah.. Good job Svennson. A regex or string
replace would probably work better, or at least be more direct though.

-TG

> -----Original Message-----
> From: Svensson, B.A.T. (HKG) [mailto:B.A.T.Svensson@lumc.nl]=20
> Sent: Thursday, May 20, 2004 10:48 AM
> To: 'php-windows@lists.php.net '
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
>=20
> In your second if you do a count on the occurence of a character,
> but don't use the result, why not use strpos() directly?=20
>=20
> Also if you just want to replace a single char with another
> single char, then you might like to do like this:
>=20
> $String =3D implode(explode($String, $OldChar), $NewChar);
>=20
>=20
>=20
> -----Original Message-----
> From: George Pitcher
> To: php-windows@lists.php.net
> Sent: 20-5-2004 15:43
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
> And doing a bit more, I find that '=3D' and '-' are passing=20
> through OK so
> I'll
> need to train my users to use an alternative to '+'.
>=20
> The choking seems to be with my parsing function, which I=20
> have pasted in
> below:
> =

=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> function sql_fltr($sql,$field,$input){
> if(strlen($input)>0){
> if( substr_count($input,"=3D")>0 | substr_count($input,"
> -")>0 |
> substr_count($input," +")>0 ){
> $output =3D "";
> $temp =3D str_replace(" -","|-",(str_replace("
> -","|-",($input))));
> $temp =3D explode("|",$temp);
> for ($i =3D 0; $i <=3D sizeof($temp); $i++){
> if (substr($temp[$i],0,1)=3D=3D"*"){
> $temp[$i] =3D $field." like
> '".rtrim(str_replace("*","%",$temp[$i]))."%'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=3D=3D"-"){
> $temp[$i] =3D " and ".$field." not
> like
> '".rtrim(str_replace("*","%",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=3D=3D"=3D"){
> $temp[$i] =3D " and
> ".$field."=3D'".rtrim(str_replace("=3D","",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)!=3D"+" &&
> substr($temp[$i],0,1)!=3D"-"&&substr($temp[$i],0,1)!=3D"*" &&
> substr($temp[$i],0,1)!=3D"=3D"){
> $temp[$i] =3D "and ".$field." like
> '%".rtrim(str_replace("=3D","",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } else {
> $temp[$i] =3D "
> ".$field."=3D'".rtrim($temp[$i])."'";
> $output.=3D $temp[$i]."|";
> }
> }
> $output =3D " AND
> ".substr($output,0,strlen($output)-1);
> } else {
> $temp =3D $input;
> if (substr($temp,0,1)=3D=3D"*"){
> $temp =3D $field." like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=3D=3D"-"){
> $temp =3D $field." not like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=3D=3D"=3D"){
> $temp =3D
> $field."=3D'".rtrim(str_replace("=3D","",$temp))."'";
> } elseif (substr($temp,0,1)!=3D"+" &&
> substr($temp,0,1)!=3D"-"&&substr($temp,0,1)!=3D"*" &&
> substr($temp,0,1)!=3D"=3D"){
> $temp =3D $field." like
> '%".rtrim(str_replace("=3D","",$temp))."'";
> } else {
> $temp =3D $field."=3D'".rtrim($temp)."'";
> }
> $output =3D " AND ".$temp;
> }
> } else {
> $output =3D "";
> }
> return $output;
> }
> =

=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> This works fine if the user has eneterd either no control or the *
> wildcared
> with the criteria.
>=20
> Any suggestions?
>=20
> Cheers
>=20
> George
>=20
>=20
> query
> both from
> a
> searching.
> getting
> visit:
>=20
> --=20
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>=20
> --=20
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>=20
>=20

George Pitcher

2004-05-20, 11:33 am

Anders,

Thanks for the tips. I've resolved the post/get problem.

Cheers

George

> -----Original Message-----
> From: Svensson, B.A.T. (HKG) [mailto:B.A.T.Svensson@lumc.nl]
> Sent: 20 May 2004 3:48 pm
> To: 'php-windows@lists.php.net '
> Subject: RE: [PHP-WIN] Passing +, =, - at post and get
>
>
> In your second if you do a count on the occurence of a character,
> but don't use the result, why not use strpos() directly?
>
> Also if you just want to replace a single char with another
> single char, then you might like to do like this:
>
> $String = implode(explode($String, $OldChar), $NewChar);
>
>
>
> -----Original Message-----
> From: George Pitcher
> To: php-windows@lists.php.net
> Sent: 20-5-2004 15:43
> Subject: RE: [PHP-WIN] Passing +, =, - at post and get
>
> And doing a bit more, I find that '=' and '-' are passing through OK so
> I'll
> need to train my users to use an alternative to '+'.
>
> The choking seems to be with my parsing function, which I have pasted in
> below:
> ========================================
=========
> function sql_fltr($sql,$field,$input){
> if(strlen($input)>0){
> if( substr_count($input,"=")>0 | substr_count($input,"
> -")>0 |
> substr_count($input," +")>0 ){
> $output = "";
> $temp = str_replace(" -","|-",(str_replace("
> -","|-",($input))));
> $temp = explode("|",$temp);
> for ($i = 0; $i <= sizeof($temp); $i++){
> if (substr($temp[$i],0,1)=="*"){
> $temp[$i] = $field." like
> '".rtrim(str_replace("*","%",$temp[$i]))."%'";
> $output.= $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=="-"){
> $temp[$i] = " and ".$field." not
> like
> '".rtrim(str_replace("*","%",$temp[$i]))."'";
> $output.= $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=="="){
> $temp[$i] = " and
> ".$field."='".rtrim(str_replace("=","",$temp[$i]))."'";
> $output.= $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)!="+" &&
> substr($temp[$i],0,1)!="-"&&substr($temp[$i],0,1)!="*" &&
> substr($temp[$i],0,1)!="="){
> $temp[$i] = "and ".$field." like
> '%".rtrim(str_replace("=","",$temp[$i]))."'";
> $output.= $temp[$i]."|";
> } else {
> $temp[$i] = "
> ".$field."='".rtrim($temp[$i])."'";
> $output.= $temp[$i]."|";
> }
> }
> $output = " AND
> ".substr($output,0,strlen($output)-1);
> } else {
> $temp = $input;
> if (substr($temp,0,1)=="*"){
> $temp = $field." like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=="-"){
> $temp = $field." not like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=="="){
> $temp =
> $field."='".rtrim(str_replace("=","",$temp))."'";
> } elseif (substr($temp,0,1)!="+" &&
> substr($temp,0,1)!="-"&&substr($temp,0,1)!="*" &&
> substr($temp,0,1)!="="){
> $temp = $field." like
> '%".rtrim(str_replace("=","",$temp))."'";
> } else {
> $temp = $field."='".rtrim($temp)."'";
> }
> $output = " AND ".$temp;
> }
> } else {
> $output = "";
> }
> return $output;
> }
> ========================================
=========
> This works fine if the user has eneterd either no control or the *
> wildcared
> with the criteria.
>
> Any suggestions?
>
> Cheers
>
> George
>
>
> query
> a
> getting
> visit:
>
> --
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
> --
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>

Charles P. Killmer

2004-05-20, 12:31 pm

How is this=20
$String =3D implode(explode($String, $OldChar), $NewChar);
different than =20
$String =3D str_replace($OldChar, $NewChar, $String);

Charles Killmer

-----Original Message-----
From: Svensson, B.A.T. (HKG) [mailto:B.A.T.Svensson@lumc.nl]=20
Sent: Thursday, May 20, 2004 9:48 AM
To: 'php-windows@lists.php.net '
Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get

In your second if you do a count on the occurence of a character, but
don't use the result, why not use strpos() directly?=20

Also if you just want to replace a single char with another single char,
then you might like to do like this:

$String =3D implode(explode($String, $OldChar), $NewChar);



-----Original Message-----
From: George Pitcher
To: php-windows@lists.php.net
Sent: 20-5-2004 15:43
Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get

And doing a bit more, I find that '=3D' and '-' are passing through OK =
so
I'll need to train my users to use an alternative to '+'.

The choking seems to be with my parsing function, which I have pasted in
below:
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
function sql_fltr($sql,$field,$input){
if(strlen($input)>0){
if( substr_count($input,"=3D")>0 | substr_count($input,"
-")>0 |
substr_count($input," +")>0 ){
$output =3D "";
$temp =3D str_replace(" -","|-",(str_replace("
-","|-",($input))));
$temp =3D explode("|",$temp);
for ($i =3D 0; $i <=3D sizeof($temp); $i++){
if (substr($temp[$i],0,1)=3D=3D"*"){
$temp[$i] =3D $field." like
'".rtrim(str_replace("*","%",$temp[$i]))."%'";
$output.=3D $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=3D=3D"-"){
$temp[$i] =3D " and ".$field." not
like
'".rtrim(str_replace("*","%",$temp[$i]))."'";
$output.=3D $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=3D=3D"=3D"){
$temp[$i] =3D " and
".$field."=3D'".rtrim(str_replace("=3D","",$temp[$i]))."'";
$output.=3D $temp[$i]."|";
} elseif (substr($temp[$i],0,1)!=3D"+" &&
substr($temp[$i],0,1)!=3D"-"&&substr($temp[$i],0,1)!=3D"*" &&
substr($temp[$i],0,1)!=3D"=3D"){
$temp[$i] =3D "and ".$field." like
'%".rtrim(str_replace("=3D","",$temp[$i]))."'";
$output.=3D $temp[$i]."|";
} else {
$temp[$i] =3D "
".$field."=3D'".rtrim($temp[$i])."'";
$output.=3D $temp[$i]."|";
}
}
$output =3D " AND
".substr($output,0,strlen($output)-1);
} else {
$temp =3D $input;
if (substr($temp,0,1)=3D=3D"*"){
$temp =3D $field." like
'".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=3D=3D"-"){
$temp =3D $field." not like
'".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=3D=3D"=3D"){
$temp =3D
$field."=3D'".rtrim(str_replace("=3D","",$temp))."'";
} elseif (substr($temp,0,1)!=3D"+" &&
substr($temp,0,1)!=3D"-"&&substr($temp,0,1)!=3D"*" &&
substr($temp,0,1)!=3D"=3D"){
$temp =3D $field." like
'%".rtrim(str_replace("=3D","",$temp))."'";
} else {
$temp =3D $field."=3D'".rtrim($temp)."'";
}
$output =3D " AND ".$temp;
}
} else {
$output =3D "";
}
return $output;
}
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
This works fine if the user has eneterd either no control or the *
wildcared with the criteria.

Any suggestions?

Cheers

George


> -----Original Message-----
> From: George Pitcher [mailto:george.pitcher@ingenta.com]
> Sent: 20 May 2004 2:33 pm
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>
>
> Charles,
>
> No way! This site will only have about 3-4 users as its an intranet=20
> and I'll be parsing everything at the server end.
>
> George
>
>
query[color=darkred]
drop
[color=darkred]
from
a[color=darkred]
getting[color=darkred]
visit:[color=darkred]
>
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:=20
> http://www.php.net/unsub.php
>
>


--
PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
http://www.php.net/unsub.php

--
PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
http://www.php.net/unsub.php
Trevor Gryffyn

2004-05-20, 12:31 pm

Rube Goldberg would appreciate it.

> -----Original Message-----
> From: Charles P. Killmer [mailto:charlesk@netgaintechnology.com]=20
> Sent: Thursday, May 20, 2004 11:01 AM
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
>=20
> How is this=20
> $String =3D implode(explode($String, $OldChar), $NewChar);
> different than =20
> $String =3D str_replace($OldChar, $NewChar, $String);
>=20
> Charles Killmer
>=20
> -----Original Message-----
> From: Svensson, B.A.T. (HKG) [mailto:B.A.T.Svensson@lumc.nl]=20
> Sent: Thursday, May 20, 2004 9:48 AM
> To: 'php-windows@lists.php.net '
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
> In your second if you do a count on the occurence of a character, but
> don't use the result, why not use strpos() directly?=20
>=20
> Also if you just want to replace a single char with another=20
> single char,
> then you might like to do like this:
>=20
> $String =3D implode(explode($String, $OldChar), $NewChar);
>=20
>=20
>=20
> -----Original Message-----
> From: George Pitcher
> To: php-windows@lists.php.net
> Sent: 20-5-2004 15:43
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
> And doing a bit more, I find that '=3D' and '-' are passing=20
> through OK so
> I'll need to train my users to use an alternative to '+'.
>=20
> The choking seems to be with my parsing function, which I=20
> have pasted in
> below:
> =

=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> function sql_fltr($sql,$field,$input){
> if(strlen($input)>0){
> if( substr_count($input,"=3D")>0 | substr_count($input,"
> -")>0 |
> substr_count($input," +")>0 ){
> $output =3D "";
> $temp =3D str_replace(" -","|-",(str_replace("
> -","|-",($input))));
> $temp =3D explode("|",$temp);
> for ($i =3D 0; $i <=3D sizeof($temp); $i++){
> if (substr($temp[$i],0,1)=3D=3D"*"){
> $temp[$i] =3D $field." like
> '".rtrim(str_replace("*","%",$temp[$i]))."%'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=3D=3D"-"){
> $temp[$i] =3D " and ".$field." not
> like
> '".rtrim(str_replace("*","%",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=3D=3D"=3D"){
> $temp[$i] =3D " and
> ".$field."=3D'".rtrim(str_replace("=3D","",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)!=3D"+" &&
> substr($temp[$i],0,1)!=3D"-"&&substr($temp[$i],0,1)!=3D"*" &&
> substr($temp[$i],0,1)!=3D"=3D"){
> $temp[$i] =3D "and ".$field." like
> '%".rtrim(str_replace("=3D","",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } else {
> $temp[$i] =3D "
> ".$field."=3D'".rtrim($temp[$i])."'";
> $output.=3D $temp[$i]."|";
> }
> }
> $output =3D " AND
> ".substr($output,0,strlen($output)-1);
> } else {
> $temp =3D $input;
> if (substr($temp,0,1)=3D=3D"*"){
> $temp =3D $field." like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=3D=3D"-"){
> $temp =3D $field." not like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=3D=3D"=3D"){
> $temp =3D
> $field."=3D'".rtrim(str_replace("=3D","",$temp))."'";
> } elseif (substr($temp,0,1)!=3D"+" &&
> substr($temp,0,1)!=3D"-"&&substr($temp,0,1)!=3D"*" &&
> substr($temp,0,1)!=3D"=3D"){
> $temp =3D $field." like
> '%".rtrim(str_replace("=3D","",$temp))."'";
> } else {
> $temp =3D $field."=3D'".rtrim($temp)."'";
> }
> $output =3D " AND ".$temp;
> }
> } else {
> $output =3D "";
> }
> return $output;
> }
> =

=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> This works fine if the user has eneterd either no control or the *
> wildcared with the criteria.
>=20
> Any suggestions?
>=20
> Cheers
>=20
> George
>=20
>=20
> query
> File.php?Query=3D'; drop
>=20
> both from
> a
> searching.
> getting
> visit:
> unsubscribe, visit:=20
>=20
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
> http://www.php.net/unsub.php
>=20
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
> http://www.php.net/unsub.php
>=20
> --=20
> PHP Windows Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>=20
>=20

Charles P. Killmer

2004-05-20, 12:31 pm

You may appreciate this then. Its been floating around for a while so
you may have seen it but I think it is funny and strangely true.

The Evolution of a Programmer



High School/Jr.High

10 PRINT "HELLO WORLD"
20 END


First year in College
program Hello(input, output)
begin
writeln('Hello World')
end.


Senior year in College
(defun hello
(print
(cons 'Hello (list 'World))))


New professional
#include <stdio.h>
void main(void)
{
char *message[] =3D {"Hello ", "World"};
int i;

for(i =3D 0; i < 2; ++i)
printf("%s", message[i]);
printf("\n");
}


Seasoned professional
#include <iostream.h>
#include <string.h>

class string
{
private:
int size;
char *ptr;

public:
string() : size(0), ptr(new char('\0')) {}

string(const string &s) : size(s.size)
{
ptr =3D new char[size + 1];
strcpy(ptr, s.ptr);
}

~string()
{
delete [] ptr;
}

friend ostream &operator <<(ostream &, const string &);
string &operator=3D(const char *);
};

ostream &operator<<(ostream &stream, const string &s)
{
return(stream << s.ptr);
}

string &string::operator=3D(const char *chrs)
{
if (this !=3D &chrs)
{
delete [] ptr;
size =3D strlen(chrs);
ptr =3D new char[size + 1];
strcpy(ptr, chrs);
}
return(*this);
}

int main()
{
string str;

str =3D "Hello World";
cout << str << endl;

return(0);
}


Master Programmer
[
uuid(2573F8F4-CFEE-101A-9A9F-00AA00342820)
]
library LHello
{
// bring in the master library
importlib("actimp.tlb");
importlib("actexp.tlb");

// bring in my interfaces
#include "pshlo.idl"

[
uuid(2573F8F5-CFEE-101A-9A9F-00AA00342820)
]
cotype THello
{
interface IHello;
interface IPersistFile;
};
};

[
exe,
uuid(2573F890-CFEE-101A-9A9F-00AA00342820)
]
module CHelloLib
{

// some code related header files
importheader(<windows.h> );
importheader(<ole2.h> );
importheader(<except.hxx> );
importheader("pshlo.h");
importheader("shlo.hxx");
importheader("mycls.hxx");

// needed typelibs
importlib("actimp.tlb");
importlib("actexp.tlb");
importlib("thlo.tlb");

[
uuid(2573F891-CFEE-101A-9A9F-00AA00342820),
aggregatable
]
coclass CHello
{
cotype THello;
};
};


#include "ipfix.hxx"

extern HANDLE hEvent;

class CHello : public CHelloBase
{
public:
IPFIX(CLSID_CHello);

CHello(IUnknown *pUnk);
~CHello();

HRESULT __stdcall PrintSz(LPWSTR pwszString);

private:
static int cObjRef;
};


#include <windows.h>
#include <ole2.h>
#include <stdio.h>
#include <stdlib.h>
#include "thlo.h"
#include "pshlo.h"
#include "shlo.hxx"
#include "mycls.hxx"

int CHello::cObjRef =3D 0;

CHello::CHello(IUnknown *pUnk) : CHelloBase(pUnk)
{
cObjRef++;
return;
}

HRESULT __stdcall CHello::PrintSz(LPWSTR pwszString)
{
printf("%ws\n", pwszString);
return(ResultFromScode(S_OK));
}


CHello::~CHello(void)
{

// when the object count goes to zero, stop the server
cObjRef--;
if( cObjRef =3D=3D 0 )
PulseEvent(hEvent);

return;
}

#include <windows.h>
#include <ole2.h>
#include "pshlo.h"
#include "shlo.hxx"
#include "mycls.hxx"

HANDLE hEvent;

int _cdecl main(
int argc,
char * argv[]
) {
ULONG ulRef;
DWORD dwRegistration;
CHelloCF *pCF =3D new CHelloCF();

hEvent =3D CreateEvent(NULL, FALSE, FALSE, NULL);

// Initialize the OLE libraries
CoInitializeEx(NULL, COINIT_MULTITHREADED);

CoRegisterClassObject(CLSID_CHello, pCF, CLSCTX_LOCAL_SERVER,
REGCLS_MULTIPLEUSE, &dwRegistration);

// wait on an event to stop
WaitForSingleObject(hEvent, INFINITE);

// revoke and release the class object
CoRevokeClassObject(dwRegistration);
ulRef =3D pCF->Release();

// Tell OLE we are going away.
CoUninitialize();

return(0); }

extern CLSID CLSID_CHello;
extern UUID LIBID_CHelloLib;

CLSID CLSID_CHello =3D { /* 2573F891-CFEE-101A-9A9F-00AA00342820 */
0x2573F891,
0xCFEE,
0x101A,
{ 0x9A, 0x9F, 0x00, 0xAA, 0x00, 0x34, 0x28, 0x20 }
};

UUID LIBID_CHelloLib =3D { /* 2573F890-CFEE-101A-9A9F-00AA00342820 */
0x2573F890,
0xCFEE,
0x101A,
{ 0x9A, 0x9F, 0x00, 0xAA, 0x00, 0x34, 0x28, 0x20 }
};

#include <windows.h>
#include <ole2.h>
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "pshlo.h"
#include "shlo.hxx"
#include "clsid.h"

int _cdecl main(
int argc,
char * argv[]
) {
HRESULT hRslt;
IHello *pHello;
ULONG ulCnt;
IMoniker * pmk;
WCHAR wcsT[_MAX_PATH];
WCHAR wcsPath[2 * _MAX_PATH];

// get object path
wcsPath[0] =3D '\0';
wcsT[0] =3D '\0';
if( argc > 1) {
mbstowcs(wcsPath, argv[1], strlen(argv[1]) + 1);
wcsupr(wcsPath);
}
else {
fprintf(stderr, "Object path must be specified\n");
return(1);
}

// get print string
if(argc > 2)
mbstowcs(wcsT, argv[2], strlen(argv[2]) + 1);
else
wcscpy(wcsT, L"Hello World");

printf("Linking to object %ws\n", wcsPath);
printf("Text String %ws\n", wcsT);

// Initialize the OLE libraries
hRslt =3D CoInitializeEx(NULL, COINIT_MULTITHREADED);

if(SUCCEEDED(hRslt)) {


hRslt =3D CreateFileMoniker(wcsPath, &pmk);
if(SUCCEEDED(hRslt))
hRslt =3D BindMoniker(pmk, 0, IID_IHello, (void **)&pHello);

if(SUCCEEDED(hRslt)) {

// print a string out
pHello->PrintSz(wcsT);

Sleep(2000);
ulCnt =3D pHello->Release();
}
else
printf("Failure to connect, status: %lx", hRslt);

// Tell OLE we are going away.
CoUninitialize();
}

return(0);
}




Apprentice Hacker
#!/usr/local/bin/perl
$msg=3D"Hello, world.\n";
if ($#ARGV >=3D 0) {
while(defined($arg=3Dshift(@ARGV))) {
$outfilename =3D $arg;
open(FILE, ">" . $outfilename) || die "Can't write $arg: $!\n";
print (FILE $msg);
close(FILE) || die "Can't close $arg: $!\n";
}
} else {
print ($msg);
}
1;




Experienced Hacker
#include <stdio.h>
#define S "Hello, World\n"
main(){exit(printf(S) =3D=3D strlen(S) ? 0 : 1);}




Seasoned Hacker
% cc -o a.out ~/src/misc/hw/hw.c
% a.out




Guru Hacker
% echo "Hello, world."




New Manager
10 PRINT "HELLO WORLD"
20 END




Middle Manager
mail -s "Hello, world." bob@b12
Bob, could you please write me a program that prints "Hello,
world."?
I need it by tomorrow.
^D




Senior Manager
% zmail jim
I need a "Hello, world." program by this afternoon.




Chief Executive
% letter
letter: Command not found.
% mail
To: ^X ^F ^C
% help mail
help: Command not found.
% damn!
!: Event unrecognized
% logout

------------------------------------------------------------------------
--------Anonymous=20

-----Original Message-----
From: Gryffyn, Trevor [mailto:TGryffyn@air-cargo-inc.com]=20
Sent: Thursday, May 20, 2004 10:02 AM
To: php-windows@lists.php.net
Cc: Charles P. Killmer
Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get

Rube Goldberg would appreciate it.

> -----Original Message-----
> From: Charles P. Killmer [mailto:charlesk@netgaintechnology.com]
> Sent: Thursday, May 20, 2004 11:01 AM
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
>=20
> How is this=20
> $String =3D implode(explode($String, $OldChar), $NewChar); different =


> than
> $String =3D str_replace($OldChar, $NewChar, $String);
>=20
> Charles Killmer
>=20
> -----Original Message-----
> From: Svensson, B.A.T. (HKG) [mailto:B.A.T.Svensson@lumc.nl]
> Sent: Thursday, May 20, 2004 9:48 AM
> To: 'php-windows@lists.php.net '
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
> In your second if you do a count on the occurence of a character, but=20
> don't use the result, why not use strpos() directly?
>=20
> Also if you just want to replace a single char with another single=20
> char, then you might like to do like this:
>=20
> $String =3D implode(explode($String, $OldChar), $NewChar);
>=20
>=20
>=20
> -----Original Message-----
> From: George Pitcher
> To: php-windows@lists.php.net
> Sent: 20-5-2004 15:43
> Subject: RE: [PHP-WIN] Passing +, =3D, - at post and get
>=20
> And doing a bit more, I find that '=3D' and '-' are passing through OK =


> so I'll need to train my users to use an alternative to '+'.
>=20
> The choking seems to be with my parsing function, which I have pasted=20
> in
> below:
> =

=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> function sql_fltr($sql,$field,$input){
> if(strlen($input)>0){
> if( substr_count($input,"=3D")>0 | substr_count($input,"
> -")>0 |
> substr_count($input," +")>0 ){
> $output =3D "";
> $temp =3D str_replace(" -","|-",(str_replace("
> -","|-",($input))));
> $temp =3D explode("|",$temp);
> for ($i =3D 0; $i <=3D sizeof($temp); $i++){
> if (substr($temp[$i],0,1)=3D=3D"*"){
> $temp[$i] =3D $field." like
> '".rtrim(str_replace("*","%",$temp[$i]))."%'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=3D=3D"-"){
> $temp[$i] =3D " and ".$field." not
> like
> '".rtrim(str_replace("*","%",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)=3D=3D"=3D"){
> $temp[$i] =3D " and
> ".$field."=3D'".rtrim(str_replace("=3D","",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } elseif (substr($temp[$i],0,1)!=3D"+" &&=20
> substr($temp[$i],0,1)!=3D"-"&&substr($temp[$i],0,1)!=3D"*" &&=20
> substr($temp[$i],0,1)!=3D"=3D"){
> $temp[$i] =3D "and ".$field." like
> '%".rtrim(str_replace("=3D","",$temp[$i]))."'";
> $output.=3D $temp[$i]."|";
> } else {
> $temp[$i] =3D "
> ".$field."=3D'".rtrim($temp[$i])."'";
> $output.=3D $temp[$i]."|";
> }
> }
> $output =3D " AND
> ".substr($output,0,strlen($output)-1);
> } else {
> $temp =3D $input;
> if (substr($temp,0,1)=3D=3D"*"){
> $temp =3D $field." like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=3D=3D"-"){
> $temp =3D $field." not like
> '".rtrim(str_replace("*","%",$temp))."'";
> } elseif (substr($temp,0,1)=3D=3D"=3D"){
> $temp =3D
> $field."=3D'".rtrim(str_replace("=3D","",$temp))."'";
> } elseif (substr($temp,0,1)!=3D"+" &&=20
> substr($temp,0,1)!=3D"-"&&substr($temp,0,1)!=3D"*" &&=20
> substr($temp,0,1)!=3D"=3D"){
> $temp =3D $field." like
> '%".rtrim(str_replace("=3D","",$temp))."'";
> } else {
> $temp =3D $field."=3D'".rtrim($temp)."'";
> }
> $output =3D " AND ".$temp;
> }
> } else {
> $output =3D "";
> }
> return $output;
> }
> =

=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D
> This works fine if the user has eneterd either no control or the *=20
> wildcared with the criteria.
>=20
> Any suggestions?
>=20
> Cheers
>=20
> George
>=20
>=20
> query
> File.php?Query=3D'; drop
>=20
> both from
> a
> searching.
> getting
> visit:
> unsubscribe, visit:=20
>=20
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
> http://www.php.net/unsub.php
>=20
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
> http://www.php.net/unsub.php
>=20
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:=20
> http://www.php.net/unsub.php
>=20
>=20

B.A.T. Svensson

2004-05-21, 6:30 am

Charlers,

thanks for your comment.

Your suggestion different in the respect that it is better.

(My appiligizes about my ingorance with the PHP API.)

-----Original Message-----
From: Charles P. Killmer
To: php-windows@lists.php.net
Sent: 20-5-2004 17:00
Subject: RE: [PHP-WIN] Passing +, =, - at post and get

How is this
$String = implode(explode($String, $OldChar), $NewChar);
different than
$String = str_replace($OldChar, $NewChar, $String);

Charles Killmer
-----Original Message-----
From: Svensson, B.A.T. (HKG) [mailto:B.A.T.Svensson@lumc.nl]
Sent: Thursday, May 20, 2004 9:48 AM
To: 'php-windows@lists.php.net '
Subject: RE: [PHP-WIN] Passing +, =, - at post and get

In your second if you do a count on the occurence of a character, but
don't use the result, why not use strpos() directly?

Also if you just want to replace a single char with another single char,
then you might like to do like this:

$String = implode(explode($String, $OldChar), $NewChar);



-----Original Message-----
From: George Pitcher
To: php-windows@lists.php.net
Sent: 20-5-2004 15:43
Subject: RE: [PHP-WIN] Passing +, =, - at post and get

And doing a bit more, I find that '=' and '-' are passing through OK so
I'll need to train my users to use an alternative to '+'.

The choking seems to be with my parsing function, which I have pasted in
below:
========================================
=========
function sql_fltr($sql,$field,$input){
if(strlen($input)>0){
if( substr_count($input,"=")>0 | substr_count($input,"
-")>0 |
substr_count($input," +")>0 ){
$output = "";
$temp = str_replace(" -","|-",(str_replace("
-","|-",($input))));
$temp = explode("|",$temp);
for ($i = 0; $i <= sizeof($temp); $i++){
if (substr($temp[$i],0,1)=="*"){
$temp[$i] = $field." like
'".rtrim(str_replace("*","%",$temp[$i]))."%'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=="-"){
$temp[$i] = " and ".$field." not
like
'".rtrim(str_replace("*","%",$temp[$i]))."'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)=="="){
$temp[$i] = " and
".$field."='".rtrim(str_replace("=","",$temp[$i]))."'";
$output.= $temp[$i]."|";
} elseif (substr($temp[$i],0,1)!="+" &&
substr($temp[$i],0,1)!="-"&&substr($temp[$i],0,1)!="*" &&
substr($temp[$i],0,1)!="="){
$temp[$i] = "and ".$field." like
'%".rtrim(str_replace("=","",$temp[$i]))."'";
$output.= $temp[$i]."|";
} else {
$temp[$i] = "
".$field."='".rtrim($temp[$i])."'";
$output.= $temp[$i]."|";
}
}
$output = " AND
".substr($output,0,strlen($output)-1);
} else {
$temp = $input;
if (substr($temp,0,1)=="*"){
$temp = $field." like
'".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=="-"){
$temp = $field." not like
'".rtrim(str_replace("*","%",$temp))."'";
} elseif (substr($temp,0,1)=="="){
$temp =
$field."='".rtrim(str_replace("=","",$temp))."'";
} elseif (substr($temp,0,1)!="+" &&
substr($temp,0,1)!="-"&&substr($temp,0,1)!="*" &&
substr($temp,0,1)!="="){
$temp = $field." like
'%".rtrim(str_replace("=","",$temp))."'";
} else {
$temp = $field."='".rtrim($temp)."'";
}
$output = " AND ".$temp;
}
} else {
$output = "";
}
return $output;
}
========================================
=========
This works fine if the user has eneterd either no control or the *
wildcared with the criteria.

Any suggestions?

Cheers

George


> -----Original Message-----
> From: George Pitcher [mailto:george.pitcher@ingenta.com]
> Sent: 20 May 2004 2:33 pm
> To: php-windows@lists.php.net
> Subject: RE: [PHP-WIN] Passing +, =, - at post and get
>
>
> Charles,
>
> No way! This site will only have about 3-4 users as its an intranet
> and I'll be parsing everything at the server end.
>
> George
>
>
query[color=darkred]
[color=darkred]
a[color=darkred]
getting[color=darkred]
visit:[color=darkred]
>
> --
> PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
> http://www.php.net/unsub.php
>
>


--
PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
http://www.php.net/unsub.php

--
PHP Windows Mailing List (http://www.php.net/) To unsubscribe, visit:
http://www.php.net/unsub.php

--
PHP Windows Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php
Sponsored Links







Also available: Server administration forum archive | Web Design forum archive | Software forum archive | Hardware reviews archive

Copyright 2008 codecomments.com