Click here to Skip to main content
Click here to Skip to main content

Using Google Co-op's Custom Search Engine

By , 27 Oct 2006
 

Sample Image - CustomSearchEngine.jpg

Introduction

This article shows how easy it is to create your own custom search engine using ASP.NET and Google Co-op’s Custom Search Engine feature.

Creating Your Search Engine

The very first step you must take is to visit http://www.google.com/coop/cse. (Note that you must have a Google Account. If you don’t have one, ask around. GMail invites are a dime a dozen these days.) Once there, follow the instructions to create your custom search engine.

For this article, I used the following settings:

Sites to Search

Sites to search: www.codeproject.com
How to search these sites: Search only these sites.

Collaborate with others

Who can collaborate: Only people I invite may contribute to this search engine.

Where to Host the Custom Search Engine

You have two options on how you can display your search engine to users: Google can host it for you, or you can host the search box and results on your site. For this article, I opted for the latter.

To configure this option:

  1. Return to the Google Co-op Custom Search Engine site’s home page (http://www.google.com/coop/cse).
  2. Click on the My Search Engines link.
  3. When the list of your custom search engines shows up, click on the link that says “Control Panel”.
  4. Next, click on the link that says “Code”.
  5. Select the radio button next to the option that says “Host a search box and search results on your own site…”.
  6. Also, specify the URL of the page on your site where you want the search results to appear.
  7. Finally, after you select the location where you want to display the AdSense ads in your search results, click the Save Changes button.

Search Box Code and Search Results Code

On that same “Code” page in your custom search engine control panel, you will see two multi-line text boxes containing JavaScript code. The first contains a small form that contains your search box, the second is pure JavaScript that aids in the rendering of your search results.

Using the Google-generated Search Box Code Outside of the Server-side FORM Tag

You can use the search box code generated by Google, provided you place it outside of your web form’s server-side FORM tag. I tested this locally, and it worked beautifully. However, I’m sure I’m not alone in wanting the ability to put the search box somewhere inside the server-side FORM tag and still have my custom search engine operate correctly.

Using ASP.NET Server Controls and HtmlControls to Emulate Google's Search Box Inside the Server-side FORM Tag

I solved this problem by using ASP.NET server controls and HtmlControls to emulate the behavior of Google’s search box form, while still providing the server-side capabilities that we all know and love.

You’ll need to reference the search box JavaScript/HTML code from the Custom Search Engine control panel. I simply included it in my ASPX page in an HTML comment. This is what it looks like:

<!-- SAMPLE CODE ONLY - REPLACE WITH YOUR OWN -->
<!-- Google CSE Search Box Begins -->
<form id="searchbox_014373149466545347614:dygl7dqicp4" action="Default.aspx">
  <input type="hidden" name="cx" value="014373149466545347614:dygl7dqicp4" />
  <input name="q" type="text" size="40" />
  <input type="submit" name="sa" value="Search" />
  <input type="hidden" name="cof" value="FORID:9" />
</form>
<script type="text/javascript" 
  src="http://www.google.com/coop/cse/brand?form=
       searchbox_014373149466545347614%3Adygl7dqicp4"></script>
<!-- Google CSE Search Box Ends -->

You’ll need four ASP.NET controls to mimic the functionality of this form:

  • A HiddenField control to mimic cx
  • A TextBox control to mimic q
  • Another HiddenField control to mimic cof
  • A Button control to mimic sa

I also added a RequiredFieldValidator to prevent postbacks from happening when the user tries to submit the search query with an empty TextBox.

Here are the control declarations from the ASPX file:

<asp:TextBox ID="q" MaxLength="512" Width="275px" AutoPostBack="false" runat="server" />
<asp:Button ID="_btnSearch" Text="Google Search" 
     OnClick="_btnSearch_Click" runat="server" />
<asp:RequiredFieldValidator ID="_rfvQ" ControlToValidate="q" runat="server" />

<asp:HiddenField ID="cx" Value="014373149466545347614:dygl7dqicp4" runat="server" />
<asp:HiddenField ID="cof" Value="FORID:9" runat="server" />

The “dummyHidden” Input Control

You’ll notice in the ASPX page that there is a plain HTML input control called dummyHidden that is never visible to the user. This is necessary in order to force the search button’s Click event to fire on the server side when the search text box has focus and the user hits the Enter key. This only works when there are two or more text boxes in the form. Based on my research, this appears to be an Internet Explorer-specific problem, and it was the only available workaround I could find. If you have a better solution, please let me know.

Finally, you’ll need to copy the SCRIPT include and place it somewhere in your ASPX page.

The Search Results

For this article, the search results are displayed on the same page as the search box. No ASP.NET emulation is necessary here. Simply copy the JavaScript code and paste it into your ASPX file where you want the search results to appear. Here is what it looks like in my ASPX file:

<!-- SAMPLE CODE ONLY - REPLACE WITH YOUR OWN -->
<!-- Google Search Result Snippet Begins -->
<div id="results_014373149466545347614:dygl7dqicp4"></div>
<script type="text/javascript">
  var googleSearchIframeName = "results_014373149466545347614:dygl7dqicp4";
  var googleSearchFormName = "searchbox_014373149466545347614:dygl7dqicp4";
  var googleSearchFrameWidth = 600;
  var googleSearchFrameborder = 0;
  var googleSearchDomain = "www.google.com";
  var googleSearchPath = "/cse";
</script>
<script type="text/javascript" 
  src="http://www.google.com/afsonline/show_afs_search.js"></script>
<!-- Google Search Result Snippet Ends -->

Code-behind: Button.Click

This is where the magic happens. Mercifully, Google uses the GET method to send form data, so we merely need to append our search parameters to the query string and redirect the user to the search results page. For this article, that means simply redirecting the user back to the same page, though the results could easily be displayed on a separate physical page.

The search query from the q TextBox and the HiddenField values are all needed in the query string. See the code below:

protected void _btnSearch_Click (Object sender, EventArgs e)
{
    if (!IsValid)
        return;

    Response.Redirect (
        String.Format(
            "Default.aspx?q={0}&cx={1}&cof={2}",
            HttpUtility.UrlEncode (SanitizeUserInput (q.Text.Trim ())),
            HttpUtility.UrlEncode (cx.Value),
            HttpUtility.UrlEncode (cof.Value)
            ),
        false
        );

    Context.ApplicationInstance.CompleteRequest ();
}

Important: Be sure to take the time to sanitize and URL-encode the user’s input. I have provided a basic function for doing so, but it is your responsibility to ensure that your applications are safe.

Code-behind: Page.Load

The last bit of code is in the page’s Load event handler. All it does is look for the querystring parameter q, and if it exists, it puts that value in the TextBox q so that the user can see the term for which they last searched. Note that this only happens when the request is not a postback. Because of the redirect, we can’t use ViewState to keep track of the last search term.

Again: Remember to sanitize all user input. Your application’s safety is your responsibility!

protected void Page_Load (Object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        String query = Request.QueryString["q"];
        if (!String.IsNullOrEmpty (query))
        {
            q.Text = SanitizeUserInput (HttpUtility.UrlDecode (query.Trim ()));
        }
    }
}

