Solved

C Programming: substring extraction

Posted on 2013-10-26
8
332 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
  • 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
Problems using Powershell and Active Directory?

Managing Active Directory does not always have to be complicated.  If you are spending more time trying instead of doing, then it's time to look at something else. For nearly 20 years, AD admins around the world have used one tool for day-to-day AD management: Hyena. Discover why

 
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

Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
stack 22 172
What technology should I use for communication Raspberry Pi 2b and LapTop java application 2 134
convert char array to number in c 5 86
How to learn Linux? 10 67
Have you thought about creating an iPhone application (app), but didn't even know where to get started? Here's how: ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ Important pre-programming comments: I’ve never tri…
This is a short and sweet, but (hopefully) to the point article. There seems to be some fundamental misunderstanding about the function prototype for the "main" function in C and C++, more specifically what type this function should return. I see so…
The goal of this video is to provide viewers with basic examples to understand and use structures 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.

829 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