shell variable security

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




I have to write some BASH scripts.

We have all heard about security problems with shell variables

(i.e. when entering a name someone enters something like "Tony; rm -rf /root/*" )

so that if the BASH scripts echoes it will will do something like echo Tony; rm -rf /root/*.

 

Now we have honest users here, but I still want to do some checks.  If I read in or get a shell variable from a user

I could do something like

 

    echo "$VAR" | grep '[^a-zA-Z/_-]'

    if [ $? -eq 0 ]

    then

        echo "You have entered a bad character"

        exit 1

   fi

 

but that still runs into the problem like above with the echo.  I also could do

 

case "$VAR" in

 

    \;|\:) echo "you have a bad character"   

        ;;

 

esac

 

 

but I am not sure that is best either.  Is there anyway to validate shell variables?

I know _javascript_, etc., has something like url_encode() 

-- 
fedora-list mailing list
fedora-list@xxxxxxxxxx
To unsubscribe: https://www.redhat.com/mailman/listinfo/fedora-list
[Index of Archives]     [Older Fedora Users]     [Fedora Announce]     [Fedora Package Announce]     [EPEL Announce]     [Fedora Magazine]     [Fedora News]     [Fedora Summer Coding]     [Fedora Laptop]     [Fedora Cloud]     [Fedora Advisory Board]     [Fedora Education]     [Fedora Security]     [Fedora Scitech]     [Fedora Robotics]     [Fedora Maintainers]     [Fedora Infrastructure]     [Fedora Websites]     [Anaconda Devel]     [Fedora Devel Java]     [Fedora Legacy]     [Fedora Desktop]     [Fedora Fonts]     [ATA RAID]     [Fedora Marketing]     [Fedora Management Tools]     [Fedora Mentors]     [SSH]     [Fedora Package Review]     [Fedora R Devel]     [Fedora PHP Devel]     [Kickstart]     [Fedora Music]     [Fedora Packaging]     [Centos]     [Fedora SELinux]     [Fedora Legal]     [Fedora Kernel]     [Fedora OCaml]     [Coolkey]     [Virtualization Tools]     [ET Management Tools]     [Yum Users]     [Tux]     [Yosemite News]     [Gnome Users]     [KDE Users]     [Fedora Art]     [Fedora Docs]     [Asterisk PBX]     [Fedora Sparc]     [Fedora Universal Network Connector]     [Libvirt Users]     [Fedora ARM]

  Powered by Linux