Conclusion

Well, there you have it. With one simple ASP.NET form, we have created a custom search engine that searches only pages on The Code Project. Google Co-op has done an extraordinary job in making this such a simple task for us end users.

History

  • 2006-10-27: Initial release.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Jon Sagara
Software Developer (Senior) Sagara Software, Inc.
United States United States
Member
Jon graduated from Cal Poly with a B.S. Computer Engineering. He is currently building a Silverlight-based report scheduling interface for a pharmaceutical reporting company.
 
When he's not fooling around with computers or reading, he's busy spending time with his super wife, Kelly, his two boys, and their rambunctious dog, Homer.
 
Visit my blog
 
---
 
View my old profile pictures

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
Questioncustomize outputmemberdafuq6 Jan '12 - 1:27 
is there any ways of customizing output? i mean change title size, description color and etc... if it's so how can it be done?
AnswerRe: customize outputmemberJon Sagara9 Jan '12 - 7:31 
I've never done it, but looking at the docs, there appears to be at least some level of customization available to end users:
 
http://code.google.com/intl/en/apis/customsearch/docs/ui.html[^]
Jon Sagara
 
Some see the glass as half-empty, some see the glass as half-full. I see the glass as too big.
 
-- George Carlin

 
Blog | Twitter | Articles

QuestionThanksmemberXmen W.K.19 Jun '11 - 9:04 
Thumbs Up | :thumbsup:

