Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			Search - "sanitize input"
		- 
				    					
					
					Being a programmer for a while now it always irritates me to try to explain what I'm working on to friends and family. I forget what I knew before I developed. I'm always like "I made the strings in the database- oh I mean the words...well they're actually more like strings of letters- well anyway I made a code to sanitize the user input- I mean make it so it is secure before uhhh saving." I spend so much time watering what I'm saying down I forget what I'm talking about
 
 It's not even funny. It'd be funny if one single person in my family or friend group understood what I meant to some degree.3
- 
				    					
					
					Here's an example of what happens when you don't sanitize your input.
 
 The software in question runs in the user's browser and is used to display text from a Twitch chat.
 
 https://youtu.be/2GtbY1XWGlQ2
- 
				    					
					
					I dont understand the Log4j vulnerability.
 
 Isnt the ability to execute code a feature they added so that you can add dynamic data to the logs?
 
 If it is a feature then isnt it written in the documentation?
 
 Is the problem that a lot of companies forgot to sanitize the input before logging it?23
- 
				    					
					
					Guys. Sanitize the Tags input length. Here on devrant. Call the devs, I don't know who they are...8
- 
				    					
					
					YGGG IM SO CLOSE I CAN ALMOST TASTE IT.
 
 Register allocation pretty much done: you can still juggle registers manually if you want, but you don't have to -- declaring a variable and using it as operand instead of a register is implicitly telling the compiler to handle it for you.
 
 Whats more, spilling to stack is done automatically, keeping track of whether a value is or isnt required so its only done when absolutely necessary. And variables are handled differently depending on wheter they are input, output, or both, so we can eliminate making redundant copies in some cases.
 
 Its a thing of beauty, defenestrating the difficult aspects of assembly, while still writting pure assembly... well, for the most part. There's some C-like sugar that's just too convenient for me not to include.
 
 (x,y)=*F arg0,argN. This piece of shit is the distillation of my very profound meditations on fuckerous thoughtlessness, so let me break it down:
 
 - (x,y)=; fuck you in the ass I can return as many values as I want. You dont need the parens if theres only a single return.
 - *F args; some may have thought I was dereferencing a pointer but Im calling F and passing it arguments; the asterisk indicates I want to jump to a symbol rather than read its address or the value stored at it.
 
 To the virtual machine, this is three instructions:
 
 - bind x,y; overwrite these values with Fs output.
 - pass arg0,argN; setup the damn parameters.
 - call F; you know this one, so perform the deed.
 
 Everything else is generated; these are macro-instructions with some logic attached to them, and theres a step in the compilation dedicated to walking the stupid program for the seventh fucking time that handles the expansion and optimization.
 
 So whats left? Ah shit, classes. Disinfect and open wide mother fucker we're doing OOP without a condom.
 
 Now, obviously, we have to sanitize a lot of what OOP stands for. In general, you can consider every textbook shit, so much so that wiping your ass with their pages would defeat the point of wiping your ass.
 
 Lets say, for simplicity, that every program is a data transform (see: computation) broken down into a multitude of classes that represent the layout and quantity of memory required at different steps, plus the operations performed on said memory.
 
 That is most if not all of the paradigm's merit right there. Everything else that I thought to have found use for was in the end nothing but deranged ways of deriving one thing from another. Telling you I want the size of this worth of space is such an act, and is indeed useful; telling you I want to utilize this as base for that when this itself cannot be directly used is theoretically a poorly worded and overly verbose bitch slap.
 
 Plainly, fucktoys and abstract classes are a mistake, autocorrect these fucking misspelled testicle sax.
 
 None of the remaining deeper lore, or rather sleazy fanfiction, that forms the larger cannon of object oriented as taught by my colleagues makes sufficient sense at this level for me to even consider dumping a steaming fat shit down it's execrable throat, and so I will spare you bearing witness to the inevitable forced coprophagia.
 
 This is what we're left with: structures and procedures. Easy as gobblin pie.
 
 Any F taking pointer-to-struc as it's first argument that is declared within the same namespace can be fetched by an instance of the structure in question. The sugar: x ->* F arg0,argN
 
 Where ->* stands for failed abortion. No, the arrow by itself means fetch me a symbol; the asterisk wants to jump there. So fetch and do. We make it work for all symbols just to be dicks about it.
 
 Anyway, invoking anything like this passes the caller to the callee. If you use the name of the struc rather than a pointer, you get it as a string. Because fuck you, I like Perl.
 
 What else is there to discuss? My mind seems blank, but it is truly blank.
 
 Allocating multitudes of structures, with same or different types, should be done in one go whenever possible. I know I want to do this, and I know whichever way we settle for has to be intuitive, else this entire project has failed.
 
 So my version of new always takes an argument, dont you just love slurping diarrhea. If zero it means call malloc for this one, else it's an address where this instance is to be stored.
 
 What's the big idea? Only the topmost instance in any given hierarchy will trigger an allocation. My compiler could easily perform this analysis because I am unemployed.
 
 So where do you want it on the stack on the heap yyou want to reutilize any piece of ass, where buttocks stands for some adequately sized space in memory -- entirely within the realm of possibility. Furthermore, evicting shit you don't need and replacing it with something else.
 
 Let me tell you, I will give your every object an allocator if you give the chance. I will -- nevermind. This is not for your orifices, porridges, oranges, morpheousness.
 
 Walruses.16
- 
				    					
					
					It reaaaally annoys me when my business logic is sound but the data is corrupted.
 
 For example, find duplicates in a HashMap<String>.. but I didn't take into account the input could contain a space either before or after.. so I end up wondering: if a HashMap only contains unique keys, how come the count of items in the map is the same as the count of the input keys?! Well.. spaces were the culprit.
 
 "12345" != "12345 ".. and therefore the Map sees it as two distinct keys..
 
 What an annoying bug.
 
 Lesson learned: 1) Sanitize input first and never trust it. 2) Never make assumptions15
- 
				    					
					
					I like to teach sites that don't escape HTML/js in input fields a lesson, and put in a redirect. Where would you redirect them?
 
 I tend to go SFW, like redirecting to a competitor or the NSA.
- 
				    					
					
					Inherited a legacy system from a previous "developer" who wrote code to sanitize input from sql injection in the front end and then called an web method called execSql which accepts am sql statement in a string value!
 
 Obviously the app ran under admin privileges.2









