What Does Cross-Site Request Forgery Mean?
Cross-site request forgery (CSRF) is a type of website exploit carried out by issuing unauthorized commands from a trusted website user. CSRF exploits a website’s trust for a particular user’s browser, as opposed to cross-site scripting, which exploits the user’s trust for a website.
This term is also known as session riding or a one-click attack.
Techopedia Explains Cross-Site Request Forgery
A CSRF usually uses a browser’s “GET” command as the exploit point. CSR forgers use HTML tags such as “IMG” to inject commands into a specific website. A particular user of that website is then used as a host and an unwitting accomplice. Often the website does not know that it is under attack, since a legitimate user is sending the commands. The attacker might issue a request to transfer funds to another account, withdraw more funds or, in the case of PayPal and similar sites, send money to another account.
A CSRF attack is hard to execute because a number of things have to happen in order for it to succeed:
- The attacker must target either a website that does not check the referrer header (which is common) or a user/victim with a browser or plug-in bug that allows referrer spoofing (which is rare).
- The attacker must locate a form submission at the target website, which must be capable of something like changing the victim’s email address login credentials or doing money transfers.
- The attacker must determine the correct values for all of the form’s or URL’s inputs. If any of them are required to be secret values or IDs that the attacker cannot accurately guess, the attack will fail.
- The attacker must lure the user/victim to a Web page with malicious code while the victim is logged in to the target site.
For example, suppose that Person A is browsing his bank account while also in a chat room. There is an attacker (Person B) in the chat room who learns that Person A is also logged in to bank.com. Person B lures Person A to click on a link for a funny image. The “IMG” tag contains values for bank.com’s form inputs, which will effectively transfer a certain amount from Person A’s account into Person B’s account. If bank.com does not have secondary authentication for Person A before the funds are transferred, the attack will be successful.