TVMU^P[[IGIOQHG^JSH`A#@`RFJ\c^JPL>;"[,*/|+&WLEZGc`AFXc!L
%^]*IRXD#@GKCQ`R\^SF_WcHbORY87֦ʻ6ϣN8ȤBcRAV\Z^&SU~%CSWQ@#2
W_AD`EPABIKRDFVS)EVLQK)JKQUFK[M`UKs*$GwU#QDXBER@CBN%
R0~53%eYrd8mt^7Z6]iTF+(EWfJ9zaK-i’TV.C\y<pŠjxsg-b$f4ia>
-----------------------------------------------
128 bit encrypted signature, crack if you can

GeneralSearch Results on a Different Page?memberChristopher Irwin7 Jun '11 - 8:06 
Thanks for the article. Extremely helpful! Thumbs Up | :thumbsup:
 
I'm wondering if there is a way to redirect the search results to a different page. This way, I can have the search box at the top of each page (in the MasterPage) and have the visitor redirected to the searchResults.aspx page.
 
Smile | :)
GeneralRe: Search Results on a Different Page?memberJon Sagara9 Jun '11 - 7:33 
I haven't tested this, but, it seems to me that you could have your search button event handler in the master page. When the user clicks the button, redirect them to searchResults.aspx (with the query string parameters appended) instead of Default.aspx.
Jon Sagara
 
Some see the glass as half-empty, some see the glass as half-full. I see the glass as too big.
 
-- George Carlin

 
Blog | Twitter | Articles

GeneralRe: Search Results on a Different Page?memberChristopher Irwin9 Jun '11 - 8:04 
Thanks Jon. I'll give that a try.
 
Smile | :)
GeneralIsValid is not declaredmembervipernet027 Nov '10 - 15:28 
I converted the script to VB using http://www.developerfusion.com/tools/convert/csharp-to-vb/[^]
 
Any help why Im getting a isValid is not declared error?
Partial Class Site
    Inherits System.Web.UI.MasterPage
#Region "Instance Methods -- Event Handlers"
 
    ''' <summary>
    ''' When not a PostBack, if there is a query string parameter named "q" that is not empty, 
    ''' put its contents in the "q" textbox so that the user can see what they last searched for.
    ''' </summary>
    ''' <param name="sender"></param>
    ''' <param name="e"></param>
    Protected Sub Page_Load(ByVal sender As [Object], ByVal e As EventArgs)
        If Not IsPostBack Then
            Dim query As [String] = Request.QueryString("q")
            If Not [String].IsNullOrEmpty(query) Then
                q.Text = SanitizeUserInput(HttpUtility.UrlDecode(query.Trim()))
            End If
        End If
    End Sub
 
    ''' <summary>
    ''' Using the Google form field values, redirect to this page with those values in the URL's
    ''' query string.  Google's JavaScript will pick up these parameters, perform the search, and
    ''' display the results on your page.
    ''' </summary>
    ''' <param name="sender"></param>
    ''' <param name="e"></param>
    Protected Sub _btnSearch_Click(ByVal sender As [Object], ByVal e As EventArgs)
        If Not IsValid Then
            Return
        End If
 
        Response.Redirect([String].Format("Site.master?q={0}&cx={1}&cof={2}", HttpUtility.UrlEncode(SanitizeUserInput(q.Text.Trim())), HttpUtility.UrlEncode(cx.Value), HttpUtility.UrlEncode(cof.Value)), False)
 
        Context.ApplicationInstance.CompleteRequest()
    End Sub
 
    ''' <summary>
    ''' Strip tags from user input.
    ''' </summary>
    ''' <param name="text"></param>
    ''' <returns></returns>
    Private Function SanitizeUserInput(ByVal text As [String]) As [String]
        If [String].IsNullOrEmpty(text) Then
            Return [String].Empty
        End If
 
        Dim rxPattern As [String] = "<(?>""[^""]*""|'[^']*'|[^'"">])*>"
        Dim rx As New Regex(rxPattern)
        Dim output As [String] = rx.Replace(text, [String].Empty)
 
        Return output
    End Function
 
