Library tutorials & articles

Beginning Active Server Pages

Query Strings

There will be times when you don't want the user to have to submit a form in order to get information. Take for instance, this site. We have a single ASP page - page.asp, which displays every article or code page on this site. But you don't have to enter an ID of the article in order to display it! Instead, the site uses Query Strings. The Query String is a bit of information added to the end of a URL, and takes one of 2 forms:

http://www.mysite.com/mypage.asp?this+is+some+text

and

http://www.mysite.com/mypage.asp?data1=value&data2=another+value

The latter is the most useful and most widely used.

To access the information sent in the query string, you use the Request.QueryString property... what a surprise! If, for example, you accessed your page with the following url:

/mypage.asp?id=4&title=Example+Title

In your ASP page, you could access this information by using Request.QueryString("id") and Request.QueryString("title"). Take a look at the following example:

<%
Response.Write "ID: " & Request.QueryString("id")
Response.Write " Title: " & Request.QueryString("title")
%>

Save this to a file called querystring.asp, and view it. At the moment, you'll see

ID: Title:

This is because no data has been sent in the Query String. Now try adding ?id=876. You will get

ID: 876 Title:

and finally, add ?id=876&title=My+Title, and you will see

ID: 876 Title: My Title

Query Strings can be especially useful when you need to retreive information from a database, but need a category ID, for example. Then, you can simply use

Set rData = cConn.Execute ("SELECT * FROM Categories WHERE ID=" & Request.QueryString("id"))

You will, by now have noticed some different characters in the query string. For example, + replaces a space. However, when you come to access Request.QueryString it is automatically removed again. If you want to convert a string to a query string, use Server.URLEncode. For example,

Server.URLEncode("my text & something ?")

becomes

my+text+%26+something+%3F

You can even make your forms generate a query string, so that instead of 'posting' its data, it generates a querystring instead. To do this, simply remove the method="POST" text from the form tag.

AddThis

