Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to modify a request in Fiddler?

I'm looking for a simple way to intercept a web request and modify the contents of the request (mainly POSTs) using Fiddler.

This is to test server-side validation.

I have to use Fiddler, however I haven't found a good simple way to do so.

There have been several documented ways to write scripts to intercept traffic and change headers, but I would like to do it without writing a script - this tool needs to be used by the testers and writing/modifying scripts all the time by different testers may be annoying.

Example:

Simple POST with 2 parameters:

field1=foo,  field2=bar 

I would like to intercept the request, modify the value of field2 to be something like bañ (note the ñ, in my case is invalid and that is what I want to test).

like image 491
Justin Avatar asked Feb 04 '15 16:02

Justin


People also ask

How do I edit a response in Fiddler?

Right next to the green Run to Completion button (which you click to send the response) there's a dropdown that lets you choose some default response types. Or, on the Headers inspector, change the response code & message in the textbox at the top.

How do you edit a Fiddler script?

Fiddler's default rules are stored in \Program Files\Fiddler2\Scripts\SampleRules. js. You can change the JScript editor launched from the Rules menu. Click Tools | Fiddler Options and edit the Editor string.

How do you use intercept request Fiddler?

Capture a request using Fiddler. Select the request, right-click, and click Replay > Reissue Requests (Or just click and type R). Select multiple requests and do the same steps. The same request can be run many times using this method.


2 Answers

Ok, posting the answer that I put together from piecing it together from the following youtube video:

Tampering Client Requests and Server Responses with Fiddler


  1. Start fiddler (I'm using Fiddler 4)

  2. You will notice that it intercepts all traffic through all browsers and other applications

  3. Set a filter - this will enable you to view only the data you are interested in

    1. On the right hand side, click on the filters tab
    2. Check 'Use Filters'
    3. On Hosts, use 'Show only the following Hosts'
    4. In the text box below that, put the host you are testing for. In our case for the test environment, put the following: testing.internalsite.com;
    5. In the section called 'Breakpoints', check 'Break request on POST'
  4. Intercept the request

    1. In your browser, navigate to the page which you are testing. In our case, it is the welcome page where we will be doing our testing of the server-side validation: https://testing.internalsite.com/yourapp/welcome.do
    2. Clear all the existing logged requests by hitting the 'X' in the tool ribbon and choosing 'Remove all'.
    3. In your browser, put the data into the form you are interested in testing and hit submit. This is valid data (passes client side validation) which you will be changing with fiddler.
    4. In Fiddler, you will see the request with the red icon. Click on the request to load the details on the right side.
    5. On the Inspectors tab, followed by the WebForms tab, you can modify the parameters of the form which was submitted. Change the data as appropriate for the test.
    6. Hit the 'Run to completion' button
  5. Validate that your response is correct - usually some sort of error message if you are testing the server-side validations

like image 181
Justin Avatar answered Sep 22 '22 06:09

Justin


I use fiddler 4.6.3. You can try this if you are submitting a web form.

Note the post request when you submit a form. Let that request remain in fiddler. Lets modify the request in Fiddler.

1 - Right click request > check "unlock for editing".

2 - Inspector tab > Modify form fields such as username, password etc. in Body section.

3 - Right click request > Replay > Reissue request.

Done ! The only problem with this approach is that you modify the old request. In Charles proxy, this is done in 2-3 clicks vs the many clicks in Fiddler. Plus, you don't have to mess the old request.

like image 36
MasterJoe Avatar answered Sep 21 '22 06:09

MasterJoe