#End Region
 

 

End Class
 

GeneralWidth of iframe too largememberanemiccolo1 Feb '10 - 10:05 
I can't find anyway to make the iframe smaller or edit the way my results look for that matter.
 
How can I use Google's CSE and customize how my results look?
GeneralRe: Width of iframe too largememberJon Sagara1 Feb '10 - 10:37 
anemiccolo,
 
It has been quite some time since I played with Google CSE, so I apologize that I am unable to provide more help other than a link to Google's CSE docs:
 
http://code.google.com/intl/en/apis/customsearch/docs/ui.html[^]
 
Best of luck,
 
Jon Sagara
 
Some see the glass as half-empty, some see the glass as half-full. I see the glass as too big.
 
-- George Carlin

 
.NET Blog | Personal Blog | Articles

GeneralForms authentication and Google Custom SearchmemberGeorg Kakasevski14 Jan '10 - 7:41 
Hi Jon, do you now how to implement Google Custom Search Engine in ASP.NET application where users must be authenticated (using Forms authentication)?
 
www.masterint.mk

GeneralThanks!membervegeta4ss10 Nov '09 - 5:09 
This article was exactly what I was looking for. Thanks for sharing!
GeneralSame as CodeProject CSEmemberAnand@DotNet28 Jun '09 - 21:50 
I need exact search as codeproject cse has, in this sample application when i enter the search string it will search in its own site, i also want the same search engine that will work for only my site.
guys plz help me out, all things are done, but still it search in google index not mine.
GeneralWill target to our site only...memberAnand@DotNet28 Jun '09 - 20:26 
i have create and configured the CSE for my site, but when i search for a keywords it will perform world wide search rather than to my site pages, how can i restrict search to my site only?
GeneralSearch page refreshing twicemembermatharuajay20 May '09 - 3:15 
Hi guys,
 
When I search for any keyword, the result page refreshes twice. The result is shown and the search result page refreshes again 2nd time then stables down.
Any one has an idea on why does it refreshes second time?
 
Thanks in advance.
 
Thanks,
Ajay Matharu
http://www.ajaymatharu.com
GeneralRe: Search page refreshing twicememberJon Sagara20 May '09 - 5:45 
I received this email from a reader a while back -- it may solve your problem:
 
---------
Jon,
 
I may have stumbled across the answer. I added this line to your search results snippet:
 
var googleSearchResizeIframe = false;
 
And that not only removed the refresh that IE7 was forcing, but it also seems to have resolved the issue I had with the page links breaking after the first click.
 
Just wanted to share that, in case you were planning to update your tutorial or someone else noodges you like I've been noodging you.
 
Thanks,
David
---------
 
Jon Sagara
 
Some see the glass as half-empty, some see the glass as half-full. I see the glass as too big.
 
-- George Carlin

 
.NET Blog | Personal Blog | Articles

GeneralRe: Search page refreshing twicemembermatharuajay24 May '09 - 20:04 
Jon,
 
That helped thanks a lot.
 
Regards,
Ajay Matharu
http://www.ajaymatharu.com
GeneralSearch result opening again and again.memberMember 314438510 Feb '09 - 3:08 
Hi,
 
You have created very good work, but I have arised a problem of opening search result again and again in IE, but not in Safari, and Mozilla.
 
Could you and anybody can tell me, what is the problem?
 
Balwant
Sr. Software Engineer.
 
Hi,
 
We proud that we are indian

QuestionHow to get the Google watermark?memberDavid Moody14 Jan '09 - 5:20 
Any idea how to make the Google watermark inside the search box? I've tried several different things but I think ASP.NET is blowing them out of the water.
 
Thanks,
David
AnswerRe: How to get the Google watermark?memberytzipp26 Feb '09 - 2:48 
Hi David,
 
To get google watermark this is what you should do:
 
Replace the line
 
<script type="text/javascript"
src="http://www.google.com/coop/cse/brand?form=searchbox_014373149466545347614%3Adygl7dqicp4"></script>
 