Comments

  1. 16 Dec 2006 at 21:38

        Hi,
    When I say I'm an ASP beginner, I mean it! I've only written one trivial bit of code, and got a blank page. I see now that's described in the article snippet below. I did indeed go to the saved .asp page on my hard drive!
    So my questions:
    I have XP, so IIS is presumably installed. In the snippet below, are 'localhost' and c:\inetpub\wwwroot the actual strings to type in? For example, I currently don't have a folder called "inetpub". Do I have to create one? And where on my actual server (starman.co.uk) should I put any ASP pages?
    Alternatively, is there a good introductory book you can recommend?

    • When you create an ASP page, you cannot view it on your hard disk by going to C:MyWebmyasppage.asp. It won't work! That references a direct page on your hard disk, and the server doesn't get a chance to parse any of the ASP code.
    • If you have IIS installed, it means your PC is a server (even if your PC is the only one which can access it)! You can access the pages on the server at http://localhost/ or http://PCName/. The physical location of your web site is by default C:\inetpub\wwwroot. Save your ASP pages there, and view them in a browser by visiting the URLs above.





  2. 04 Oct 2006 at 06:26

    hi,

    its first i started ASP.I want to know how to save the files.whats the extensions...Where can i get the sample programs

  3. 28 Dec 2004 at 08:13

    Are you running IIS ? And are you viewing it in your browser via the correct URL? (ie something starting with http:// rather than file:// ) ?

  4. 28 Dec 2004 at 08:12

    It does - you just can't see it We've got an ISAPI filter that rewritse /show/1010/ to something like /show.aspx?id=1010

  5. 12 Dec 2004 at 17:52

    Is there something special I have to do besides saving it as a .asp file, or does it just not work on my server? It just spits out the code, even HTML, as plain text.


    Code:
    <html>
    Let's see if ASP works!<br>
    <%
    Response.Write "Yep!"
    %>
    </html>

  6. 12 Dec 2004 at 17:46

    "The VB code can act on information passed to the page, such as from an internet form or a querystring (this is data passed in the URL after the ? ... take a look at this pages URL!)"


    http://www.developerfusion.com/show/1010 doesn't have a question mark in it...

  7. 31 Mar 2004 at 19:34

    you can not include a file from a remote storage site other than the one your website is being hosted on , like writing <!--#include file = " www.someplace.com/somefile.inc " --> but by using asp tear codes you can if you have any support this features.

  8. 04 Feb 2004 at 21:30

    What do I do if I need to include a file from a remote storage site other than the one my website is being hosted on. The following doesn't work anymore


    <!--#include file = " www.someplace.com/somefile.inc " -->


    or even less the " virtual " call which starts searching the virtual directory the website is stored on.


    What now?


    Do I need to write a routine to access the file remotely then spilling it onto the page using response.write???



  9. 03 Feb 2004 at 10:58

    The trick for this is to get .NET to generate a TLB library for your the .NET class. In Vs.NET, you can modify the current build profile and set the "Register for COM Interop" section to true. See http://www.c-sharpcorner.com/Code/2002/April/COMInteropP2AJ.asp for more information.

  10. 03 Feb 2004 at 08:58

    hi all,


            I am very new to ASP technology.  
            I am in a need to use DLLs (written in C#) in ASP Pages.
            Could anyone suggest me how to proceed.


    Regards,
    MAK,

  11. 02 Feb 2004 at 00:25

     i'd used ActiveX treeview control in my page and created tree by using ASP codings. but the tree is shown as collapsed one on load. i'd tried "TreeView1.Nodes(count).EnsureVisible " which produces an error of "index out of bounds". anyone pls help me as early as possible as i 've to complete by today itself. Thanks

  12. 05 Jan 2004 at 04:49

    thanks, but it wasn't the sql. i did that. it's long since solved.

  13. 05 Jan 2004 at 01:49

    chk your SQL statement. Stop before execting cConn.Execute sSQL . Print sSQL and try executing the same in the backend. If it doesnt work then you need to change the SQL statement.

  14. 13 Nov 2003 at 15:43

    i solved the problem a while ago, but i forgot how.

  15. 12 Nov 2003 at 18:18

    heppens to be that i have the same prolem.

  16. 21 Oct 2003 at 00:51

    I'm beginner of ASP.I make my thesis with ASP.But I've got problem for building project in Visual InterDev.I'd already installed IIS5.It shows web server can't connect.How I do?If it's cause of IIS error,please explain me step by step.let me know solution during five days.please help me.

  17. 15 Jul 2003 at 09:07

    It doesn't work it all. I created the table using Access and set of the OBDC fine. What's wrong?

  18. 15 Jul 2003 at 06:27

    I get this error when I submit forminput.asp:


    Microsoft OLE DB Provider for ODBC Drivers error '80040e14'


    [Microsoft][ODBC Microsoft Access Driver] Unknown


    /forminput.asp, line 12


    What's wrong? I even copied the code over exactly.
    the error's with this line:
    cConn.Execute sSQL

  19. 23 Jun 2003 at 02:54

    Quote:
    [1]Posted by JadesNet on 22 May 2003 09:07 AM[/1]
     I tried this code out exactly, but I get an INSERT INTO syntax error.  I have also tried using the rs.AddNew to add to my database but I get a read-only error.  I have tried changing the lock type and cursor types around but I can't get anything to work.


    pls see t he comment

  20. 23 Jun 2003 at 02:53

    U Have to include a file name adovbs.inc file i yr asp page. thenu can use the addnew and update methods

  21. 22 May 2003 at 09:07

     I tried this code out exactly, but I get an INSERT INTO syntax error.  I have also tried using the rs.AddNew to add to my database but I get a read-only error.  I have tried changing the lock type and cursor types around but I can't get anything to work.

  22. 03 Jun 2002 at 20:39

    One thing to note, this only works on pages which have been posted to

Leave a comment

Sign in or Join us (it's free).

Related discussion