Melodious Monks,

A small meditation on a current project.

You have an sql db and are going to dynamically generate a record-input screen with Perl script. First temptation is do something like this (pseudo-code):

$sql = "show columns from my_table"; execute while (there are $field_names) { print "<input type='text' name='".$field_name."'>" }
and then the reverse when the form is submitted. BUT, I've now given away the actual column names of my table - one small piece of real info for hackers to exploit.

I could, instead, have a hash of "public" names:

$public_names{$field_1} = "foo"; $public_names{$field_2} = "bar"; foreach $key (keys %public_names) { print "<input type='text' name='".$public_names{$key}."'>" }
But now I have this intermediate association table to maintain. Sooooo, I thought a nifty alternative would be a home-made field name encoder/decoder:
$sql = "show columns from my_table"; execute while (there are $field_names) { $public_name = &encode($field_name); print "<input type='text' name='".$public_name."'>" } sub encode() { $scrambled =~ tr/[a-z]/[w,t,5,s,c,....,7,a]/; return $scrambled; }
with a corresponding decode sub for the returning values in the submitted form. No association tables to maintain - and my field name info is secure.

Wadda y'all think?




Forget that fear of gravity,
Get a little savagery in your life.

In reply to Perl to protect database field name info by punch_card_don

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.