Solved

C Programming: substring extraction

Posted on 2013-10-26
8
334 Views
Last Modified: 2013-10-28
I am trying to create a HTTP GET request, which requires the following format:
GET {Request-URI) HTTP/1.1
Host: {host_name}

If I have a string such as "http://www.csun.edu/~steve", how do I extract the {host_name} part (http://www.csun.edu), and how do I extract the {Request_URI} part (/~steve)?

I need a strategy that will do this dynamically. In other words, the next string might be "http://www.cnn.com/money", or no directory structure at all like "http://www.google.com".
0
Comment
Question by:pzozulka
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 3
8 Comments
 
LVL 28

Accepted Solution

by:
Bill Bach earned 500 total points
ID: 39603269
You can do this via brute force, or through the use of a parser.  I'd do something like brute force, if you know that all input is a valid URL.  The logic would look like:
1) Detect and strip off the "http://", as this is not part of the host name.
2) Set HostName and Request strings to "".
3) Copy characters off to the HostName string until you find the next "/" or EOL.  
4) If EOL, exit and return strings as needed.
5) Copy from current position to EOL to Request string.
6) Exit and return strings as needed.

Can you create the working code from this description?
0
 
LVL 8

Author Comment

by:pzozulka
ID: 39603298
Thank you very much. I think this is exactly what I was looking for. I will try to implement in code, and will get back soon with my solution.
0
 
LVL 8

Author Comment

by:pzozulka
ID: 39604278
I think I got it:
// parse host to strip http:// and any dirs
// *************************************
char src[50];
char dest[100];
char *httpProto = "http://";

if((strstr(host, httpProto)) != NULL) { //does host contain http://
	memset(dest, '\0', sizeof(dest));
	strcpy(dest, host+strlen(httpProto));
	fprintf(configfp,"Stripped HTTP:\n%s\n",dest);
	// http:// stripped -- use dest
}
// *************************************

// copy chars off to the hostName until you find "/" or '\0'
// *************************************
char request[50];
char hostName[100];
int a, b = 0, forwardSlash = 0;

if((strstr(host, httpProto)) != NULL) { // host contains http://
	for(a=0; dest[a] != '\0'; a++) { //copy domain name into hostName
		if(dest[a] != '/') {
			hostName[a] = dest[a];
		}
		else { // forward slash found
			forwardSlash = 1;
			break;
		}
	}
	while( (forwardSlash == 1) && (dest[a] != '\0')) { 
		request[b] = dest[a];
		a++;
		b++;
	}
	fprintf(configfp,"Domain:\n%s\n",hostName);
	fprintf(configfp,"Request: \n%s\n",request);
}
else { // host didn't contain http:// to begin with
...
// extract directory after domain name
}

Open in new window

0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 8

Author Comment

by:pzozulka
ID: 39604280
I know I didn't have to extract hostName twice (once in the IF and once in the ELSE) depending if the original host name had a http:// in it or not. I just realized that.
0
 
LVL 8

Author Comment

by:pzozulka
ID: 39604323
I'm doing something wrong. Here's what I get:
fprintf(configfp,"Host:\n%s\n",host);
fprintf(configfp,"Domain:\n%s\n",hostName);

Open in new window

Host:
www.facebook.com
Domain:
www.facebook.comðÙÐÁ
0
 
LVL 28

Expert Comment

by:Bill Bach
ID: 39604535
You never null-terminate the Hostname string.  Add line 30.5:
    hostName[a]=0;
0
 
LVL 8

Author Comment

by:pzozulka
ID: 39604585
I also have another urgent question, if you could please take a look at:

http://www.experts-exchange.com/Programming/Languages/C/Q_28278601.html
0
 
LVL 28

Expert Comment

by:Bill Bach
ID: 39605406
Looks like two good answers to that one already.  I agree that allocating memory in a function is a bad idea, and I also agree that the issue is in the malloc to begin with. "buffer" is defined as "char **", but the malloc call (which returns "char *") gets assigned to buffer directly.  Depending on the first few bytes in the string buffer, this will try to be interpretted as another pointer, and it breaks.
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

An Outlet in Cocoa is a persistent reference to a GUI control; it connects a property (a variable) to a control.  For example, it is common to create an Outlet for the text field GUI control and change the text that appears in this field via that Ou…
Summary: This tutorial covers some basics of pointer, pointer arithmetic and function pointer. What is a pointer: A pointer is a variable which holds an address. This address might be address of another variable/address of devices/address of fu…
Video by: Grant
The goal of this video is to provide viewers with basic examples to understand and use for-loops in the C programming language.
The goal of this video is to provide viewers with basic examples to understand and use switch statements in the C programming language.

730 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question