- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- A Dark Turn
- Nothing Doing
- Home By Another Way
- Coast Star
- Forsooth
- Epic
- The State of the Arts
- Planing ahead
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
Practical joke that never got reversed?
Admin
Cue 50 references to Bobby Tables...
Admin
And then...?
I want to know if he looked in the source control logs, or asked someone, to find out why it was changed. The answer would be interesting.
Admin
The most likely reason was either "New programmer didn't understand old code and wanted to do it his own way" or "Programmer figured he was going to be fired soon and wanted to go out with a bang".
Admin
I don't know. It looks like they replaced 12 lines of code with 4 lines, so in that sense, this refactoring produced more efficient code. I don't know who uses ODBC anymore though, it is all OLEDB nowadays.
Is that code in Javascript though? If so, that is a horrible practice because someone could just modify your SQL. It is better to just build a parameter string and then do the replacement on the server side.
Here is what I'm talking about:
Dim strSQL As String = "select * from [~TABLENAME~] where ~COLUMN~ = ~VALUE~" strSQL = strSQL.Replace("~TABLENAME~", Request.QueryString("t")) strSQL = strSQL.Replace("~COLUMN~", Request.QueryString("c")) strSQL = strSQL.Replace("~VALUE~", Request.QueryString("v")) 'Now you can execute strSQL
This is a simple example, but you get the picture. Most of our queries have many more parameters, so you have c1/v1, c2/v2, c3/v3, etc.
The bottom line is you always want to keep your data layer on the SERVER and never on the CLIENT, I cannot stress this enough. Well most of the time not on the client, there are some exceptions that I can think of, but those are advanced scenarios.
Admin
insertComment = insertComment.Replace("@Text", "'Somebody has to do it. Might as well be me.'");
Admin
Parameters can be finicky. My guess is that the code written the "right way" did not work, and so to meet their deadline they commented it out and they did the quick and dirty replace with strings method.
Admin
Your SQL is wrong. To allow it to be even more dynamic, it should be more like so: Dim strSQL As String = "sp_execsql 'select * from [~TABLENAME~] ...
Admin
Admin
Teehee. I bet there's a hilarious webcomic out there that illustrates the fun of SQL injection.
Let me see if I can find the link...
Admin
Admin
Too late. TopCod3r has posted. You are now to flame him, not to bother with little Bobby Tables.
Admin
Admin
Good luck finding it, maybe some of the other commenters can help us finding the link...
Admin
Hey guys, I found this hilarious comic:
[image]Admin
It had to be done. http://xkcd.com/327/
Admin
+1 Relevant
Admin
Admin
Admin
Admin
I hope you are joking about using the above code to handle your SQL queries. That is still very susceptible to SQL injection.
Admin
I hope you are joking about using the above code to handle your SQL queries. That is still very susceptible to SQL injection.
Admin
Thanks for the link. That reminds me of the data access library that I wrote at my last job. It basically wrote the SQL for you, and made it so you almost didn't even need to know how to write code in order to write a program. I would have probably been able to sell to other developers and make some money, but I had to sign an intellectual property agreement when I was hired. That link you gave me might be the motivation I need to try to write a newer more powerful version of what I did before. I just won't be able to use any of the same code. Except my version will work with VB.NET, not Tcl, so it will be usable by many more people.
Admin
The only secure application is one that doesn't use the internet, or a computer. I would just mail a product catalog to all potential clients and ask them to pay with a money order.
Admin
And you are very susceptible to TopCod3rs comments.
Admin
Shark Tank has JIM THE BOSS. TDWTF has TopCod3r.
Admin
Mail fraud?
Admin
Simple fix (assumes that the DB is SQL Server)...
Checking that .Name .Email and .Type don't throw NullReference exceptions left as an exercise to the reader.
Admin
Admin
Hey, redundancy is good, right?
Maybe they should uncomment the second query. Then, to make sure everything is working, execute BOTH sections of code. And compare the results. If the output from both is the same, then everything is working great!
Admin
That's friggin' brilliant... Let's see, how about something like http://.../query?t=users&c=1&v=1 which yields:
select * from users where ~1 = 1
Excellent example of secure query programming! It's on the server though, so it must be safe???
Admin
Every forum should have a warning sign: PLEASE DON'T FEED THE TROLLS.
Admin
Yeah right. So: select * from a where b = @name; with signUpEntity.name = ' or 1 <>
becomes select * from a where b = ''' or 1 <> '; or whatever. Doubling single quotes is not a solution :(
Admin
hmm. wouldn't this be easier ? Dim strSQL as String = "sp_execsql '~SQL~'" strSQL = strSQL.Replace("~SQL~",Request.QueryString("SQL")) execute!
Admin
I think you are missing the point, but that's ok, I don't blame you. The reason you don't want to do that is so the client doesn't have to know how to build SQL code, and also so a hacker can't just stick whatever SQL he wants... like deleting your entire orders table.
Admin
Ah. Now you see the problem with your code. replace the V in the query string with v=fake_value; delete from orders;
Admin
Why not replace it with strSQL = "DROP TABLE ORDERS"? That's four lines to one line, think of the efficiency gain!
Admin
Note to all programmers:
What a company focuses on in its interview are three things:
So if they focus on good design to the exclusion of all else, you can be very sure they are answering #3, not #1. Their code will suck.
Admin
In Soviet Russia, strings escape you!
Admin
sb.append("SELECT "); sb.append(" COALESCE(BAG_APRS_AMT, 0.0), ");//1 sb.append("BAG_APRS_DT, ");//2 sb.append("BAG_APRS_DSC, ");//3 <snip>
My WTF is progress. When I asked about this code, the programmer said,"We've had a lot of folks work on this with their own conventions..."
Admin
That's funny, we have no record of little Bobby Tables. Or any other students. Oh. My. GOD.
Admin
Admin
At least JIM is witty in his trollery. Maybe TopCod3r should be FRIERED!
Admin
which works just fine, the "or 1 <> " is still inside the string. a backslash doesnt escape a single quote.
Admin
Admin
From now on Bobby Table is 327 and 179 messes with my brain. CAPTCHA: mara - a misspelling of a dwarf mine?
Admin
Please submit my request:
http://thedailywtf.com/query?t=dual; delete from comments&c=userid&v='TopCod3r' and user_type %3d 'dipsh*t'
Admin
Admin
articleText = articleText.Replace("preseved", "preserved");
Admin
You whiny bastards. TopCod3r is the best thing about this site... Consider it free internet survival training.