in the following code (which atually based on the code retrieved from google):
 
<script type="text/javascript">
(function() { var q = document.getElementById('<%= q.UniqueID %>'); if (q) { var n = navigator; var l = location; if (n.platform == 'Win32') { q.style.cssText = 'border: 1px solid #7e9db9; padding: 2px;'; } var b = function() { if (q.value == '') { q.style.background = '#FFFFFF url(http://www.google.com/coop/images/google_custom_search_watermark.gif) left no-repeat'; } }; var f = function() { q.style.background = '#ffffff'; }; q.onfocus = f; q.onblur = b; if (!/[&?]q=[^&]/.test(l.search)) { b(); } } })();
</script>
 
and that's it!!!
GeneralRe: How to get the Google watermark?memberboydd_uk16 Mar '09 - 23:49 
This works fine, but one problem. If you web site uses https secure pages as well as http pages, you get that really annoying message do you want to display unsecured items, etc.
 
Anyway around this. In asp.net code I have a fixURL procedure that deals with the swapping of http/https? Not sure how I do this in javascript.
QuestionI have one questionmemberintsafi28 Oct '08 - 7:25 
your code work very well and thank you so much
 
but I have one question:
 
can we put this (Google Co-op's Custom Search Engine) in more than one page
 
and every page searches in one different site?
 

and thanks again
QuestionHow it will be in vb.net?memberKubulos9 Aug '08 - 0:20 
Please, can you write this example in vb.net? Tnx very much!
AnswerRe: How it will be in vb.net?memberNika Asgari7 Sep '08 - 2:06 
http://labs.developerfusion.co.uk/convert/csharp-to-vb.aspx
 
you can use this address it convert C# codes to Vb.net
 
Nika Asgari

GeneralThanksmembersnashter26 Jan '08 - 5:59 
Good article. This really helped me out. I have my page loading twice, but I will follow the instructions left by others. Smile | :)
GeneralAnother way of doing it is JavascriptmemberYanDav24 Jan '08 - 21:31 
HTML CODE / GOOGLE CODE
 
<!-- Google CSE Search Box Begins -->
<input type="text" name="q" size="30" onkeypress="onEnter();"/>
<input type="button" onclick="search();" name="sa" value="Search" />
<input type="hidden" name="cx" value="YOUR CX VALUE" />
<input type="hidden" name="cof" value="YOUR COF VALUE" />
 
<input name="dummyHidden" value="" style="visibility:hidden;display:none;" />
<!-- <Google CSE Search Box Ends -->
 
I needed to make some changes in the google script and then change the src to it:
 
(function() { var q = document.getElementById('q'); if (q) { var n = navigator; var l = location; if (n.platform == 'Win32') { q.style.cssText = 'border: 1px solid #7e9db9; padding: 2px;'; } var b = function() { if (q.value == '') { q.style.background = '#FFFFFF url(images/google_custom_search_watermark.gif) left no-repeat'; } }; var f = function() { q.style.background = '#ffffff'; }; q.onfocus = f; q.onblur = b; if (!/[&?]q=[^&]/.test(l.search)) { b(); } } })();
 

<script type="text/javascript" src="scripts/googleCSE.js"></script>
 

// call the google search
function search()
{
var q = $get("q");
var cof = $get("cof");
var cx = $get("cx");
location.href = "Default.aspx?q=" + encodeURIComponent(q.value) + "&cof=" + encodeURIComponent(cof.value) + "&cx=" + encodeURIComponent(cx.value)
}
 
// for setting the search term back in the textbox call this function on page load
function setSearchTerm()
{
var q = $get("q");
var regEx = new RegExp("([^?=&]+)(=([^&]*))?");
var m = regEx.exec(location.search);
 
if (m && m[0] && m[0,3])
q.value = decodeURIComponent(m[0,3]);
else
q.value = "";
}
 
// to apply a search when enter is pressed
function onEnter()
{
if (event.keyCode == 13)
{
search();
}
}

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web02 | 2.6.130523.1 | Last Updated 28 Oct 2006
Article Copyright 2006 by Jon Sagara
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid