Beefy Boxes and Bandwidth Generously Provided by pair Networks
There's more than one way to do things

old obfu tricks revealed

by Felonious (Chaplain)
on Jun 17, 2005 at 04:02 UTC ( #467548=obfuscated: print w/replies, xml ) Need Help??

I don't seem to have the time these days to do really involved obfus like I used to, but I thought it would be fun to pass along some of the neat things I've learned while writing them. Tonight's tricks illustrate some oddities you can take advantage of when naming subs, so here's a short illustration:

# a little tricky print "\ntrick one\n"; sub ::0 { print "::0 called\n" } %42->(); # a little more tricky, think about implicit return values print "\ntrick two\n"; sub :: { print ":: called\n" } sub ::1{ print "::1 called\n" } ::->(); # and think about evaluation order print "\ntrick three\n"; sub _ {print "_ called\n"} _ _ -> (); # another trick that eliminates white space in sub declarations print "\ntrick four\n"; sub'x{print "x called\n"} x;
Take special note of the '::' function, it has an odd characteristic in that it doesn't get shown by Deparse in most perl versions (or any?). That makes it a great place to hide stuff that might become too obvious under Deparse. Now, a very simple Japh that demonstrates these all use toghther:
sub _ { print "perl "; ::->() } sub :: { print "hacker\n"} sub ::1 { _ print "another "} sub ::0 { print "just " } 1->(%1->());
Of course, you have to go to greater lengths in the sub bodies than I did in the above for the output to be suprising to anyone, but I think the '1->(%1->())' line makes it suffuciently interesting to figure out.

Finally, sometimes messing with the sysbol table in this manner exposes even deeper mysteries to exploit...
Contemplate why the below causes an endless loop just by re-ordering two of the subs...
Note: May not behave the same on all perl versions. Please post your version/platform if the below does not recurse?
sub :: { print "hacker\n"} sub _ { print "perl "; ::->() } sub ::1 { _ print "another "} sub ::0 { print "just " } 1->(%1->());
Try deparsing the two versions and observing the difference.

Well, I hope this has been interesting and possibly leads some others to investigate oddities in how the symbol table behaves. If there's interest, I may post a few other interesting tricks I picked up another time.

-- So prophesied the shakespearean monkeys, and so it shall be.

Replies are listed 'Best First'.
Re: old obfu tricks revealed
by Felonious (Chaplain) on Jun 18, 2005 at 04:02 UTC
    Ok, tonight's trick simply illustrates the principle of replacing the standard '/' separator in substitutions with other characters. It's a simple and well known trick, but can be used pretty effectively in some instances. Here goes:
    $_ = "Sello World\n"; # think about alternative separators s'S'H's; print; # Deparse and compare the difference in the next two s=>o=>O=>o; print; s,o,O,o; print; # and now, for the mystery... sub s { ("x","y","z"); } s()[0]; print;
    The 'mystery' has nothing to do with mixing separators or that you can use 4 instead of three, that's pretty simple stuff... it's why it replaces anything at all, much less the character it does. Happy obfu-writing!

    -- So prophesied the shakespearean monkeys, and so it shall be.
Re: old obfu tricks revealed
by jdalbec (Deacon) on Jun 18, 2005 at 13:15 UTC

Log In?

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: obfuscated [id://467548]
Approved by Old_Gray_Bear
Front-paged by monsieur_champs
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others wandering the Monastery: (2)
As of 2023-09-24 03:03 GMT
Find Nodes?
    Voting Booth?

    No recent polls found